9: insn reg, addr; \
.section __ex_table,"a"; \
PTR 9b, handler; \
.previous
.macro f_fill64 dst, offset, val, fixup
EX(LONG_S, \val, (\offset + 0 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 1 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 2 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 3 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 4 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 5 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 6 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 7 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 8 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 9 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 10 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 11 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 12 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 13 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 14 * LONGSIZE)(\dst), \fixup)
EX(LONG_S, \val, (\offset + 15 * LONGSIZE)(\dst), \fixup)
.endm
.set noreorder
.align 5
LEAF(memset)
beqz a1, 1f
move v0, a0
andi a1, 0xff
LONG_SLL t1, a1, 8
or a1, t1
LONG_SLL t1, a1, 16
or a1, t1
LONG_SLL t1, a1, 32
or a1, t1
1:
FEXPORT(__bzero)
sltiu t0, a2, LONGSIZE
bnez t0, .Lsmall_memset
andi t0, a0, LONGMASK
beqz t0, 1f
PTR_SUBU t0, LONGSIZE
.set noat
li AT, LONGSIZE
beqz t0, 1f
PTR_SUBU t0, AT
.set at
R10KCBARRIER(0(ra))
EX(LONG_S_L, a1, (a0), .Lfirst_fixup)
EX(LONG_S_R, a1, (a0), .Lfirst_fixup)
PTR_SUBU a0, t0
PTR_ADDU a2, t0
1: ori t1, a2, 0x3f
xori t1, 0x3f
beqz t1, .Lmemset_partial
andi t0, a2, 0x40-LONGSIZE
PTR_ADDU t1, a0
.set reorder
1: PTR_ADDIU a0, 64
R10KCBARRIER(0(ra))
f_fill64 a0, -64, a1, .Lfwd_fixup
bne t1, a0, 1b
.set noreorder
.Lmemset_partial:
R10KCBARRIER(0(ra))
PTR_LA t1, 2f
PTR_SUBU t1, t0
.set noat
LONG_SRL AT, t0, 1
PTR_SUBU t1, AT
.set at
jr t1
PTR_ADDU a0, t0
.set push
.set noreorder
.set nomacro
f_fill64 a0, -64, a1, .Lpartial_fixup
2: .set pop
andi a2, LONGMASK
beqz a2, 1f
PTR_ADDU a0, a2
R10KCBARRIER(0(ra))
EX(LONG_S_R, a1, -1(a0), .Llast_fixup)
EX(LONG_S_L, a1, -1(a0), .Llast_fixup)
1: jr ra
move a2, zero
.Lsmall_memset:
beqz a2, 2f
PTR_ADDU t1, a0, a2
1: PTR_ADDIU a0, 1
R10KCBARRIER(0(ra))
bne t1, a0, 1b
sb a1, -1(a0)
2: jr ra
move a2, zero
END(memset)
.Lfirst_fixup:
jr ra
nop
.Lfwd_fixup:
PTR_L t0, TI_TASK($28)
andi a2, 0x3f
LONG_L t0, THREAD_BUADDR(t0)
LONG_ADDU a2, t1
jr ra
LONG_SUBU a2, t0
.Lpartial_fixup:
PTR_L t0, TI_TASK($28)
andi a2, LONGMASK
LONG_L t0, THREAD_BUADDR(t0)
LONG_ADDU a2, t1
jr ra
LONG_SUBU a2, t0
.Llast_fixup:
jr ra
andi v1, a2, LONGMASK