2018-04-19 13:24:26 +02:00
|
|
|
/*
|
|
|
|
Linker script for fxcg50 add-ins. Most symbols are used in the startup
|
|
|
|
routine in core/start.c; some others in core/setup.c.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* All fxcg50 have SH4 processors (finally rid of compatibility issues) */
|
|
|
|
OUTPUT_ARCH(sh4)
|
|
|
|
/* ELF offers a lot of symbol/section/relocation insights */
|
|
|
|
OUTPUT_FORMAT(elf32-sh)
|
|
|
|
/* Located in core/start.c */
|
|
|
|
ENTRY(_start)
|
|
|
|
|
|
|
|
MEMORY
|
|
|
|
{
|
|
|
|
/* Userspace mapping of the add-in (without G3A header) */
|
2020-06-14 11:01:27 +02:00
|
|
|
rom (rx): o = 0x00300000, l = 2M
|
2018-04-19 13:24:26 +02:00
|
|
|
/* Static RAM; stack grows down from the end of this region.
|
kernel: dynamic loading of GMAPPED functions to user RAM
This commit introduces a large architectural change. Unlike previous
models of the fx-9860G series, the G-III models have a new user RAM
address different from 8801c000. The purpose of this change is to
dynamically load GMAPPED functions to this address by querying the TLB,
and call them through a function pointer whose address is determined
when loading.
Because of the overhead of using a function pointer in both assembly and
C code, changes have been made to avoid GMAPPED functions altogether.
Current, only cpu_setVBR() and gint_inth_callback() are left, the second
being used specifically to enable TLB misses when needed.
* Add a .gint.mappedrel section for the function pointers holding
addresses to GMAPPED functions; add function pointers for
cpu_setVBR() and gint_inth_callback()
* Move rram to address 0 instead of the hardcoded 0x8801c000
* Load GMAPPED functions at their linked address + the physical address
user RAM is mapped, to and compute their function pointers
* Remove the GMAPPED macro since no user function needs it anymore
* Add section flags "ax" (code) or "aw" (data) to every custom .section
in assembler code, as they default to unpredictable values that can
cause the section to be marked NOLOAD by the linker
* Update the main kernel, TMU, ETMU and RTC interrupt handlers to use
the new indirect calling method
This is made possible by new MMU functions giving direct access to the
physical area behind any virtualized page.
* Add an mmu_translate() function to query the TLB
* Add an mmu_uram() function to access user RAM from P1
The exception catching mechanism has been modified to avoid the use of
GMAPPED functions altogether.
* Set SR.BL=0 and SR.IMASK=15 before calling exception catchers
* Move gint_exc_skip() to normal text ROM
* Also fix registers not being popped off the stack before a panic
The timer drivers have also been modified to avoid GMAPPED functions.
* Invoke timer_stop() through gint_inth_callback() and move it to ROM
* Move and expand the ETMU driver to span 3 blocks at 0xd00 (ETMU4)
* Remove the timer_clear() function by inlining it into the ETMU handler
(TCR is provided within the storage block of each timer)
* Also split src/timer/inth.s into src/timer/inth-{tmu,etmu}.s
Additionally, VBR addresses are now determined at runtime to further
reduce hardcoded memory layout addresses in the linker script.
* Determine fx-9860G VBR addresses dynamically from mmu_uram()
* Determine fx-CG 50 VBR addresses dynamically from mmu_uram()
* Remove linker symbols for VBR addresses
Comments and documentation have been updated throughout the code to
reflect the changes.
2020-09-17 14:48:54 +02:00
|
|
|
The first 5k (0x1400 bytes) are reserved by gint for the VBR space,
|
|
|
|
which is loaded dynamically and accessed through P1 */
|
2022-01-10 14:46:45 +01:00
|
|
|
ram (rw): o = 0x08101400, l = 491k
|
2019-09-15 19:29:47 +02:00
|
|
|
/* On-chip IL memory */
|
|
|
|
ilram (rwx): o = 0xe5200000, l = 4k
|
|
|
|
/* On-chip X and Y memory */
|
2022-05-04 18:21:23 +02:00
|
|
|
xyram (rwx): o = 0xe500e000, l = 16k
|
2018-04-19 13:24:26 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
SECTIONS
|
|
|
|
{
|
|
|
|
/*
|
2019-09-15 19:29:47 +02:00
|
|
|
** ROM sections
|
2018-04-19 13:24:26 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
/* First address to be mapped to ROM */
|
|
|
|
_brom = 0x00300000;
|
|
|
|
/* Size of ROM mappings */
|
|
|
|
_srom = SIZEOF(.text) + SIZEOF(.rodata)
|
|
|
|
+ SIZEOF(.gint.drivers) + SIZEOF(.gint.blocks);
|
|
|
|
|
|
|
|
/* Machine code going to ROM:
|
2020-06-20 17:18:51 +02:00
|
|
|
- Entry function (.text.entry)
|
2018-04-19 13:24:26 +02:00
|
|
|
- Compiler-provided constructors (.ctors) and destructors (.dtors)
|
|
|
|
- All text from .text and .text.* (including user code) */
|
|
|
|
.text : {
|
2020-06-20 17:18:51 +02:00
|
|
|
*(.text.entry)
|
2018-04-19 13:24:26 +02:00
|
|
|
|
2020-06-20 17:18:51 +02:00
|
|
|
_bctors = . ;
|
2018-04-19 13:24:26 +02:00
|
|
|
*(.ctors .ctors.*)
|
2020-06-20 17:18:51 +02:00
|
|
|
_ectors = . ;
|
|
|
|
|
|
|
|
_bdtors = . ;
|
2018-04-19 13:24:26 +02:00
|
|
|
*(.dtors .dtors.*)
|
2020-06-20 17:18:51 +02:00
|
|
|
_edtors = . ;
|
2018-04-19 13:24:26 +02:00
|
|
|
|
2020-06-14 18:22:20 +02:00
|
|
|
_gint_exch_start = . ;
|
|
|
|
*(.gint.exch)
|
|
|
|
_gint_exch_size = ABSOLUTE(. - _gint_exch_start);
|
|
|
|
|
|
|
|
_gint_tlbh_start = . ;
|
|
|
|
*(.gint.tlbh)
|
|
|
|
_gint_tlbh_size = ABSOLUTE(. - _gint_tlbh_start);
|
2019-09-03 22:15:00 +02:00
|
|
|
|
2018-04-19 13:24:26 +02:00
|
|
|
*(.text .text.*)
|
|
|
|
} > rom
|
|
|
|
|
2020-07-02 15:47:11 +02:00
|
|
|
/* gint's interrupt handler blocks (.gint.blocks)
|
|
|
|
Although gint's blocks end up in VBR space, they are relocated at
|
2018-04-19 13:24:26 +02:00
|
|
|
startup by the library/drivers, so we store them here for now */
|
|
|
|
.gint.blocks : {
|
|
|
|
KEEP(*(.gint.blocks));
|
|
|
|
} > rom
|
|
|
|
|
2020-07-02 15:47:11 +02:00
|
|
|
/* Exposed driver interfaces (.gint.drivers)
|
2018-04-19 13:24:26 +02:00
|
|
|
The driver information is required to start and configure the
|
|
|
|
driver, even if the symbols are not referenced */
|
|
|
|
.gint.drivers : {
|
2021-04-23 18:50:20 +02:00
|
|
|
_gint_drivers = . ;
|
|
|
|
KEEP(*(SORT_BY_NAME(.gint.drivers.*)));
|
|
|
|
_gint_drivers_end = . ;
|
2018-04-19 13:24:26 +02:00
|
|
|
} > rom
|
|
|
|
|
|
|
|
/* Read-only data going to ROM:
|
|
|
|
- Resources or assets from fxconv or similar converters
|
|
|
|
- Data marked read-only by the compiler (.rodata and .rodata.*) */
|
|
|
|
.rodata : SUBALIGN(4) {
|
|
|
|
/* Put these first, they need to be 4-aligned */
|
2019-09-15 19:29:47 +02:00
|
|
|
*(.rodata.4)
|
2018-04-19 13:24:26 +02:00
|
|
|
|
|
|
|
*(.rodata .rodata.*)
|
|
|
|
} > rom
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
2019-09-15 19:29:47 +02:00
|
|
|
** RAM sections
|
2018-04-19 13:24:26 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
. = ORIGIN(ram);
|
|
|
|
|
|
|
|
/* BSS data going to RAM. The BSS section is to be stripped from the
|
|
|
|
ELF file later, and wiped at startup */
|
|
|
|
.bss (NOLOAD) : {
|
|
|
|
_rbss = . ;
|
|
|
|
|
|
|
|
*(.bss COMMON)
|
|
|
|
|
|
|
|
. = ALIGN(16);
|
|
|
|
} > ram :NONE
|
|
|
|
|
|
|
|
_sbss = SIZEOF(.bss);
|
|
|
|
|
2020-02-23 15:49:55 +01:00
|
|
|
/* Read-write data sections going to RAM (.data and .data.*) */
|
2018-04-19 13:24:26 +02:00
|
|
|
.data ALIGN(4) : ALIGN(4) {
|
|
|
|
_ldata = LOADADDR(.data);
|
|
|
|
_rdata = . ;
|
|
|
|
|
|
|
|
*(.data .data.*)
|
kernel: dynamic loading of GMAPPED functions to user RAM
This commit introduces a large architectural change. Unlike previous
models of the fx-9860G series, the G-III models have a new user RAM
address different from 8801c000. The purpose of this change is to
dynamically load GMAPPED functions to this address by querying the TLB,
and call them through a function pointer whose address is determined
when loading.
Because of the overhead of using a function pointer in both assembly and
C code, changes have been made to avoid GMAPPED functions altogether.
Current, only cpu_setVBR() and gint_inth_callback() are left, the second
being used specifically to enable TLB misses when needed.
* Add a .gint.mappedrel section for the function pointers holding
addresses to GMAPPED functions; add function pointers for
cpu_setVBR() and gint_inth_callback()
* Move rram to address 0 instead of the hardcoded 0x8801c000
* Load GMAPPED functions at their linked address + the physical address
user RAM is mapped, to and compute their function pointers
* Remove the GMAPPED macro since no user function needs it anymore
* Add section flags "ax" (code) or "aw" (data) to every custom .section
in assembler code, as they default to unpredictable values that can
cause the section to be marked NOLOAD by the linker
* Update the main kernel, TMU, ETMU and RTC interrupt handlers to use
the new indirect calling method
This is made possible by new MMU functions giving direct access to the
physical area behind any virtualized page.
* Add an mmu_translate() function to query the TLB
* Add an mmu_uram() function to access user RAM from P1
The exception catching mechanism has been modified to avoid the use of
GMAPPED functions altogether.
* Set SR.BL=0 and SR.IMASK=15 before calling exception catchers
* Move gint_exc_skip() to normal text ROM
* Also fix registers not being popped off the stack before a panic
The timer drivers have also been modified to avoid GMAPPED functions.
* Invoke timer_stop() through gint_inth_callback() and move it to ROM
* Move and expand the ETMU driver to span 3 blocks at 0xd00 (ETMU4)
* Remove the timer_clear() function by inlining it into the ETMU handler
(TCR is provided within the storage block of each timer)
* Also split src/timer/inth.s into src/timer/inth-{tmu,etmu}.s
Additionally, VBR addresses are now determined at runtime to further
reduce hardcoded memory layout addresses in the linker script.
* Determine fx-9860G VBR addresses dynamically from mmu_uram()
* Determine fx-CG 50 VBR addresses dynamically from mmu_uram()
* Remove linker symbols for VBR addresses
Comments and documentation have been updated throughout the code to
reflect the changes.
2020-09-17 14:48:54 +02:00
|
|
|
/* References to mapped code - no relocation needed */
|
|
|
|
*(.gint.mappedrel)
|
2018-04-19 13:24:26 +02:00
|
|
|
|
|
|
|
. = ALIGN(16);
|
|
|
|
} > ram AT> rom
|
|
|
|
|
2019-02-21 20:58:38 +01:00
|
|
|
/* Read-write data sub-aligned to 4 bytes (mainly from fxconv) */
|
|
|
|
.data.4 : SUBALIGN(4) {
|
|
|
|
*(.data.4)
|
|
|
|
. = ALIGN(16);
|
|
|
|
} > ram AT> rom
|
|
|
|
|
|
|
|
_sdata = SIZEOF(.data) + SIZEOF(.data.4);
|
2018-04-19 13:24:26 +02:00
|
|
|
|
2019-09-15 19:29:47 +02:00
|
|
|
/* On-chip memory sections: IL, X and Y memory */
|
|
|
|
|
|
|
|
. = ORIGIN(ilram);
|
|
|
|
.ilram ALIGN(4) : ALIGN(4) {
|
|
|
|
_lilram = LOADADDR(.ilram);
|
|
|
|
_rilram = . ;
|
|
|
|
|
|
|
|
*(.ilram)
|
2020-06-15 20:55:18 +02:00
|
|
|
/* Code that must remain mapped is placed here */
|
|
|
|
*(.gint.mapped)
|
2019-09-15 19:29:47 +02:00
|
|
|
|
|
|
|
. = ALIGN(16);
|
|
|
|
} > ilram AT> rom
|
|
|
|
|
2022-05-04 18:21:23 +02:00
|
|
|
. = ORIGIN(xyram);
|
|
|
|
.xyram ALIGN(4) : ALIGN(4) {
|
|
|
|
_lxyram = LOADADDR(.xyram);
|
|
|
|
_rxyram = . ;
|
2019-09-15 19:29:47 +02:00
|
|
|
|
2022-05-04 18:21:23 +02:00
|
|
|
*(.xram .yram .xyram)
|
2019-09-15 19:29:47 +02:00
|
|
|
|
|
|
|
. = ALIGN(16);
|
2022-05-04 18:21:23 +02:00
|
|
|
} > xyram AT> rom
|
2019-09-15 19:29:47 +02:00
|
|
|
|
|
|
|
_silram = SIZEOF(.ilram);
|
2022-05-04 18:21:23 +02:00
|
|
|
_sxyram = SIZEOF(.xyram);
|
2019-09-15 19:29:47 +02:00
|
|
|
|
2018-04-19 13:24:26 +02:00
|
|
|
/* gint's uninitialized BSS section, going to static RAM. All the large
|
|
|
|
data arrays will be located here */
|
|
|
|
.gint.bss (NOLOAD) : {
|
2020-07-10 16:36:05 +02:00
|
|
|
*(.gint.bss)
|
2018-04-19 13:24:26 +02:00
|
|
|
. = ALIGN(16);
|
2021-02-15 09:39:14 +01:00
|
|
|
|
|
|
|
/* End of user RAM */
|
|
|
|
_euram = . ;
|
2020-06-18 09:59:31 +02:00
|
|
|
} > ram :NONE
|
2018-04-19 13:24:26 +02:00
|
|
|
|
|
|
|
_sgbss = SIZEOF(.gint.bss);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
kernel: dynamic loading of GMAPPED functions to user RAM
This commit introduces a large architectural change. Unlike previous
models of the fx-9860G series, the G-III models have a new user RAM
address different from 8801c000. The purpose of this change is to
dynamically load GMAPPED functions to this address by querying the TLB,
and call them through a function pointer whose address is determined
when loading.
Because of the overhead of using a function pointer in both assembly and
C code, changes have been made to avoid GMAPPED functions altogether.
Current, only cpu_setVBR() and gint_inth_callback() are left, the second
being used specifically to enable TLB misses when needed.
* Add a .gint.mappedrel section for the function pointers holding
addresses to GMAPPED functions; add function pointers for
cpu_setVBR() and gint_inth_callback()
* Move rram to address 0 instead of the hardcoded 0x8801c000
* Load GMAPPED functions at their linked address + the physical address
user RAM is mapped, to and compute their function pointers
* Remove the GMAPPED macro since no user function needs it anymore
* Add section flags "ax" (code) or "aw" (data) to every custom .section
in assembler code, as they default to unpredictable values that can
cause the section to be marked NOLOAD by the linker
* Update the main kernel, TMU, ETMU and RTC interrupt handlers to use
the new indirect calling method
This is made possible by new MMU functions giving direct access to the
physical area behind any virtualized page.
* Add an mmu_translate() function to query the TLB
* Add an mmu_uram() function to access user RAM from P1
The exception catching mechanism has been modified to avoid the use of
GMAPPED functions altogether.
* Set SR.BL=0 and SR.IMASK=15 before calling exception catchers
* Move gint_exc_skip() to normal text ROM
* Also fix registers not being popped off the stack before a panic
The timer drivers have also been modified to avoid GMAPPED functions.
* Invoke timer_stop() through gint_inth_callback() and move it to ROM
* Move and expand the ETMU driver to span 3 blocks at 0xd00 (ETMU4)
* Remove the timer_clear() function by inlining it into the ETMU handler
(TCR is provided within the storage block of each timer)
* Also split src/timer/inth.s into src/timer/inth-{tmu,etmu}.s
Additionally, VBR addresses are now determined at runtime to further
reduce hardcoded memory layout addresses in the linker script.
* Determine fx-9860G VBR addresses dynamically from mmu_uram()
* Determine fx-CG 50 VBR addresses dynamically from mmu_uram()
* Remove linker symbols for VBR addresses
Comments and documentation have been updated throughout the code to
reflect the changes.
2020-09-17 14:48:54 +02:00
|
|
|
** Unused sections
|
2018-04-19 13:24:26 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
/DISCARD/ : {
|
kernel: dynamic loading of GMAPPED functions to user RAM
This commit introduces a large architectural change. Unlike previous
models of the fx-9860G series, the G-III models have a new user RAM
address different from 8801c000. The purpose of this change is to
dynamically load GMAPPED functions to this address by querying the TLB,
and call them through a function pointer whose address is determined
when loading.
Because of the overhead of using a function pointer in both assembly and
C code, changes have been made to avoid GMAPPED functions altogether.
Current, only cpu_setVBR() and gint_inth_callback() are left, the second
being used specifically to enable TLB misses when needed.
* Add a .gint.mappedrel section for the function pointers holding
addresses to GMAPPED functions; add function pointers for
cpu_setVBR() and gint_inth_callback()
* Move rram to address 0 instead of the hardcoded 0x8801c000
* Load GMAPPED functions at their linked address + the physical address
user RAM is mapped, to and compute their function pointers
* Remove the GMAPPED macro since no user function needs it anymore
* Add section flags "ax" (code) or "aw" (data) to every custom .section
in assembler code, as they default to unpredictable values that can
cause the section to be marked NOLOAD by the linker
* Update the main kernel, TMU, ETMU and RTC interrupt handlers to use
the new indirect calling method
This is made possible by new MMU functions giving direct access to the
physical area behind any virtualized page.
* Add an mmu_translate() function to query the TLB
* Add an mmu_uram() function to access user RAM from P1
The exception catching mechanism has been modified to avoid the use of
GMAPPED functions altogether.
* Set SR.BL=0 and SR.IMASK=15 before calling exception catchers
* Move gint_exc_skip() to normal text ROM
* Also fix registers not being popped off the stack before a panic
The timer drivers have also been modified to avoid GMAPPED functions.
* Invoke timer_stop() through gint_inth_callback() and move it to ROM
* Move and expand the ETMU driver to span 3 blocks at 0xd00 (ETMU4)
* Remove the timer_clear() function by inlining it into the ETMU handler
(TCR is provided within the storage block of each timer)
* Also split src/timer/inth.s into src/timer/inth-{tmu,etmu}.s
Additionally, VBR addresses are now determined at runtime to further
reduce hardcoded memory layout addresses in the linker script.
* Determine fx-9860G VBR addresses dynamically from mmu_uram()
* Determine fx-CG 50 VBR addresses dynamically from mmu_uram()
* Remove linker symbols for VBR addresses
Comments and documentation have been updated throughout the code to
reflect the changes.
2020-09-17 14:48:54 +02:00
|
|
|
/* SH3-only data sections */
|
|
|
|
*(.gint.data.sh3 .gint.bss.sh3)
|
|
|
|
/* Debug sections (often from libgcc) */
|
2018-08-01 20:41:36 +02:00
|
|
|
*(.debug_info .debug_abbrev .debug_loc .debug_aranges
|
2022-03-19 20:26:05 +01:00
|
|
|
.debug_ranges .debug_line .debug_str .debug_frame
|
|
|
|
.debug_loclists .debug_rnglists)
|
kernel: dynamic loading of GMAPPED functions to user RAM
This commit introduces a large architectural change. Unlike previous
models of the fx-9860G series, the G-III models have a new user RAM
address different from 8801c000. The purpose of this change is to
dynamically load GMAPPED functions to this address by querying the TLB,
and call them through a function pointer whose address is determined
when loading.
Because of the overhead of using a function pointer in both assembly and
C code, changes have been made to avoid GMAPPED functions altogether.
Current, only cpu_setVBR() and gint_inth_callback() are left, the second
being used specifically to enable TLB misses when needed.
* Add a .gint.mappedrel section for the function pointers holding
addresses to GMAPPED functions; add function pointers for
cpu_setVBR() and gint_inth_callback()
* Move rram to address 0 instead of the hardcoded 0x8801c000
* Load GMAPPED functions at their linked address + the physical address
user RAM is mapped, to and compute their function pointers
* Remove the GMAPPED macro since no user function needs it anymore
* Add section flags "ax" (code) or "aw" (data) to every custom .section
in assembler code, as they default to unpredictable values that can
cause the section to be marked NOLOAD by the linker
* Update the main kernel, TMU, ETMU and RTC interrupt handlers to use
the new indirect calling method
This is made possible by new MMU functions giving direct access to the
physical area behind any virtualized page.
* Add an mmu_translate() function to query the TLB
* Add an mmu_uram() function to access user RAM from P1
The exception catching mechanism has been modified to avoid the use of
GMAPPED functions altogether.
* Set SR.BL=0 and SR.IMASK=15 before calling exception catchers
* Move gint_exc_skip() to normal text ROM
* Also fix registers not being popped off the stack before a panic
The timer drivers have also been modified to avoid GMAPPED functions.
* Invoke timer_stop() through gint_inth_callback() and move it to ROM
* Move and expand the ETMU driver to span 3 blocks at 0xd00 (ETMU4)
* Remove the timer_clear() function by inlining it into the ETMU handler
(TCR is provided within the storage block of each timer)
* Also split src/timer/inth.s into src/timer/inth-{tmu,etmu}.s
Additionally, VBR addresses are now determined at runtime to further
reduce hardcoded memory layout addresses in the linker script.
* Determine fx-9860G VBR addresses dynamically from mmu_uram()
* Determine fx-CG 50 VBR addresses dynamically from mmu_uram()
* Remove linker symbols for VBR addresses
Comments and documentation have been updated throughout the code to
reflect the changes.
2020-09-17 14:48:54 +02:00
|
|
|
/* Java class registration (why are they even here?!) */
|
2018-04-19 13:24:26 +02:00
|
|
|
*(.jcr)
|
kernel: dynamic loading of GMAPPED functions to user RAM
This commit introduces a large architectural change. Unlike previous
models of the fx-9860G series, the G-III models have a new user RAM
address different from 8801c000. The purpose of this change is to
dynamically load GMAPPED functions to this address by querying the TLB,
and call them through a function pointer whose address is determined
when loading.
Because of the overhead of using a function pointer in both assembly and
C code, changes have been made to avoid GMAPPED functions altogether.
Current, only cpu_setVBR() and gint_inth_callback() are left, the second
being used specifically to enable TLB misses when needed.
* Add a .gint.mappedrel section for the function pointers holding
addresses to GMAPPED functions; add function pointers for
cpu_setVBR() and gint_inth_callback()
* Move rram to address 0 instead of the hardcoded 0x8801c000
* Load GMAPPED functions at their linked address + the physical address
user RAM is mapped, to and compute their function pointers
* Remove the GMAPPED macro since no user function needs it anymore
* Add section flags "ax" (code) or "aw" (data) to every custom .section
in assembler code, as they default to unpredictable values that can
cause the section to be marked NOLOAD by the linker
* Update the main kernel, TMU, ETMU and RTC interrupt handlers to use
the new indirect calling method
This is made possible by new MMU functions giving direct access to the
physical area behind any virtualized page.
* Add an mmu_translate() function to query the TLB
* Add an mmu_uram() function to access user RAM from P1
The exception catching mechanism has been modified to avoid the use of
GMAPPED functions altogether.
* Set SR.BL=0 and SR.IMASK=15 before calling exception catchers
* Move gint_exc_skip() to normal text ROM
* Also fix registers not being popped off the stack before a panic
The timer drivers have also been modified to avoid GMAPPED functions.
* Invoke timer_stop() through gint_inth_callback() and move it to ROM
* Move and expand the ETMU driver to span 3 blocks at 0xd00 (ETMU4)
* Remove the timer_clear() function by inlining it into the ETMU handler
(TCR is provided within the storage block of each timer)
* Also split src/timer/inth.s into src/timer/inth-{tmu,etmu}.s
Additionally, VBR addresses are now determined at runtime to further
reduce hardcoded memory layout addresses in the linker script.
* Determine fx-9860G VBR addresses dynamically from mmu_uram()
* Determine fx-CG 50 VBR addresses dynamically from mmu_uram()
* Remove linker symbols for VBR addresses
Comments and documentation have been updated throughout the code to
reflect the changes.
2020-09-17 14:48:54 +02:00
|
|
|
/* Asynchronous unwind tables: no C++ exception handling */
|
2018-04-19 13:24:26 +02:00
|
|
|
*(.eh_frame_hdr)
|
|
|
|
*(.eh_frame)
|
kernel: dynamic loading of GMAPPED functions to user RAM
This commit introduces a large architectural change. Unlike previous
models of the fx-9860G series, the G-III models have a new user RAM
address different from 8801c000. The purpose of this change is to
dynamically load GMAPPED functions to this address by querying the TLB,
and call them through a function pointer whose address is determined
when loading.
Because of the overhead of using a function pointer in both assembly and
C code, changes have been made to avoid GMAPPED functions altogether.
Current, only cpu_setVBR() and gint_inth_callback() are left, the second
being used specifically to enable TLB misses when needed.
* Add a .gint.mappedrel section for the function pointers holding
addresses to GMAPPED functions; add function pointers for
cpu_setVBR() and gint_inth_callback()
* Move rram to address 0 instead of the hardcoded 0x8801c000
* Load GMAPPED functions at their linked address + the physical address
user RAM is mapped, to and compute their function pointers
* Remove the GMAPPED macro since no user function needs it anymore
* Add section flags "ax" (code) or "aw" (data) to every custom .section
in assembler code, as they default to unpredictable values that can
cause the section to be marked NOLOAD by the linker
* Update the main kernel, TMU, ETMU and RTC interrupt handlers to use
the new indirect calling method
This is made possible by new MMU functions giving direct access to the
physical area behind any virtualized page.
* Add an mmu_translate() function to query the TLB
* Add an mmu_uram() function to access user RAM from P1
The exception catching mechanism has been modified to avoid the use of
GMAPPED functions altogether.
* Set SR.BL=0 and SR.IMASK=15 before calling exception catchers
* Move gint_exc_skip() to normal text ROM
* Also fix registers not being popped off the stack before a panic
The timer drivers have also been modified to avoid GMAPPED functions.
* Invoke timer_stop() through gint_inth_callback() and move it to ROM
* Move and expand the ETMU driver to span 3 blocks at 0xd00 (ETMU4)
* Remove the timer_clear() function by inlining it into the ETMU handler
(TCR is provided within the storage block of each timer)
* Also split src/timer/inth.s into src/timer/inth-{tmu,etmu}.s
Additionally, VBR addresses are now determined at runtime to further
reduce hardcoded memory layout addresses in the linker script.
* Determine fx-9860G VBR addresses dynamically from mmu_uram()
* Determine fx-CG 50 VBR addresses dynamically from mmu_uram()
* Remove linker symbols for VBR addresses
Comments and documentation have been updated throughout the code to
reflect the changes.
2020-09-17 14:48:54 +02:00
|
|
|
/* Comments or anything the compiler might generate */
|
2018-04-19 13:24:26 +02:00
|
|
|
*(.comment)
|
|
|
|
}
|
|
|
|
}
|