2 * Copyright © 2011 Intel Corporation
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
24 #include "piglit-util-gl.h"
26 PIGLIT_GL_TEST_CONFIG_BEGIN
28 config
.supports_gl_compat_version
= 10;
30 config
.window_visual
= PIGLIT_GL_VISUAL_RGBA
| PIGLIT_GL_VISUAL_DOUBLE
;
32 PIGLIT_GL_TEST_CONFIG_END
39 float gray
[4] = {0.5, 0.5, 0.5, 0.5};
40 float green
[4] = {0.0, 1.0, 0.0, 0.0};
42 glClearColor(0.5, 0.5, 0.5, 0.5);
43 glClear(GL_COLOR_BUFFER_BIT
);
46 piglit_ortho_projection(piglit_width
, piglit_height
, false);
48 glColor4f(0.0, 1.0, 0.0, 0.0);
49 for (x
= 0; x
<= 5; x
++) {
50 for (y
= 0; y
<= 5; y
++) {
51 float x1
= 5 + (10 + 5) * x
+ y
* 0.2;
52 float y1
= 5 + (10 + 5) * y
+ x
* 0.2;
54 piglit_draw_rect(x1
, y1
, 10, 10);
58 for (x
= 0; x
<= 5; x
++) {
59 for (y
= 0; y
<= 5; y
++) {
60 int x1
= 5 + (10 + 5) * x
;
61 int y1
= 5 + (10 + 5) * y
;
69 p
= p
&& piglit_probe_rect_rgba(x1
, y1
, 10, 10, green
);
71 p
= p
&& piglit_probe_rect_rgba(x1
- 1, y1
,
73 p
= p
&& piglit_probe_rect_rgba(x1
+ 10, y1
,
75 p
= p
&& piglit_probe_rect_rgba(x1
, y1
- 1,
77 p
= p
&& piglit_probe_rect_rgba(x1
, y1
+ 10,
81 printf("Failure on rectangle (%d, %d): "
83 x
, y
, y
* 0.2, x
* 0.2);
89 piglit_present_results();
91 return pass
? PIGLIT_PASS
: PIGLIT_FAIL
;
95 piglit_init(int argc
, char **argv
)
98 printf("The test's expectation is that the implementation samples\n"
99 "at pixel centers to produce fragments, so the fourth\n"
100 "(subpixel offset = 0.6) rectangle in each axis will\n"
101 "be offset compared to the previous.\n\n");
103 piglit_ortho_projection(piglit_width
, piglit_height
, GL_FALSE
);