riscv: align stack and data sections to 8 bytes
Alignment on 4 bytes can cause load/store address misalignment exceptions when loading/storing 64bit values on the stack.
Этот коммит содержится в:
родитель
d599959711
коммит
75bcbbe6d8
1 изменённых файлов: 5 добавлений и 5 удалений
|
@ -18,7 +18,7 @@ SECTIONS
|
||||||
* See: http://blog.japaric.io/stack-overflow-protection/ */
|
* See: http://blog.japaric.io/stack-overflow-protection/ */
|
||||||
.stack (NOLOAD) :
|
.stack (NOLOAD) :
|
||||||
{
|
{
|
||||||
. = ALIGN(4);
|
. = ALIGN(8);
|
||||||
. += _stack_size;
|
. += _stack_size;
|
||||||
_stack_top = .;
|
_stack_top = .;
|
||||||
} >RAM
|
} >RAM
|
||||||
|
@ -29,25 +29,25 @@ SECTIONS
|
||||||
/* Globals with initial value */
|
/* Globals with initial value */
|
||||||
.data :
|
.data :
|
||||||
{
|
{
|
||||||
. = ALIGN(4);
|
. = ALIGN(8);
|
||||||
/* see https://gnu-mcu-eclipse.github.io/arch/riscv/programmer/#the-gp-global-pointer-register */
|
/* see https://gnu-mcu-eclipse.github.io/arch/riscv/programmer/#the-gp-global-pointer-register */
|
||||||
PROVIDE( __global_pointer$ = . + (4K / 2) );
|
PROVIDE( __global_pointer$ = . + (4K / 2) );
|
||||||
_sdata = .; /* used by startup code */
|
_sdata = .; /* used by startup code */
|
||||||
*(.sdata)
|
*(.sdata)
|
||||||
*(.data .data.*)
|
*(.data .data.*)
|
||||||
. = ALIGN(4);
|
. = ALIGN(8);
|
||||||
_edata = .; /* used by startup code */
|
_edata = .; /* used by startup code */
|
||||||
} >RAM AT>FLASH_TEXT
|
} >RAM AT>FLASH_TEXT
|
||||||
|
|
||||||
/* Zero-initialized globals */
|
/* Zero-initialized globals */
|
||||||
.bss :
|
.bss :
|
||||||
{
|
{
|
||||||
. = ALIGN(4);
|
. = ALIGN(8);
|
||||||
_sbss = .; /* used by startup code */
|
_sbss = .; /* used by startup code */
|
||||||
*(.sbss)
|
*(.sbss)
|
||||||
*(.bss .bss.*)
|
*(.bss .bss.*)
|
||||||
*(COMMON)
|
*(COMMON)
|
||||||
. = ALIGN(4);
|
. = ALIGN(8);
|
||||||
_ebss = .; /* used by startup code */
|
_ebss = .; /* used by startup code */
|
||||||
} >RAM
|
} >RAM
|
||||||
|
|
||||||
|
|
Загрузка…
Создание таблицы
Сослаться в новой задаче