OpenCores
URL https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk

Subversion Repositories openrisc_me

[/] [openrisc/] [trunk/] [gnu-src/] [binutils-2.20.1/] [gas/] [testsuite/] [gas/] [score/] [bit_32.s] - Rev 205

Compare with Previous | Blame | View Log

/*
 * tests for bit operations' instruction relaxation
 *
 * Author: libin
 */
 
.include "relaxation_macro.h"
 
.macro _bit_op_pattern insn insn1
  insn_32 "\insn r0,  r0,  0"
  insn_32 "\insn r0,  r0,  0x1f"
  insn_32 "\insn r15, r15, 0"
  insn_32 "\insn r15, r15, 0x1f"
 
  tran_16_32 "\insn! r0,0", "\insn r0,r0,0"
 
  /* shouldn't alter */
  insn_32 "\insn1 r0,  r0,  0"
  insn_32 "\insn  r16, r16, 0"
  insn_32 "\insn  r16, r16, 0x1f"
.endm
 
.text
/*
 * bitclr rD,rA,BN5 -> bitclr! rD,BN5
 * bitset rD,rA,BN5 -> bitset! rD,BN5
 * bittgl rD,rA,BN5 -> bittgl! rD,BN5
 */
_bit_op_pattern "bitclr", "bitclr.c"
_bit_op_pattern "bitset", "bitset.c"
_bit_op_pattern "bittgl", "bittgl.c"
 
/* bittst.c rA,BN5 <-> bittst! rD,BN5" */
insn_32 "bittst.c r0,  0"
insn_32 "bittst.c r0,  0x1f"
insn_32 "bittst.c r15, 0"
insn_32 "bittst.c r15, 0x1f"
 
tran_16_32 "bittst! r0,0", "bittst.c r0,0"
 
/* shouldn't alter */
insn_32 "bittst.c r16, 0"
insn_32 "bittst.c r16, 0x1f"

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.