/* { dg-do compile { target powerpc*-*-* ia64-*-* i?86-*-* x86_64-*-* } } */ /* { dg-options "-O3 -fselective-scheduling2 -funroll-loops" } */ extern int mode_size[]; typedef unsigned HARD_REG_SET[ ((64 + 32 - 1) / 32) ]; enum reload_type { RELOAD_FOR_INPUT, RELOAD_FOR_OUTPUT, RELOAD_FOR_INSN, RELOAD_FOR_INPUT_ADDRESS, RELOAD_FOR_OUTPUT_ADDRESS, RELOAD_FOR_OPERAND_ADDRESS, RELOAD_FOR_OPADDR_ADDR, RELOAD_OTHER, RELOAD_FOR_OTHER_ADDRESS }; static HARD_REG_SET reload_reg_used; static HARD_REG_SET reload_reg_used_in_input_addr[10]; static HARD_REG_SET reload_reg_used_in_output_addr[10]; static HARD_REG_SET reload_reg_used_in_input[10]; static HARD_REG_SET reload_reg_used_in_output[10]; static HARD_REG_SET reload_reg_used_in_op_addr; static HARD_REG_SET reload_reg_used_in_op_addr_reload; static HARD_REG_SET reload_reg_used_in_insn; static HARD_REG_SET reload_reg_used_in_other_addr; static HARD_REG_SET reload_reg_used_at_all; void __attribute__((cold)) mark_reload_reg_in_use (regno, opnum, type, mode) { int nregs = regno ? 1 : mode_size[mode]; int i; for (i = regno; i < nregs + regno; i++) { switch (type) { case RELOAD_OTHER: reload_reg_used[i / 32u] |= 1 << i % 32u; break; case RELOAD_FOR_INPUT_ADDRESS: reload_reg_used_in_input_addr[opnum][i / 32u] |= 1 << i % 32u; break; case RELOAD_FOR_OUTPUT_ADDRESS: reload_reg_used_in_output_addr[opnum][i / 32u] |= 1 << i % 32u; break; case RELOAD_FOR_OPERAND_ADDRESS: reload_reg_used_in_op_addr[i / 32u] |= 1 << i % 32u; break; case RELOAD_FOR_OPADDR_ADDR: reload_reg_used_in_op_addr_reload[i / 32u] |= 1 << i % 32u; break; case RELOAD_FOR_OTHER_ADDRESS: reload_reg_used_in_other_addr[i / 32u] |= 1; break; case RELOAD_FOR_INPUT: reload_reg_used_in_input[opnum][i / 32u] |= 1 << i % 32u; break; case RELOAD_FOR_OUTPUT: reload_reg_used_in_output[opnum][i / 32u] |= 1 << i % 32u; break; case RELOAD_FOR_INSN: reload_reg_used_in_insn[i / 32u] |= 1 << i % 32u; } reload_reg_used_at_all[i / 32u] |= 1 << i; } }