summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.c-torture/compile/pr37381.c
diff options
context:
space:
mode:
authorupstream source tree <ports@midipix.org>2015-03-15 20:14:05 -0400
committerupstream source tree <ports@midipix.org>2015-03-15 20:14:05 -0400
commit554fd8c5195424bdbcabf5de30fdc183aba391bd (patch)
tree976dc5ab7fddf506dadce60ae936f43f58787092 /gcc/testsuite/gcc.c-torture/compile/pr37381.c
downloadcbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.bz2
cbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.xz
obtained gcc-4.6.4.tar.bz2 from upstream website;upstream
verified gcc-4.6.4.tar.bz2.sig; imported gcc-4.6.4 source tree from verified upstream tarball. downloading a git-generated archive based on the 'upstream' tag should provide you with a source tree that is binary identical to the one extracted from the above tarball. if you have obtained the source via the command 'git clone', however, do note that line-endings of files in your working directory might differ from line-endings of the respective files in the upstream repository.
Diffstat (limited to 'gcc/testsuite/gcc.c-torture/compile/pr37381.c')
-rw-r--r--gcc/testsuite/gcc.c-torture/compile/pr37381.c97
1 files changed, 97 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.c-torture/compile/pr37381.c b/gcc/testsuite/gcc.c-torture/compile/pr37381.c
new file mode 100644
index 000000000..a2fed66c4
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/compile/pr37381.c
@@ -0,0 +1,97 @@
+extern unsigned int __invalid_size_argument_for_IOC;
+typedef unsigned int __u32;
+struct video_window
+{
+ __u32 x, y;
+ __u32 width, height;
+};
+typedef unsigned long XID;
+typedef XID Window;
+typedef struct _XExtData
+{
+ Window root;
+}
+Screen;
+typedef struct
+{
+ int border_width;
+}
+XWindowAttributes;
+typedef struct _XDisplay Display;
+typedef struct
+{
+ int default_screen;
+ Screen *screens;
+}
+ *_XPrivDisplay;
+typedef struct
+{
+ int x, y;
+}
+XSizeHints;
+typedef struct
+{
+ unsigned short hdisplay;
+ unsigned short vdisplay;
+}
+XF86VidModeModeInfo;
+Display *display;
+int tfd;
+int ccapt;
+int tml;
+int fswidth = 0;
+int fsheight = 0;
+Window fmwin;
+XF86VidModeModeInfo **modelines, *fullscreenmode = ((void *) 0);
+struct video_window vswin;
+DoFullScreen (void)
+{
+ int i;
+ int rx, ry;
+ Window junkwin;
+ XSizeHints fmsizehints;
+ XWindowAttributes fmwinattr;
+ if (ioctl
+ (tfd,
+ (((1U) << (((0 + 8) + 8) + 14)) | ((('v')) << (0 + 8)) | (((8)) << 0) |
+ (((((sizeof (int) == sizeof (int[1])
+ && sizeof (int) <
+ (1 << 14)) ? sizeof (int) : __invalid_size_argument_for_IOC))) <<
+ ((0 + 8) + 8))), &ccapt) < 0)
+ {
+ perror ("ioctl VIDIOCCAPTURE");
+ }
+ if (!XTranslateCoordinates
+ (display, fmwin,
+ ((&((_XPrivDisplay) display)->
+ screens[(((_XPrivDisplay) display)->default_screen)])->root),
+ -fmwinattr.border_width, -fmwinattr.border_width, &rx, &ry, &junkwin))
+ {
+ }
+ vswin.width = fswidth;
+ vswin.height = fsheight;
+ vswin.x = fmsizehints.x + rx;
+ vswin.y = fmsizehints.y + ry;
+ if (ioctl
+ (tfd,
+ (((1U) << (((0 + 8) + 8) + 14)) | ((('v')) << (0 + 8)) | (((8)) << 0) |
+ (((((sizeof (int) == sizeof (int[1])
+ && sizeof (int) <
+ (1 << 14)) ? sizeof (int) : __invalid_size_argument_for_IOC))) <<
+ ((0 + 8) + 8))), &ccapt) < 0)
+ {
+ XF86VidModeGetAllModeLines (display, XDefaultScreen (display), &tml,
+ &modelines);
+ {
+ if ((modelines[i]->hdisplay == fswidth)
+ && (modelines[i]->vdisplay == fsheight))
+ {
+ fullscreenmode = modelines[i];
+ }
+ }
+ {
+ XF86VidModeSetViewPort (display, XDefaultScreen (display), vswin.x,
+ vswin.y);
+ }
+ }
+}