1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
/* See LICENSE file for copyright and license details. */
#include "common.h"
/**
* Just an arbitrary version
*/
#define ANY bits64
/**
* Set the gamma ramps for a CRTC, re-encoding version
*
* @param this The CRTC state
* @param ramps The gamma ramps to apply
* @param depth_user The depth of the gamma ramps that are provided by the user,
* `-1` for `float`, `-2` for `double`
* @param depth_system The depth of the gamma ramps as required by the adjustment method,
* `-1` for `float`, `-2` for `double`
* @param fun Function that is to be used write the ramps, its parameters have
* the same function as those of this function with the same names,
* and the return value too is identical
* @return Zero on success, otherwise (negative) the value of an
* error identifier provided by this library
*/
int
libgamma_internal_translated_ramp_set_(struct libgamma_crtc_state *restrict this, const union gamma_ramps_any *restrict ramps,
signed depth_user, signed depth_system, set_ramps_any_fun *fun)
{
size_t n;
int r;
union gamma_ramps_any ramps_sys;
uint64_t *restrict ramps_full = NULL;
/* Allocate ramps with proper data type */
if ((r = libgamma_internal_allocated_any_ramp(&ramps_sys, ramps, depth_system, &n)))
return r;
/* Allocate intermediary ramps */
if (n) {
if (n > SIZE_MAX / sizeof(*ramps_full)) {
errno = ENOMEM;
free(ramps_sys.ANY.red);
return LIBGAMMA_ERRNO_SET;
}
ramps_full = malloc(n * sizeof(*ramps_full));
if (!ramps_full) {
free(ramps_sys.ANY.red);
return LIBGAMMA_ERRNO_SET;
}
}
/* Translate ramps to 64-bit integers. */
libgamma_internal_translate_to_64(depth_user, n, ramps_full, ramps);
/* Translate ramps to the proper format. */
libgamma_internal_translate_from_64(depth_system, n, &ramps_sys, ramps_full);
free(ramps_full);
/* Apply the ramps */
r = fun(this, &ramps_sys);
free(ramps_sys.ANY.red);
return r;
}
|