-
Notifications
You must be signed in to change notification settings - Fork 106
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Detailed examples memory.x files for all current STM32H7xx device families #299
Open
TomDeRybel
wants to merge
4
commits into
stm32-rs:master
Choose a base branch
from
TomDeRybel:master
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from all commits
Commits
Show all changes
4 commits
Select commit
Hold shift + click to select a range
5f636a1
Added more documented and explicit memory.x examples for all STM32H7x…
1bf52d5
Removed "INSERT AFTER .bss" to match stm32-rs#263 fix.
4f6c6a1
Improved the documentation for the H735 series regarding ITCM - AXISR…
ba6cabc
Added documentation on how to use the family-specific memory.x files.
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,106 @@ | ||
MEMORY | ||
{ | ||
/* This file is intended for parts in the STM32H735 family. (RM0468) */ | ||
/* - FLASH and RAM are mandatory memory sections. */ | ||
/* - The sum of all non-FLASH sections must add to 564k total device RAM. */ | ||
/* - The FLASH section size must match your device, see table below. */ | ||
|
||
/* FLASH */ | ||
/* Select the appropriate FLASH size for your device. */ | ||
/* - STM32H730xB 128K */ | ||
/* - STM32H723xE/725xE 512K */ | ||
/* - STM32H723xG/725xG/733xG/735xG 1M */ | ||
FLASH1 : ORIGIN = 0x08000000, LENGTH = 1M | ||
|
||
/* Data TCM */ | ||
/* - Two contiguous 64KB RAMs. */ | ||
/* - Used for interrupt handlers, stacks and general RAM. */ | ||
/* - Zero wait-states. */ | ||
/* - The DTCM is taken as the origin of the base ram. (See below.) */ | ||
/* This is also where the interrupt table and such will live, */ | ||
/* which is required for deterministic performance. */ | ||
DTCM : ORIGIN = 0x20000000, LENGTH = 128K | ||
|
||
/* Instruction TCM */ | ||
/* - More memory can be assigned to ITCM. See AXI SRAM notes, below. */ | ||
/* - Used for latency-critical interrupt handlers etc. */ | ||
/* - Zero wait-states. */ | ||
ITCM : ORIGIN = 0x00000000, LENGTH = 64K + 0K | ||
|
||
/* AXI SRAM */ | ||
/* - AXISRAM is in D1 and accessible by all system masters except BDMA. */ | ||
/* - Suitable for application data not stored in DTCM. */ | ||
/* - Zero wait-states. */ | ||
/* - The 192k of extra shared RAM is fully allotted to the AXI SRAM by default. */ | ||
/* As a result: 64k (64k + 0k) for ITCM and 320k (128k + 192k) for AXI SRAM. */ | ||
/* This can be re-configured via the TCM_AXI_SHARED[1,0] register when more */ | ||
/* ITCM is required. */ | ||
AXISRAM : ORIGIN = 0x24000000, LENGTH = 128K + 192K | ||
|
||
/* AHB SRAM */ | ||
/* - SRAM1-2 are in D2 and accessible by all system masters except BDMA, LTDC */ | ||
/* and SDMMC1. Suitable for use as DMA buffers. */ | ||
/* - SRAM4 is in D3 and additionally accessible by the BDMA. Used for BDMA */ | ||
/* buffers, for storing application data in lower-power modes. */ | ||
/* - Zero wait-states. */ | ||
SRAM1 : ORIGIN = 0x30000000, LENGTH = 16K | ||
SRAM2 : ORIGIN = 0x30040000, LENGTH = 16K | ||
SRAM4 : ORIGIN = 0x38000000, LENGTH = 16K | ||
|
||
/* Backup SRAM */ | ||
/* Used to store data during low-power sleeps. */ | ||
BSRAM : ORIGIN = 0x38800000, LENGTH = 4K | ||
} | ||
|
||
/* | ||
/* Assign the memory regions defined above for use. */ | ||
/* | ||
|
||
/* Provide the mandatory FLASH and RAM definitions for cortex-m-rt's linker script. */ | ||
REGION_ALIAS(FLASH, FLASH1); | ||
REGION_ALIAS(RAM, DTCM); | ||
|
||
/* The location of the stack can be overridden using the `_stack_start` symbol. */ | ||
/* - Set the stack location at the end of RAM, using all remaining space. */ | ||
_stack_start = ORIGIN(RAM) + LENGTH(RAM); | ||
|
||
/* The location of the .text section can be overridden using the */ | ||
/* `_stext` symbol. By default it will place after .vector_table. */ | ||
/* _stext = ORIGIN(FLASH) + 0x40c; */ | ||
|
||
/* Define sections for placing symbols into the extra memory regions above. */ | ||
/* This makes them accessible from code. */ | ||
/* - ITCM, DTCM and AXISRAM connect to a 64-bit wide bus -> align to 8 bytes. */ | ||
/* - All other memories connect to a 32-bit wide bus -> align to 4 bytes. */ | ||
SECTIONS { | ||
.itcm (NOLOAD) : ALIGN(8) { | ||
*(.itcm .itcm.*); | ||
. = ALIGN(8); | ||
} > ITCM | ||
|
||
.axisram (NOLOAD) : ALIGN(8) { | ||
*(.axisram .axisram.*); | ||
. = ALIGN(8); | ||
} > AXISRAM | ||
|
||
.sram1 (NOLOAD) : ALIGN(4) { | ||
*(.sram1 .sram1.*); | ||
. = ALIGN(4); | ||
} > SRAM1 | ||
|
||
.sram2 (NOLOAD) : ALIGN(4) { | ||
*(.sram2 .sram2.*); | ||
. = ALIGN(4); | ||
} > SRAM2 | ||
|
||
.sram4 (NOLOAD) : ALIGN(4) { | ||
*(.sram4 .sram4.*); | ||
. = ALIGN(4); | ||
} > SRAM4 | ||
|
||
.bsram (NOLOAD) : ALIGN(4) { | ||
*(.bsram .bsram.*); | ||
. = ALIGN(4); | ||
} > BSRAM | ||
|
||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
MEMORY | ||
{ | ||
/* This file is intended for parts in the STM32H742/742v families. (RM0433) */ | ||
/* - FLASH and RAM are mandatory memory sections. */ | ||
/* - The sum of all non-FLASH sections must add to 692K total device RAM. */ | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The only family that supports re-assigning memory around the map is STM32H735, so I don't think there's any value in stating this sum for the other families |
||
/* - The FLASH section size must match your device, see table below. */ | ||
|
||
/* FLASH */ | ||
/* Flash is divided in two independent banks. */ | ||
/* Select the appropriate FLASH size for your device. */ | ||
/* - STM32H742xG 1M (512K + 512K) */ | ||
/* - STM32H742xI 2M ( 1M + 1M) */ | ||
FLASH1 : ORIGIN = 0x08000000, LENGTH = 1M | ||
FLASH2 : ORIGIN = 0x08100000, LENGTH = 1M | ||
|
||
/* Data TCM */ | ||
/* - Two contiguous 64KB RAMs. */ | ||
/* - Used for interrupt handlers, stacks and general RAM. */ | ||
/* - Zero wait-states. */ | ||
/* - The DTCM is taken as the origin of the base ram. (See below.) */ | ||
/* This is also where the interrupt table and such will live, */ | ||
/* which is required for deterministic performance. */ | ||
DTCM : ORIGIN = 0x20000000, LENGTH = 128K | ||
|
||
/* Instruction TCM */ | ||
/* - Used for latency-critical interrupt handlers etc. */ | ||
/* - Zero wait-states. */ | ||
ITCM : ORIGIN = 0x00000000, LENGTH = 64K | ||
|
||
/* AXI SRAM */ | ||
/* - AXISRAM is in D1 and accessible by all system masters except BDMA. */ | ||
/* - Suitable for application data not stored in DTCM. */ | ||
/* - Zero wait-states. */ | ||
AXISRAM : ORIGIN = 0x24000000, LENGTH = 384K | ||
|
||
/* AHB SRAM */ | ||
/* - SRAM1-2 are in D2 and accessible by all system masters except BDMA. */ | ||
/* Suitable for use as DMA buffers. */ | ||
/* - SRAM4 is in D3 and additionally accessible by the BDMA. Used for BDMA */ | ||
/* buffers, for storing application data in lower-power modes. */ | ||
/* - Zero wait-states. */ | ||
SRAM1 : ORIGIN = 0x30000000, LENGTH = 32K | ||
SRAM2 : ORIGIN = 0x30020000, LENGTH = 16K | ||
SRAM4 : ORIGIN = 0x38000000, LENGTH = 64K | ||
|
||
/* Backup SRAM */ | ||
/* Used to store data during low-power sleeps. */ | ||
BSRAM : ORIGIN = 0x38800000, LENGTH = 4K | ||
} | ||
|
||
/* | ||
/* Assign the memory regions defined above for use. */ | ||
/* | ||
|
||
/* Provide the mandatory FLASH and RAM definitions for cortex-m-rt's linker script. */ | ||
REGION_ALIAS(FLASH, FLASH1); | ||
REGION_ALIAS(RAM, DTCM); | ||
|
||
/* The location of the stack can be overridden using the `_stack_start` symbol. */ | ||
/* - Set the stack location at the end of RAM, using all remaining space. */ | ||
_stack_start = ORIGIN(RAM) + LENGTH(RAM); | ||
|
||
/* The location of the .text section can be overridden using the */ | ||
/* `_stext` symbol. By default it will place after .vector_table. */ | ||
/* _stext = ORIGIN(FLASH) + 0x40c; */ | ||
|
||
/* Define sections for placing symbols into the extra memory regions above. */ | ||
/* This makes them accessible from code. */ | ||
/* - ITCM, DTCM and AXISRAM connect to a 64-bit wide bus -> align to 8 bytes. */ | ||
/* - All other memories connect to a 32-bit wide bus -> align to 4 bytes. */ | ||
SECTIONS { | ||
.flash2 (NOLOAD) : ALIGN(4) { | ||
*(.flash2 .flash2.*); | ||
. = ALIGN(4); | ||
} > FLASH2 | ||
|
||
.itcm (NOLOAD) : ALIGN(8) { | ||
*(.itcm .itcm.*); | ||
. = ALIGN(8); | ||
} > ITCM | ||
|
||
.axisram (NOLOAD) : ALIGN(8) { | ||
*(.axisram .axisram.*); | ||
. = ALIGN(8); | ||
} > AXISRAM | ||
|
||
.sram1 (NOLOAD) : ALIGN(8) { | ||
*(.sram1 .sram1.*); | ||
. = ALIGN(4); | ||
} > SRAM1 | ||
|
||
.sram2 (NOLOAD) : ALIGN(8) { | ||
*(.sram2 .sram2.*); | ||
. = ALIGN(4); | ||
} > SRAM2 | ||
|
||
.sram4 (NOLOAD) : ALIGN(4) { | ||
*(.sram4 .sram4.*); | ||
. = ALIGN(4); | ||
} > SRAM4 | ||
|
||
.bsram (NOLOAD) : ALIGN(4) { | ||
*(.bsram .bsram.*); | ||
. = ALIGN(4); | ||
} > BSRAM | ||
|
||
}; |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You can delete this little "Flash memory size" section, I think it's sufficiently covered by the new memory__.x files now