Skip to content

Commit dfb1207

Browse files
committed
ARC: entry: replace 8 byte OR with 4 byte BSET
FAKE_RET_FROM_EXCEPTION drops down to pure kernel mode. It currently has an 8 byte instruction which can be replaced with 4 byte BSET This is applicable to both ARCv2 and ARCv3 entr code. ARCv2 current ------------ 00000804 <EV_Trap>: ... 874: 216a 1280 lr r9,[status32] 878: 2146 1809 bic r9,r9,0x20 87c: 2105 1f89 8000 0000 or r9,r9,0x80000000 ^^^^^^^^^ 884: 2029 8240 kflag r9 ARCv2 after ---------- 000007e0 <EV_Trap>: ... 850: 216a 1280 lr r9,[status32] 854: 2150 1149 bclr r9,r9,0x5 858: 214f 17c9 bset r9,r9,0x1f 85c: 2029 8240 kflag r9 Signed-off-by: Vineet Gupta <[email protected]>
1 parent 13347c1 commit dfb1207

File tree

1 file changed

+2
-2
lines changed

1 file changed

+2
-2
lines changed

arch/arc/include/asm/entry-arcv2.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -274,8 +274,8 @@
274274

275275
.macro FAKE_RET_FROM_EXCPN
276276
lr r9, [status32]
277-
bic r9, r9, STATUS_AE_MASK
278-
or r9, r9, STATUS_IE_MASK
277+
bclr r9, r9, STATUS_AE_BIT
278+
bset r9, r9, STATUS_IE_BIT
279279
kflag r9
280280
.endm
281281

0 commit comments

Comments
 (0)