aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.4.3/gcc/testsuite/gcc.c-torture/compile/pr37381.c
diff options
context:
space:
mode:
authorJing Yu <jingyu@google.com>2010-07-22 14:03:48 -0700
committerJing Yu <jingyu@google.com>2010-07-22 14:03:48 -0700
commitb094d6c4bf572654a031ecc4afe675154c886dc5 (patch)
tree89394c56b05e13a5413ee60237d65b0214fd98e2 /gcc-4.4.3/gcc/testsuite/gcc.c-torture/compile/pr37381.c
parentdc34721ac3bf7e3c406fba8cfe9d139393345ec5 (diff)
downloadtoolchain_gcc-b094d6c4bf572654a031ecc4afe675154c886dc5.tar.gz
toolchain_gcc-b094d6c4bf572654a031ecc4afe675154c886dc5.tar.bz2
toolchain_gcc-b094d6c4bf572654a031ecc4afe675154c886dc5.zip
commit gcc-4.4.3 which is used to build gcc-4.4.3 Android toolchain in master.
The source is based on fsf gcc-4.4.3 and contains local patches which are recorded in gcc-4.4.3/README.google. Change-Id: Id8c6d6927df274ae9749196a1cc24dbd9abc9887
Diffstat (limited to 'gcc-4.4.3/gcc/testsuite/gcc.c-torture/compile/pr37381.c')
-rw-r--r--gcc-4.4.3/gcc/testsuite/gcc.c-torture/compile/pr37381.c97
1 files changed, 97 insertions, 0 deletions
diff --git a/gcc-4.4.3/gcc/testsuite/gcc.c-torture/compile/pr37381.c b/gcc-4.4.3/gcc/testsuite/gcc.c-torture/compile/pr37381.c
new file mode 100644
index 000000000..a2fed66c4
--- /dev/null
+++ b/gcc-4.4.3/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);
+ }
+ }
+}