diff options
| author | Keith Packard <keithp@keithp.com> | 2012-09-14 16:56:04 -0700 | 
|---|---|---|
| committer | Keith Packard <keithp@keithp.com> | 2012-09-14 16:56:04 -0700 | 
| commit | 31f5a02654cbf172beed25f4c518dfb7be8c714e (patch) | |
| tree | fdcced87163a7138335a61f9a6562c0afa020522 /src/cc1111/ao_string.c | |
| parent | b898cf0a2abf2b0478d5afc5aca030c6b4c8bd0b (diff) | |
altos: Need to use 16-bit counts for ao_xmem functions
Trying to use 8-bit counts is a nice optimization which fails when the
count is larger than 255, as is the case with clearing the flash block
in the AT45 driver. This bug resulted in the inability to erase
flights on TeleMetrum v1.0 boards.
Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'src/cc1111/ao_string.c')
| -rw-r--r-- | src/cc1111/ao_string.c | 6 | 
1 files changed, 3 insertions, 3 deletions
| diff --git a/src/cc1111/ao_string.c b/src/cc1111/ao_string.c index 3a07e47e..85d6383e 100644 --- a/src/cc1111/ao_string.c +++ b/src/cc1111/ao_string.c @@ -18,7 +18,7 @@  #include "ao.h"  void -_ao_xmemcpy(__xdata void *dst, __xdata void *src, uint8_t count) +_ao_xmemcpy(__xdata void *dst, __xdata void *src, uint16_t count)  {  	while (count--) {  		*(__xdata uint8_t *) dst = *(__xdata uint8_t *) src; @@ -28,7 +28,7 @@ _ao_xmemcpy(__xdata void *dst, __xdata void *src, uint8_t count)  }  void -_ao_xmemset(__xdata void *dst, uint8_t v, uint8_t count) +_ao_xmemset(__xdata void *dst, uint8_t v, uint16_t count)  {  	while (count--) {  		*(__xdata uint8_t *) dst = v; @@ -37,7 +37,7 @@ _ao_xmemset(__xdata void *dst, uint8_t v, uint8_t count)  }  int8_t -_ao_xmemcmp(__xdata void *a, __xdata void *b, uint8_t count) +_ao_xmemcmp(__xdata void *a, __xdata void *b, uint16_t count)  {  	while (count--) {  		int8_t	d = *(__xdata int8_t *) a - *(__xdata int8_t *) b; | 
