pickmode.c revision 1.1 1 1.1 macallan /* $NetBSD: pickmode.c,v 1.1 2010/05/04 21:17:10 macallan Exp $ */
2 1.1 macallan
3 1.1 macallan /*-
4 1.1 macallan * Copyright (c) 2006 The NetBSD Foundation
5 1.1 macallan * All rights reserved.
6 1.1 macallan *
7 1.1 macallan * this code was contributed to The NetBSD Foundation by Michael Lorenz
8 1.1 macallan *
9 1.1 macallan * Redistribution and use in source and binary forms, with or without
10 1.1 macallan * modification, are permitted provided that the following conditions
11 1.1 macallan * are met:
12 1.1 macallan * 1. Redistributions of source code must retain the above copyright
13 1.1 macallan * notice, this list of conditions and the following disclaimer.
14 1.1 macallan * 2. Redistributions in binary form must reproduce the above copyright
15 1.1 macallan * notice, this list of conditions and the following disclaimer in the
16 1.1 macallan * documentation and/or other materials provided with the distribution.
17 1.1 macallan *
18 1.1 macallan * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS
19 1.1 macallan * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
20 1.1 macallan * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21 1.1 macallan * ARE DISCLAIMED. IN NO EVENT SHALL THE NETBSD FOUNDATION BE LIABLE
22 1.1 macallan * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23 1.1 macallan * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
24 1.1 macallan * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 1.1 macallan * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
26 1.1 macallan * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
27 1.1 macallan * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28 1.1 macallan * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 1.1 macallan */
30 1.1 macallan
31 1.1 macallan #include <sys/cdefs.h>
32 1.1 macallan __KERNEL_RCSID(0, "$NetBSD: pickmode.c,v 1.1 2010/05/04 21:17:10 macallan Exp $");
33 1.1 macallan
34 1.1 macallan #include <sys/param.h>
35 1.1 macallan #include <dev/videomode/videomode.h>
36 1.1 macallan #include "opt_videomode.h"
37 1.1 macallan
38 1.1 macallan #ifdef PICKMODE_DEBUG
39 1.1 macallan #define DPRINTF printf
40 1.1 macallan #else
41 1.1 macallan #define DPRINTF while (0) printf
42 1.1 macallan #endif
43 1.1 macallan
44 1.1 macallan const struct videomode *
45 1.1 macallan pick_mode_by_dotclock(int width, int height, int dotclock)
46 1.1 macallan {
47 1.1 macallan const struct videomode *this, *best = NULL;
48 1.1 macallan int i;
49 1.1 macallan
50 1.1 macallan DPRINTF("%s: looking for %d x %d at up to %d kHz\n", __func__, width,
51 1.1 macallan height, dotclock);
52 1.1 macallan for (i = 0; i < videomode_count; i++) {
53 1.1 macallan
54 1.1 macallan this = &videomode_list[i];
55 1.1 macallan if ((this->hdisplay != width) || (this->vdisplay != height) ||
56 1.1 macallan (this->dot_clock > dotclock))
57 1.1 macallan continue;
58 1.1 macallan if (best != NULL) {
59 1.1 macallan
60 1.1 macallan if (this->dot_clock > best->dot_clock)
61 1.1 macallan best = this;
62 1.1 macallan } else
63 1.1 macallan best = this;
64 1.1 macallan }
65 1.1 macallan if (best!= NULL)
66 1.1 macallan DPRINTF("found %s\n", best->name);
67 1.1 macallan
68 1.1 macallan return best;
69 1.1 macallan }
70 1.1 macallan
71 1.1 macallan const struct videomode *
72 1.1 macallan pick_mode_by_ref(int width, int height, int refresh)
73 1.1 macallan {
74 1.1 macallan const struct videomode *this, *best = NULL;
75 1.1 macallan int mref, closest = 1000, i, diff;
76 1.1 macallan
77 1.1 macallan DPRINTF("%s: looking for %d x %d at up to %d Hz\n", __func__, width,
78 1.1 macallan height, refresh);
79 1.1 macallan for (i = 0; i < videomode_count; i++) {
80 1.1 macallan
81 1.1 macallan this = &videomode_list[i];
82 1.1 macallan mref = this->dot_clock * 1000 / (this->htotal * this->vtotal);
83 1.1 macallan diff = abs(mref - refresh);
84 1.1 macallan if ((this->hdisplay != width) || (this->vdisplay != height) ||
85 1.1 macallan (diff > closest))
86 1.1 macallan continue;
87 1.1 macallan if (best != NULL) {
88 1.1 macallan
89 1.1 macallan if (diff < closest) {
90 1.1 macallan
91 1.1 macallan best = this;
92 1.1 macallan closest = diff;
93 1.1 macallan }
94 1.1 macallan } else
95 1.1 macallan best = this;
96 1.1 macallan }
97 1.1 macallan if (best!= NULL)
98 1.1 macallan DPRINTF("found %s\n", best->name);
99 1.1 macallan
100 1.1 macallan return best;
101 1.1 macallan }
102