mirror of
https://git.code.sf.net/p/openocd/code
synced 2024-11-22 10:46:27 +00:00
a126229dff
Replace the GPLv2-or-later boilerplate with the SPDX tag. The SPDX tag on files *.c is incorrect, as it should use the C99 single line comment using '//'. But current checkpatch doesn't allow C99 comments, so keep using standard C comments, by now. Change-Id: I380d552940f1c405309a3346454251c0e80b5a45 Signed-off-by: Antonio Borneo <borneo.antonio@gmail.com> Reviewed-on: https://review.openocd.org/c/openocd/+/7159 Tested-by: jenkins
45 lines
1001 B
ArmAsm
45 lines
1001 B
ArmAsm
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
|
|
/***************************************************************************
|
|
* Copyright (C) 2005, 2007 by Dominic Rath *
|
|
* Dominic.Rath@gmx.de *
|
|
* Copyright (C) 2010 Spencer Oliver *
|
|
* spen@spen-soft.co.uk *
|
|
***************************************************************************/
|
|
|
|
.text
|
|
.arm
|
|
.arch armv4
|
|
|
|
.section .init
|
|
|
|
/* algorithm register usage:
|
|
* r0: source address (in RAM)
|
|
* r1: target address (in Flash)
|
|
* r2: count
|
|
* r3: flash write command
|
|
* r4: status byte (returned to host)
|
|
* r5: busy test pattern
|
|
* r6: error test pattern
|
|
*/
|
|
|
|
loop:
|
|
ldrh r4, [r0], #2
|
|
strh r3, [r1]
|
|
strh r4, [r1]
|
|
busy:
|
|
ldrh r4, [r1]
|
|
and r7, r4, r5
|
|
cmp r7, r5
|
|
bne busy
|
|
tst r4, r6
|
|
bne done
|
|
subs r2, r2, #1
|
|
beq done
|
|
add r1, r1, #2
|
|
b loop
|
|
done:
|
|
b done
|
|
|
|
.end
|