arch/arm: declare vector array default type to read-only
Reference:
https://developer.arm.com/documentation/dui0474/m/image-structure-and-generation/section-placement-with-the-linker/section-placement-with-the-first-and-last-attributes
CAUTION:
FIRST and LAST must not violate the basic attribute sorting order. For example, FIRST RW is placed after any read-only code or read-only data.
arm-none-eabi-readelf -aS arm_vectors.o
1. Without const:
Section Headers:
[Nr] Name Type Addr Off Size ES Flg Lk Inf Al
[ 3] .vectors PROGBITS 00000000 000034 00011c 00 WA 0 0 4
2. const symbol:
[ 3] .vectors PROGBITS 00000000 000034 00011c 00 A 0 0 4
Regression by:
| commit 229b57d6cb
|
| arch/armv[6|7|8]-m: Move _vectors to arm_internal.h to avoid the duplication
|
| and change the type of _vectors from uint32_t to const void *
|
| Signed-off-by: Xiang Xiao <xiaoxiang@xiaomi.com>
Signed-off-by: chao an <anchao@xiaomi.com>
This commit is contained in:
parent
c07d076bf5
commit
47b350a4c3
@ -81,7 +81,7 @@ extern void exception_common(void);
|
|||||||
* Note that the [ ... ] designated initialiser is a GCC extension.
|
* Note that the [ ... ] designated initialiser is a GCC extension.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const void *_vectors[] locate_data(".vectors") =
|
const void * const _vectors[] locate_data(".vectors") =
|
||||||
{
|
{
|
||||||
/* Initial stack */
|
/* Initial stack */
|
||||||
|
|
||||||
|
@ -76,7 +76,7 @@ extern void exception_common(void);
|
|||||||
* Note that the [ ... ] designated initializer is a GCC extension.
|
* Note that the [ ... ] designated initializer is a GCC extension.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const void *_vectors[] locate_data(".vectors") =
|
const void * const _vectors[] locate_data(".vectors") =
|
||||||
{
|
{
|
||||||
/* Initial stack */
|
/* Initial stack */
|
||||||
|
|
||||||
|
@ -76,7 +76,7 @@ extern void exception_common(void);
|
|||||||
* Note that the [ ... ] designated initializer is a GCC extension.
|
* Note that the [ ... ] designated initializer is a GCC extension.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const void *_vectors[] locate_data(".vectors") =
|
const void * const _vectors[] locate_data(".vectors") =
|
||||||
{
|
{
|
||||||
/* Initial stack */
|
/* Initial stack */
|
||||||
|
|
||||||
|
@ -319,7 +319,7 @@ uintptr_t arm_intstack_top(void);
|
|||||||
|
|
||||||
extern const void *__vector_table[];
|
extern const void *__vector_table[];
|
||||||
#else
|
#else
|
||||||
extern const void *_vectors[];
|
extern const void * const _vectors[];
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Interrupt acknowledge and dispatch */
|
/* Interrupt acknowledge and dispatch */
|
||||||
|
@ -63,7 +63,7 @@ extern void exception_common(void);
|
|||||||
* Note that the [ ... ] designated initialiser is a GCC extension.
|
* Note that the [ ... ] designated initialiser is a GCC extension.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const void *_vectors[] locate_data(".vectors") aligned_data(0x100) =
|
const void * const _vectors[] locate_data(".vectors") aligned_data(0x100) =
|
||||||
{
|
{
|
||||||
/* Initial stack */
|
/* Initial stack */
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user