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/] [presw.s] - Blame information for rev 219

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 205 julius
/*
2
 * test relax
3
 * pre sw <-> push! : offset == -4
4
 * syntax:
5
   sw rD, [rA, simm12]+ : rD and rA can be 0-31
6
   push! rD, [rAg0] : rAg0 must be in 0-7, rD can be 0-31
7
 
8
 * Author: ligang
9
 */
10
 
11
/* This macro transform 32b instruction to 16b. */
12
.macro tran3216 insn32, insn16
13
.align 4
14
 
15
  \insn32 r0, [r2, -4]+     #32b -> 16b
16
  \insn16 r0, [r2]
17
 
18
  \insn32 r23, [r7, -4]+    #32b -> 16b
19
  \insn16 r23, [r7]
20
 
21
  \insn32 r15, [r0, -4]+    #32b -> 16b
22
  \insn16 r15, [r0]
23
 
24
  \insn16 r15, [r7]
25
  \insn32 r15, [r7, -4]+    #32b -> 16b
26
 
27
  \insn32 r25, [r3, -4]+    #32b -> 16b
28
  \insn32 r25, [r3, -4]+    #32b -> 16b
29
 
30
  \insn32 r24, [r13, -4]+   #No transform
31
  \insn32 r23, [r7, -5]+    #No transform
32
 
33
.endm
34
 
35
/* This macro transform 16b instruction to 32b. */
36
.macro tran1632 insn32, insn16
37
.align 4
38
 
39
  \insn16 r0, [r7]         #16b -> 32b
40
  \insn32 r25, [r13, -4]+
41
 
42
  \insn16 r25, [r0]        #16b -> 32b
43
  \insn32 r18, [r23, -4]+
44
 
45
  \insn16 r6, [r3]         #No transform
46
  \insn16 r6, [r3]         #No transform
47
 
48
  \insn16 r3, [r7]         #No transform
49
  \insn32 r3, [r7, -4]+
50
 
51
.endm
52
 
53
  tran3216 "sw", "push!"
54
  tran1632 "sw", "push!"

powered by: WebSVN 2.1.0

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