Цитата(vgovseychuk @ Oct 23 2015, 10:44)

Есть ли какие-то условия ее оптимального применения?
оптимальное применение если разница между адресами кратна на 4. Похуже если 2. Если 1 то самая низкая производительность.
исходник теста
Код
#define BUFF_SIZE 0x1000
#define OFFS_QNTY 16
uint8_t src_buff[ BUFF_SIZE + OFFS_QNTY ];
uint8_t dst_buff[ BUFF_SIZE + OFFS_QNTY ];
uint32_t results[OFFS_QNTY][OFFS_QNTY];
void memcpy_test()
{
uint8_t src_offset, dst_offset;
uint32_t ticks_start, ticks_stop;
CoreDebug->DEMCR |= 0x01000000;
DWT->CYCCNT = 0;
DWT->CTRL = 1;
for( src_offset = 0; src_offset < OFFS_QNTY; src_offset++ )
for( dst_offset = 0; dst_offset < OFFS_QNTY; dst_offset++ )
{
ticks_start = DWT->CYCCNT;
memcpy( &dst_buff[ dst_offset ], &src_buff[ src_offset ], BUFF_SIZE );
ticks_stop = DWT->CYCCNT;
results[ src_offset ][ dst_offset ] = ticks_stop - ticks_start;
}
}
ниже картинка отсортированных результатов этого теста
копирование из RAM в RAM размером 0x1000 ( 4кб )
результат в тиках процессора, то есть 3300/4196=0,8такта на байт
оптимизация практически не влияет
для теста применялся LPC1778 на основе CM3

result.rar ( 4.69 килобайт )
Кол-во скачиваний: 69Цитата(vgovseychuk @ Oct 23 2015, 10:44)

Кто-нибудь в курсе скорости работы/занимаемого в памяти места функции memcpy()?
в IAR ARM7.3 занимает 116 байт ( ABImemcpy_unaligned.o ro code=118 )
Марс - единственная планета, полностью населенная роботами (около 7 штук).