summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.c-torture/execute/990628-1.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/execute/990628-1.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/execute/990628-1.c')
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/990628-1.c56
1 files changed, 56 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.c-torture/execute/990628-1.c b/gcc/testsuite/gcc.c-torture/execute/990628-1.c
new file mode 100644
index 000000000..e010510cd
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/execute/990628-1.c
@@ -0,0 +1,56 @@
+#include <stdlib.h>
+
+struct {
+ long sqlcode;
+} sqlca;
+
+
+struct data_record {
+ int dummy;
+ int a[100];
+} *data_ptr, data_tmp;
+
+
+int
+num_records()
+{
+ return 1;
+}
+
+
+void
+fetch()
+{
+ static int fetch_count;
+
+ memset(&data_tmp, 0x55, sizeof(data_tmp));
+ sqlca.sqlcode = (++fetch_count > 1 ? 100 : 0);
+}
+
+
+void
+load_data() {
+ struct data_record *p;
+ int num = num_records();
+
+ data_ptr = malloc(num * sizeof(struct data_record));
+ memset(data_ptr, 0xaa, num * sizeof(struct data_record));
+
+ fetch();
+ p = data_ptr;
+ while (sqlca.sqlcode == 0) {
+ *p++ = data_tmp;
+ fetch();
+ }
+}
+
+
+main()
+{
+ load_data();
+ if (sizeof (int) == 2 && data_ptr[0].dummy != 0x5555)
+ abort ();
+ else if (sizeof (int) > 2 && data_ptr[0].dummy != 0x55555555)
+ abort ();
+ exit (0);
+}