123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872 |
- (_MIPS_ISA == _MIPS_ISA_MIPS32) || (_MIPS_ISA == _MIPS_ISA_MIPS64)
- pref PREFETCH_LOAD_HINT, (chunk)*64(reg)
- pref PREFETCH_LOAD_HINT, ((chunk)*64)+32(reg)
- pref PREFETCH_STORE_HINT, (chunk)*64(reg)
- pref PREFETCH_STORE_HINT, ((chunk)*64)+32(reg)
- pref PREFETCH_LOAD_HINT, (chunk)*32(reg)
- pref PREFETCH_STORE_HINT, (chunk)*32(reg)
- && ((PREFETCH_CHUNK * 4) < MAX_PREFETCH_SIZE)
- LEAF(MEMCPY_NAME, 0)
- LEAF(MEMCPY_NAME)
- .set nomips16
- .set noreorder
- PTR_SUBU t0,a0,a1
- PTR_SRA t2,t0,31
- xor t1,t0,t2
- PTR_SUBU t0,t1,t2
- sltu t2,t0,a2
- beq t2,zero,L(memcpy)
- la t9,memmove
- jr t9
- nop
- L(memcpy):
- slti t2,a2,(2 * NSIZE)
- bne t2,zero,L(lasts)
- move v0,zero
- move v0,a0
- xor t8,a1,a0
- andi t8,t8,(NSIZE-1)
- bne t8,zero,L(unaligned)
- PTR_SUBU a3, zero, a0
- andi a3,a3,(NSIZE-1)
- beq a3,zero,L(aligned)
- PTR_SUBU a2,a2,a3
- C_LDHI t8,0(a1)
- PTR_ADDU a1,a1,a3
- C_STHI t8,0(a0)
- PTR_ADDU a0,a0,a3
- andi t8,a0,7
- lapc t9,L(atable)
- PTR_LSA t9,t8,t9,2
- jrc t9
- L(atable):
- bc L(lb0)
- bc L(lb7)
- bc L(lb6)
- bc L(lb5)
- bc L(lb4)
- bc L(lb3)
- bc L(lb2)
- bc L(lb1)
- L(lb7):
- lb a3, 6(a1)
- sb a3, 6(a0)
- L(lb6):
- lb a3, 5(a1)
- sb a3, 5(a0)
- L(lb5):
- lb a3, 4(a1)
- sb a3, 4(a0)
- L(lb4):
- lb a3, 3(a1)
- sb a3, 3(a0)
- L(lb3):
- lb a3, 2(a1)
- sb a3, 2(a0)
- L(lb2):
- lb a3, 1(a1)
- sb a3, 1(a0)
- L(lb1):
- lb a3, 0(a1)
- sb a3, 0(a0)
- li t9,8
- subu t8,t9,t8
- PTR_SUBU a2,a2,t8
- PTR_ADDU a0,a0,t8
- PTR_ADDU a1,a1,t8
- L(lb0):
- andi t8,a1,(NSIZE-1)
- lapc t9,L(jtable)
- PTR_LSA t9,t8,t9,2
- jrc t9
- L(jtable):
- bc L(aligned)
- bc L(r6_unaligned1)
- bc L(r6_unaligned2)
- bc L(r6_unaligned3)
- bc L(r6_unaligned4)
- bc L(r6_unaligned5)
- bc L(r6_unaligned6)
- bc L(r6_unaligned7)
- L(aligned):
- andi t8,a2,NSIZEDMASK
- beq a2,t8,L(chkw)
- PTR_SUBU a3,a2,t8
- PTR_ADDU a3,a0,a3
- PTR_ADDU t0,a0,a2
- PTR_SUBU t9,t0,PREFETCH_LIMIT
- PREFETCH_FOR_LOAD (0, a1)
- PREFETCH_FOR_LOAD (1, a1)
- PREFETCH_FOR_LOAD (2, a1)
- PREFETCH_FOR_LOAD (3, a1)
- PREFETCH_FOR_STORE (1, a0)
- PREFETCH_FOR_STORE (2, a0)
- PREFETCH_FOR_STORE (3, a0)
- sltu v1,t9,a0
- bgtz v1,L(skip_set)
- nop
- PTR_ADDIU v0,a0,(PREFETCH_CHUNK*4)
- L(skip_set):
- PTR_ADDIU v0,a0,(PREFETCH_CHUNK*1)
- && (PREFETCH_STORE_HINT != PREFETCH_HINT_PREPAREFORSTORE)
- PTR_ADDIU v0,a0,(PREFETCH_CHUNK*3)
- PTR_ADDIU v0,v0,32
- L(loop16w):
- C_LD t0,UNIT(0)(a1)
- sltu v1,t9,a0
- bgtz v1,L(skip_pref)
- C_LD t1,UNIT(1)(a1)
- PREFETCH_FOR_STORE (2, a0)
- PREFETCH_FOR_STORE (4, a0)
- PREFETCH_FOR_STORE (5, a0)
- PTR_ADDIU v0,a0,(PREFETCH_CHUNK*5)
- PTR_ADDIU v0,v0,32
- L(skip_pref):
- C_LD REG2,UNIT(2)(a1)
- C_LD REG3,UNIT(3)(a1)
- C_LD REG4,UNIT(4)(a1)
- C_LD REG5,UNIT(5)(a1)
- C_LD REG6,UNIT(6)(a1)
- C_LD REG7,UNIT(7)(a1)
- PREFETCH_FOR_LOAD (3, a1)
- PREFETCH_FOR_LOAD (4, a1)
- C_ST t0,UNIT(0)(a0)
- C_ST t1,UNIT(1)(a0)
- C_ST REG2,UNIT(2)(a0)
- C_ST REG3,UNIT(3)(a0)
- C_ST REG4,UNIT(4)(a0)
- C_ST REG5,UNIT(5)(a0)
- C_ST REG6,UNIT(6)(a0)
- C_ST REG7,UNIT(7)(a0)
- C_LD t0,UNIT(8)(a1)
- C_LD t1,UNIT(9)(a1)
- C_LD REG2,UNIT(10)(a1)
- C_LD REG3,UNIT(11)(a1)
- C_LD REG4,UNIT(12)(a1)
- C_LD REG5,UNIT(13)(a1)
- C_LD REG6,UNIT(14)(a1)
- C_LD REG7,UNIT(15)(a1)
- PREFETCH_FOR_LOAD (5, a1)
- C_ST t0,UNIT(8)(a0)
- C_ST t1,UNIT(9)(a0)
- C_ST REG2,UNIT(10)(a0)
- C_ST REG3,UNIT(11)(a0)
- C_ST REG4,UNIT(12)(a0)
- C_ST REG5,UNIT(13)(a0)
- C_ST REG6,UNIT(14)(a0)
- C_ST REG7,UNIT(15)(a0)
- PTR_ADDIU a0,a0,UNIT(16)
- bne a0,a3,L(loop16w)
- PTR_ADDIU a1,a1,UNIT(16)
- move a2,t8
- L(chkw):
- PREFETCH_FOR_LOAD (0, a1)
- andi t8,a2,NSIZEMASK
-
- beq a2,t8,L(chk1w)
- nop
- C_LD t0,UNIT(0)(a1)
- C_LD t1,UNIT(1)(a1)
- C_LD REG2,UNIT(2)(a1)
- C_LD REG3,UNIT(3)(a1)
- C_LD REG4,UNIT(4)(a1)
- C_LD REG5,UNIT(5)(a1)
- C_LD REG6,UNIT(6)(a1)
- C_LD REG7,UNIT(7)(a1)
- PTR_ADDIU a1,a1,UNIT(8)
- C_ST t0,UNIT(0)(a0)
- C_ST t1,UNIT(1)(a0)
- C_ST REG2,UNIT(2)(a0)
- C_ST REG3,UNIT(3)(a0)
- C_ST REG4,UNIT(4)(a0)
- C_ST REG5,UNIT(5)(a0)
- C_ST REG6,UNIT(6)(a0)
- C_ST REG7,UNIT(7)(a0)
- PTR_ADDIU a0,a0,UNIT(8)
- L(chk1w):
- andi a2,t8,(NSIZE-1)
- beq a2,t8,L(lastw)
- PTR_SUBU a3,t8,a2
- PTR_ADDU a3,a0,a3
- L(wordCopy_loop):
- C_LD REG3,UNIT(0)(a1)
- PTR_ADDIU a0,a0,UNIT(1)
- PTR_ADDIU a1,a1,UNIT(1)
- bne a0,a3,L(wordCopy_loop)
- C_ST REG3,UNIT(-1)(a0)
- L(lastw):
- andi t8,a2,3
- beq t8,a2,L(lastb)
- move a2,t8
- lw REG3,0(a1)
- sw REG3,0(a0)
- PTR_ADDIU a0,a0,4
- PTR_ADDIU a1,a1,4
- L(lastb):
- blez a2,L(leave)
- PTR_ADDU a3,a0,a2
- L(lastbloop):
- lb v1,0(a1)
- PTR_ADDIU a0,a0,1
- PTR_ADDIU a1,a1,1
- bne a0,a3,L(lastbloop)
- sb v1,-1(a0)
- L(leave):
- j ra
- nop
- L(lasts):
- andi t8,a2,3
- beq t8,a2,L(lastb)
- andi t9,a0,3
- bne t9,zero,L(lastb)
- andi t9,a1,3
- bne t9,zero,L(lastb)
- PTR_SUBU a3,a2,t8
- PTR_ADDU a3,a0,a3
- L(wcopy_loop):
- lw REG3,0(a1)
- PTR_ADDIU a0,a0,4
- PTR_ADDIU a1,a1,4
- bne a0,a3,L(wcopy_loop)
- sw REG3,-4(a0)
- b L(lastb)
- move a2,t8
- L(unaligned):
- andi a3,a3,(NSIZE-1)
- beqz a3,L(ua_chk16w)
- PTR_SUBU a2,a2,a3
- C_LDHI v1,UNIT(0)(a1)
- C_LDLO v1,UNITM1(1)(a1)
- PTR_ADDU a1,a1,a3
- C_STHI v1,UNIT(0)(a0)
- PTR_ADDU a0,a0,a3
- L(ua_chk16w):
- andi t8,a2,NSIZEDMASK
- beq a2,t8,L(ua_chkw)
- PTR_SUBU a3,a2,t8
- PTR_ADDU a3,a0,a3
- PTR_ADDU t0,a0,a2
- PTR_SUBU t9,t0,PREFETCH_LIMIT
- PREFETCH_FOR_LOAD (0, a1)
- PREFETCH_FOR_LOAD (1, a1)
- PREFETCH_FOR_LOAD (2, a1)
- PREFETCH_FOR_STORE (1, a0)
- PREFETCH_FOR_STORE (2, a0)
- PREFETCH_FOR_STORE (3, a0)
- sltu v1,t9,a0
- bgtz v1,L(ua_skip_set)
- nop
- PTR_ADDIU v0,a0,(PREFETCH_CHUNK*4)
- L(ua_skip_set):
- PTR_ADDIU v0,a0,(PREFETCH_CHUNK*1)
- L(ua_loop16w):
- PREFETCH_FOR_LOAD (3, a1)
- C_LDHI t0,UNIT(0)(a1)
- C_LDHI t1,UNIT(1)(a1)
- C_LDHI REG2,UNIT(2)(a1)
- sltu v1,t9,a0
- bgtz v1,L(ua_skip_pref)
- C_LDHI REG3,UNIT(3)(a1)
- PREFETCH_FOR_STORE (4, a0)
- PREFETCH_FOR_STORE (5, a0)
- L(ua_skip_pref):
- C_LDHI REG4,UNIT(4)(a1)
- C_LDHI REG5,UNIT(5)(a1)
- C_LDHI REG6,UNIT(6)(a1)
- C_LDHI REG7,UNIT(7)(a1)
- C_LDLO t0,UNITM1(1)(a1)
- C_LDLO t1,UNITM1(2)(a1)
- C_LDLO REG2,UNITM1(3)(a1)
- C_LDLO REG3,UNITM1(4)(a1)
- C_LDLO REG4,UNITM1(5)(a1)
- C_LDLO REG5,UNITM1(6)(a1)
- C_LDLO REG6,UNITM1(7)(a1)
- C_LDLO REG7,UNITM1(8)(a1)
- PREFETCH_FOR_LOAD (4, a1)
- C_ST t0,UNIT(0)(a0)
- C_ST t1,UNIT(1)(a0)
- C_ST REG2,UNIT(2)(a0)
- C_ST REG3,UNIT(3)(a0)
- C_ST REG4,UNIT(4)(a0)
- C_ST REG5,UNIT(5)(a0)
- C_ST REG6,UNIT(6)(a0)
- C_ST REG7,UNIT(7)(a0)
- C_LDHI t0,UNIT(8)(a1)
- C_LDHI t1,UNIT(9)(a1)
- C_LDHI REG2,UNIT(10)(a1)
- C_LDHI REG3,UNIT(11)(a1)
- C_LDHI REG4,UNIT(12)(a1)
- C_LDHI REG5,UNIT(13)(a1)
- C_LDHI REG6,UNIT(14)(a1)
- C_LDHI REG7,UNIT(15)(a1)
- C_LDLO t0,UNITM1(9)(a1)
- C_LDLO t1,UNITM1(10)(a1)
- C_LDLO REG2,UNITM1(11)(a1)
- C_LDLO REG3,UNITM1(12)(a1)
- C_LDLO REG4,UNITM1(13)(a1)
- C_LDLO REG5,UNITM1(14)(a1)
- C_LDLO REG6,UNITM1(15)(a1)
- C_LDLO REG7,UNITM1(16)(a1)
- PREFETCH_FOR_LOAD (5, a1)
- C_ST t0,UNIT(8)(a0)
- C_ST t1,UNIT(9)(a0)
- C_ST REG2,UNIT(10)(a0)
- C_ST REG3,UNIT(11)(a0)
- C_ST REG4,UNIT(12)(a0)
- C_ST REG5,UNIT(13)(a0)
- C_ST REG6,UNIT(14)(a0)
- C_ST REG7,UNIT(15)(a0)
- PTR_ADDIU a0,a0,UNIT(16)
- bne a0,a3,L(ua_loop16w)
- PTR_ADDIU a1,a1,UNIT(16)
- move a2,t8
- L(ua_chkw):
- PREFETCH_FOR_LOAD (0, a1)
- andi t8,a2,NSIZEMASK
-
- beq a2,t8,L(ua_chk1w)
- nop
- C_LDHI t0,UNIT(0)(a1)
- C_LDHI t1,UNIT(1)(a1)
- C_LDHI REG2,UNIT(2)(a1)
- C_LDHI REG3,UNIT(3)(a1)
- C_LDHI REG4,UNIT(4)(a1)
- C_LDHI REG5,UNIT(5)(a1)
- C_LDHI REG6,UNIT(6)(a1)
- C_LDHI REG7,UNIT(7)(a1)
- C_LDLO t0,UNITM1(1)(a1)
- C_LDLO t1,UNITM1(2)(a1)
- C_LDLO REG2,UNITM1(3)(a1)
- C_LDLO REG3,UNITM1(4)(a1)
- C_LDLO REG4,UNITM1(5)(a1)
- C_LDLO REG5,UNITM1(6)(a1)
- C_LDLO REG6,UNITM1(7)(a1)
- C_LDLO REG7,UNITM1(8)(a1)
- PTR_ADDIU a1,a1,UNIT(8)
- C_ST t0,UNIT(0)(a0)
- C_ST t1,UNIT(1)(a0)
- C_ST REG2,UNIT(2)(a0)
- C_ST REG3,UNIT(3)(a0)
- C_ST REG4,UNIT(4)(a0)
- C_ST REG5,UNIT(5)(a0)
- C_ST REG6,UNIT(6)(a0)
- C_ST REG7,UNIT(7)(a0)
- PTR_ADDIU a0,a0,UNIT(8)
- L(ua_chk1w):
- andi a2,t8,(NSIZE-1)
- beq a2,t8,L(ua_smallCopy)
- PTR_SUBU a3,t8,a2
- PTR_ADDU a3,a0,a3
- L(ua_wordCopy_loop):
- C_LDHI v1,UNIT(0)(a1)
- C_LDLO v1,UNITM1(1)(a1)
- PTR_ADDIU a0,a0,UNIT(1)
- PTR_ADDIU a1,a1,UNIT(1)
- bne a0,a3,L(ua_wordCopy_loop)
- C_ST v1,UNIT(-1)(a0)
- L(ua_smallCopy):
- beqz a2,L(leave)
- PTR_ADDU a3,a0,a2
- L(ua_smallCopy_loop):
- lb v1,0(a1)
- PTR_ADDIU a0,a0,1
- PTR_ADDIU a1,a1,1
- bne a0,a3,L(ua_smallCopy_loop)
- sb v1,-1(a0)
- j ra
- nop
- andi REG7, a2, (NSIZE-1)
- beq REG7, a2, L(lastb)
- PTR_SUBU a3, a2, REG7
- \
- move a2, REG7
- \
- PTR_ADDU REG6, a0, a3
- PTR_SUBU REG2, a1, t8
- PTR_ADDU a1, a1, a3
- C_LD t0, UNIT(0)(REG2)
- L(r6_ua_wordcopy
- C_LD t1, UNIT(1)(REG2)
- C_ALIGN REG3, SWAP_REGS(t1,t0), ALIGN_OFFSET(BYTEOFFSET); \
- PTR_ADDIU a0, a0, UNIT(1)
- PTR_ADDIU REG2, REG2, UNIT(1)
- move t0, t1
- bne a0, REG6,L(r6_ua_wordcopy
- C_ST REG3, UNIT(-1)(a0)
- j L(lastb)
- nop
-
- L(r6_unaligned1):
- R6_UNALIGNED_WORD_COPY(1)
- L(r6_unaligned2):
- R6_UNALIGNED_WORD_COPY(2)
- L(r6_unaligned3):
- R6_UNALIGNED_WORD_COPY(3)
- L(r6_unaligned4):
- R6_UNALIGNED_WORD_COPY(4)
- L(r6_unaligned5):
- R6_UNALIGNED_WORD_COPY(5)
- L(r6_unaligned6):
- R6_UNALIGNED_WORD_COPY(6)
- L(r6_unaligned7):
- R6_UNALIGNED_WORD_COPY(7)
- .set at
- .set reorder
- END(MEMCPY_NAME)
- libc_hidden_def(MEMCPY_NAME)
- libc_hidden_builtin_def (MEMCPY_NAME)
|