/**
* gammad -- Cooperative gamma server
* Copyright (C) 2016 Mattias Andrée (maandree@kth.se)
*
* This library is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this library. If not, see .
*/
#include
#include
#include "ramps.h"
#include "filter.h"
/**
* Copy the ramp sizes
*
* This macro supports both `struct output`
* and `struct gamma_ramps`
*
* @param dest The destination
* @param src The source
*/
#define COPY_RAMP_SIZES(dest, src) \
((dest)->red_size = (src)->red_size, \
(dest)->green_size = (src)->green_size, \
(dest)->blue_size = (src)->blue_size)
/**
* Information about an output
*/
struct output
{
/**
* -2: double
* -1: float
* 8: uint8_t
* 16: uint16_t
* 32: uint32_t
* 64: uint64_t
*/
signed depth;
/**
* The number of stops in the red gamma ramp
*/
size_t red_size;
/**
* The number of stops in the green gamma ramp
*/
size_t green_size;
/**
* The number of stops in the blue gamma ramp
*/
size_t blue_size;
/**
* `.red_size + .green_size + .blue_size`
* multiplied by the byte-size of each stop
*/
size_t ramps_size;
/**
* Whether gamma ramps are supported
*/
enum libgamma_decision supported;
/**
* The name of the output, will be its EDID
* if available, otherwise it will be the
* index of the partition, followed by a dot
* and the index of the CRTC within the
* partition, or if a name for the connector
* is available: the index of the partition
* followed by a dot and the name of the
* connector
*/
char* name;
/**
* The libgamma state for the output
*/
libgamma_crtc_state_t* crtc;
/**
* Saved gamma ramps
*/
union gamma_ramps saved_ramps;
struct filter* table_filters;
union gamma_ramps* table_sums;
size_t table_alloc;
size_t table_size;
};
/**
* Free all resources allocated to an output.
* The allocation of `output` itself is not freed.
*
* @param this The output
*/
void output_destroy(struct output* this);
/**
* Marshal an output
*
* @param this The output
* @param buf Output buffer for the marshalled output,
* `NULL` just measure how large the buffers
* needs to be
* @return The number of marshalled byte
*/
size_t output_marshal(const struct output* this, void* buf);
/**
* Unmarshal an output
*
* @param this Output for the output
* @param buf Buffer with the marshalled output
* @return The number of unmarshalled bytes, 0 on error
*/
size_t output_unmarshal(struct output* this, const void* buf);
/**
* Compare to outputs by the names of their respective CRTC:s
*
* @param a Return -1 if this one is lower
* @param b Return +1 if this one is higher
* @return See description of `a` and `b`,
* 0 if returned if they are the same
*/
#if defined(__GNUC__)
__attribute__((pure))
#endif
int output_cmp_by_name(const void* a, const void* b);