diff options
author | Mattias Andrée <maandree@operamail.com> | 2014-08-08 21:33:02 +0200 |
---|---|---|
committer | Mattias Andrée <maandree@operamail.com> | 2014-08-08 21:33:02 +0200 |
commit | 680aab24bb74f33b4021e5ebd2a01884149feeaf (patch) | |
tree | f43b90b20a9aa2a57654f899b8a42b963d6b49d7 /src/calibrator.c | |
parent | m (diff) | |
download | crt-calibrator-680aab24bb74f33b4021e5ebd2a01884149feeaf.tar.gz crt-calibrator-680aab24bb74f33b4021e5ebd2a01884149feeaf.tar.bz2 crt-calibrator-680aab24bb74f33b4021e5ebd2a01884149feeaf.tar.xz |
misc
Signed-off-by: Mattias Andrée <maandree@operamail.com>
Diffstat (limited to 'src/calibrator.c')
-rw-r--r-- | src/calibrator.c | 61 |
1 files changed, 59 insertions, 2 deletions
diff --git a/src/calibrator.c b/src/calibrator.c index 9ee0d88..b308c38 100644 --- a/src/calibrator.c +++ b/src/calibrator.c @@ -199,6 +199,44 @@ void draw_gamma(void) } +static int read_calibs(void) +{ + size_t c; + for (c = 0; c < crtc_count; c++) + { + if (drm_get_gamma(crtcs + c) < 0) + return -1; + + gamma_analyse(crtcs[c].gamma_stops, crtcs[c].red, gammas[0] + c, + contrasts[0] + c, brightnesses[0] + c); + gamma_analyse(crtcs[c].gamma_stops, crtcs[c].green, gammas[1] + c, + contrasts[1] + c, brightnesses[1] + c); + gamma_analyse(crtcs[c].gamma_stops, crtcs[c].blue, gammas[2] + c, + contrasts[2] + c, brightnesses[2] + c); + } + return 0; +} + + +static int apply_calibs(void) +{ + size_t c; + for (c = 0; c < crtc_count; c++) + { + gamma_generate(crtcs[c].gamma_stops, crtcs[c].red, gammas[0][c], + contrasts[0][c], brightnesses[0][c]); + gamma_generate(crtcs[c].gamma_stops, crtcs[c].green, gammas[1][c], + contrasts[1][c], brightnesses[1][c]); + gamma_generate(crtcs[c].gamma_stops, crtcs[c].blue, gammas[2][c], + contrasts[2][c], brightnesses[2][c]); + + if (drm_set_gamma(crtcs + c) < 0) + return -1; + } + return 0; +} + + int main(int argc __attribute__((unused)), char* argv[]) { int tty_configured = 0, rc = 0, in_fork = 0; @@ -262,7 +300,7 @@ int main(int argc __attribute__((unused)), char* argv[]) printf("contrast should be as high as possible without\n"); printf("causing distortion.\n"); printf("\n"); - printf("Press ENTER to continue, and ENTER again once\n"); + printf("Press ENTER to continue, and ENTER again when\n"); printf("your are done.\n"); fflush(stdout); @@ -276,7 +314,26 @@ int main(int argc __attribute__((unused)), char* argv[]) while (getchar() != 10) ; - if (draw_id() < 0) + printf("\033[H\033[2J"); + printf("An index will be displayed on each monitor.\n"); + printf("It behoves you to memorise them.\n"); + printf("\n"); + printf("Press ENTER to continue, and ENTER again when\n"); + printf("your are done.\n"); + fflush(stdout); + + while (getchar() != 10) + ; + + printf("\033[H\033[2J"); + fflush(stdout); + if ((read_calibs() < 0) || (draw_id() < 0)) + goto fail; + + while (getchar() != 10) + ; + + if (apply_calibs() < 0) goto fail; done: |