/** * 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, char* 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 char* 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);