Alignment of 1-Byte in the custom memory-region
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2020-04-01 04:55 AM
Hello all, I have created a custom section in memory region for the controller 'STM32L073VBT6TR' and also modified the linker-script for the same. I am using the '__attribute__((section(".custom_section")))' with the variables to be placed in the custom-section but however some of the variables with the 'unsigned char' are taking 4-bytes . I assume its the issue for alignment. Kindly suggest a way out. I am using the STM32CUBE-IDE for the development
- Labels:
-
DEBUG
-
STM32CubeIDE
-
STM32L0 Series
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2020-04-01 05:23 AM
Can you give an example what do you mean by 'are taking 4-bytes'?
In the following situation
char x;
int y;
char z;
The compiler might choose to leave 3 bytes unused after x to enforce a 4-byte alignment for y.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2020-04-01 05:56 AM
To forcefully pack data and tell the compiler the maybe overridden native alignment of some members you can put them into a packed struct like this (GCC example):
struct tPData
{
uint8_t A8;
uint16_t B16;
uint8_t C8;
uint32_t D32;
} __attribute__((__packed__));
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2020-04-01 06:10 AM
Thanks @Community member​ for being prompt, that's the backup plan, as I am using the multiple structures hence in your solution there will be multi-level of nested structure which could be less-manageable hence it would be good if we can align a 'custom_section' with 1-byte, suggestions for the same ?
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2020-04-01 11:57 AM
The problem is that sections are related to the linker which can align sections and even (linker generated) symbols by the linker script. But you’ll also need to tell the compiler the proper way to access individual, typed C variables. I think you’ve to tag all your structs packed if really needed and be aware that this might cause a certain performance penalty accessing them in a non-native way.
Also (mis-)aligning sections in the linker script is usually a bad idea because the compiler has no clue. It assumes alignments as specified by the EABI the compiler was built for and generates the corresponding code. But there is also an __align__ attribute ...