1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- {
- This file is part of the Free Pascal run time library.
- Copyright (c) 1999-2000 by the Free Pascal development team
- Processor specific implementation of strpas
- See the file COPYING.FPC, included in this distribution,
- for details about the copyright.
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- **********************************************************************}
- {
- ifndef FPC_STRPASPROC
- r3: result address
- r4: p (source)
- else
- r3: result address
- r4: high(result)
- r5: p (source)
- endif
- }
- asm
- { nil? }
- mr r8, p
- cmplwi p, 0
- { load the begin of the string in the data cache }
- dcbt 0, p
- { maxlength }
- {$ifdef FPC_STRPASPROC}
- mr r10,r4
- {$else FPC_STRPASPROC}
- li r10,255
- {$endif FPC_STRPASPROC}
- mtctr r10
- { at LStrPasDone, we set the length of the result to 255 - r10 - r4 }
- { = 255 - 255 - 0 if the soure = nil -> perfect :) }
- beq .LStrPasDone
- { save address for at the end and use r7 in loop }
- mr r7,r3
- { no "subi r7,r7,1" because the first byte = length byte }
- subi r8,r8,1
- .LStrPasLoop:
- lbzu r10,1(r8)
- cmplwi cr0,r10,0
- stbu r10,1(r7)
- bdnzf cr0*4+eq, .LStrPasLoop
- { if we stopped because of a terminating #0, decrease the length by 1 }
- cntlzw r4,r10
- { get remaining count for length }
- mfctr r10
- { if r10 was zero (-> stopped because of zero byte), then r4 will be 32 }
- { (32 leading zero bits) -> shr 5 = 1, otherwise this will be zero }
- srwi r4,r4,5
- .LStrPasDone:
- subfic r10,r10,255
- sub r10,r10,r4
- { store length }
- stb r10,0(r3)
- end;
|