2 The problem here is that the ia64 scheduler saw a sequence of L L M type
3 insns, and messed up its internal state on which slot it was issuing
6 /* { dg-do compile } */
7 /* In ILP32 mode, we get warnings about large integer constants.
8 Those cause spurious FAILs. */
9 /* { dg-options "-w -O2 -mconstant-gp" } */
11 typedef unsigned long __u64
;
12 typedef unsigned int __u32
;
13 typedef struct { } spinlock_t
;
20 __u64 irq_and_bh_counts
;
22 __u32 softirq_pending
;
23 } __attribute__ ((aligned ((1UL << 14)))) ;
46 unsigned int data_len
;
50 static inline int skb_is_nonlinear(const struct sk_buff
*skb
)
54 static inline int skb_tailroom(const struct sk_buff
*skb
)
56 return skb_is_nonlinear(skb
) ? 0 : skb
->end
-skb
->tail
;
60 unsigned short rta_len
;
61 unsigned short rta_type
;
63 int qdisc_copy_stats(struct sk_buff
*skb
, struct tc_stats
*st
)
65 do { do { (((struct cpuinfo_ia64
*) (0xa000000000000000 + 2*(1UL << 14)))->irq_stat
.f
.bh_count
)++; __asm__
__volatile__("": : :"memory"); } while (0); (void)(st
->lock
); } while (0);
66 ({ if (skb_tailroom(skb
) < (int)( (((( ((sizeof(struct rtattr
))+4 -1) & ~(4 -1) ) + ((char*)&st
->lock
- (char*)st
)))+4 -1) & ~(4 -1) )) goto rtattr_failure
; __rta_fill(skb
, TCA_STATS
, (char*)&st
->lock
- (char*)st
, st
); });
67 do { do { } while(0); do { do { __asm__
__volatile__("": : :"memory"); (((struct cpuinfo_ia64
*) (0xa000000000000000 + 2*(1UL << 14)))->irq_stat
.f
.bh_count
)--; } while (0); if (__builtin_expect((((struct cpuinfo_ia64
*) (0xa000000000000000 + 2*(1UL << 14)))->softirq_pending
), 0) && (((struct cpuinfo_ia64
*) (0xa000000000000000 + 2*(1UL << 14)))->irq_stat
.f
.bh_count
) == 0) do_softirq(); } while (0); } while (0);
70 do { do { } while(0); do { do { __asm__
__volatile__("": : :"memory"); (((struct cpuinfo_ia64
*) (0xa000000000000000 + 2*(1UL << 14)))->irq_stat
.f
.bh_count
)--; } while (0); if (__builtin_expect((((struct cpuinfo_ia64
*) (0xa000000000000000 + 2*(1UL << 14)))->softirq_pending
), 0) && (((struct cpuinfo_ia64
*) (0xa000000000000000 + 2*(1UL << 14)))->irq_stat
.f
.bh_count
) == 0) do_softirq(); } while (0); } while (0);