bus width vs access width
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2019-09-25 10:21 AM
Hello,
We are using FMC interface.
Is it that the access must be in the same size of the memory data bus ?
In software, the bus width is defined as following:
MemoryDataWidth = FMC_NORSRAM_MEM_BUS_WIDTH_16;
and the access is 16 bit as following:
So, is it illegal to make the access in 32-bit if the data width is 16-bit ?
Thank you!
Solved! Go to Solution.
- Labels:
-
FMC-FSMC
Accepted Solutions
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2019-09-25 10:52 AM
> Is it that the access must be in the same size of the memory data bus ?
No.
Read the manual.
FMC chapter, Supported memories and transactions / General transaction rules. You again neglected to tell us that you are using H7, there this sentence applies:
The AXI transaction size depends on memory region MPU attributes
and in the other thread you started I gave you a link to a thread where that was discussed; read it.
JW
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2019-09-25 10:52 AM
> Is it that the access must be in the same size of the memory data bus ?
No.
Read the manual.
FMC chapter, Supported memories and transactions / General transaction rules. You again neglected to tell us that you are using H7, there this sentence applies:
The AXI transaction size depends on memory region MPU attributes
and in the other thread you started I gave you a link to a thread where that was discussed; read it.
JW
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2019-09-25 11:48 AM
The system decomposes transactions to the right sizes. Burst or sequenced accesses might be optimized, or folded at the FMC level depending on the configuration, or via other peripheral units attached to the FMC.
The processor handles some unaligned accesses, others will fault depending on the core implementation. For example 64-bit LDRD/STRD will fault across most cores for unaligned accesses. As I recall most cores will break a transaction in two, but don't have transistors to go further.
Up vote any posts that you find helpful, it shows what's working..