summaryrefslogtreecommitdiff
path: root/gcc/testsuite
diff options
context:
space:
mode:
authorebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2008-06-13 10:20:57 +0000
committerebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2008-06-13 10:20:57 +0000
commitb2f0b2a33f40ea27f6f1f130f0e20a3aa44eb02c (patch)
treeffb72b25b3366639abc607ceaa8c9633577cdf14 /gcc/testsuite
parent56f06eefe91d32c510a389a65078d2b040ca8108 (diff)
downloadgcc-b2f0b2a33f40ea27f6f1f130f0e20a3aa44eb02c.tar.gz
PR middle-end/36520
* builtins.c (get_memory_rtx): Test for the presence of DECL_SIZE_UNIT before evaluating it. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@136747 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/testsuite')
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.c-torture/compile/20080613-1.c40
2 files changed, 44 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index c9e1e422496..ae25ac0723e 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2008-06-13 Eric Botcazou <ebotcazou@adacore.com>
+
+ * gcc.c-torture/compile/20080613-1.c: New test.
+
2008-06-13 Jakub Jelinek <jakub@redhat.com>
PR c/36507
diff --git a/gcc/testsuite/gcc.c-torture/compile/20080613-1.c b/gcc/testsuite/gcc.c-torture/compile/20080613-1.c
new file mode 100644
index 00000000000..f64964e7740
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/compile/20080613-1.c
@@ -0,0 +1,40 @@
+/* PR middle-end/36520 */
+/* Testcase by Richard Guenther <rguenth@gcc.gnu.org> */
+
+typedef long unsigned int size_t;
+typedef unsigned short int sa_family_t;
+struct cmsghdr {
+ size_t cmsg_len;
+ __extension__ unsigned char __cmsg_data [];
+};
+typedef unsigned int uint32_t;
+struct in6_addr {
+ union {
+ uint32_t u6_addr32[4];
+ } in6_u;
+};
+struct sockaddr_in {
+ sa_family_t sin_family;
+};
+struct in6_pktinfo {
+ struct in6_addr ipi6_addr;
+};
+typedef union {
+ struct sockaddr_in sin;
+} sockaddr_any;
+static sockaddr_any src_addr;
+
+inline struct cmsghdr * cmsg_put(struct cmsghdr *cm, int type, void *data, size_t len)
+{
+ memcpy(((cm)->__cmsg_data), data, len);
+}
+
+int hop_sendmsg(int fd) {
+ struct cmsghdr *cm;
+ if (src_addr.sin.sin_family) {
+ if (src_addr.sin.sin_family == 2) {
+ struct in6_pktinfo info;
+ cm = cmsg_put(cm, 50, &info, sizeof(info));
+ }
+ }
+}