// TBD: This doesn't quite work for rv32 yet /* { dg-do compile } */ /* { dg-options { -march=rv64gcv -mabi=lp64d } } */ /* { dg-skip-if "" { *-*-* } { "-O0" "-Og" "-Os" "-Oz" } } */ /* Ensure that gcc doesn't generate standlone li reg, 4096. */ long plus1(unsigned long i) { return i + 2048; } long plus2(unsigned long i) { return i + 4094; } long plus3(unsigned long i) { return i + 2064; } /* Ensure that gcc doesn't generate standlone li reg, -4096. */ long minus1(unsigned long i) { return i - 4096; } long minus2(unsigned long i) { return i - 2049; } long minus3(unsigned long i) { return i - 2064; } /* { dg-final { scan-assembler-not {li\t[a-x0-9]+,-4096} } } */ /* { dg-final { scan-assembler-not {li\t[a-x0-9]+,4096} } } */