Skip to content

Commit

Permalink
Allow LOAD FRAGMENT (#1552)
Browse files Browse the repository at this point in the history
This was implemented in #736 but removed after discussion in #869.

Fixes #1537
  • Loading branch information
Rangi42 authored Oct 24, 2024
1 parent 0d3980d commit 5efd303
Show file tree
Hide file tree
Showing 24 changed files with 170 additions and 12 deletions.
8 changes: 4 additions & 4 deletions man/rgbasm.5
Original file line number Diff line number Diff line change
Expand Up @@ -968,11 +968,11 @@ block before performing its own function.
.Ic LOAD
blocks can use the
.Ic UNION
modifier as described in
.Sx Unionized sections
below, but not the
or
.Ic FRAGMENT
modifier.
modifiers as described in
.Sx Unionized sections
below.
.Ss Unionized sections
When you're tight on RAM, you may want to define overlapping static memory allocations, as explained in the
.Sx Allocating overlapping spaces in RAM
Expand Down
5 changes: 0 additions & 5 deletions src/asm/section.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -462,11 +462,6 @@ void sect_SetLoadSection(
return;
}

if (mod == SECTION_FRAGMENT) {
error("`LOAD FRAGMENT` is not allowed\n");
return;
}

if (currentLoadSection)
sect_EndLoadSection("LOAD");

Expand Down
27 changes: 27 additions & 0 deletions test/asm/load-fragment.asm
Original file line number Diff line number Diff line change
@@ -1,2 +1,29 @@
SECTION "A", ROM0
AData::
LOAD FRAGMENT "RAM", WRAM0
AMem::
db 0, 1, 2
AMemEnd::
ENDL
ADataEnd::
dw AMem

SECTION "B", ROM0
BData::
LOAD FRAGMENT "RAM", WRAM0
BMem::
db 3, 4, 5, 6, 7
BMemEnd::
ENDL
BDataEnd::
dw BMem

SECTION "C", ROM0
CData::
LOAD FRAGMENT "RAM", WRAM0
CMem::
db 8, 9
CMemEnd::
ENDL
CDataEnd::
dw CMem
3 changes: 0 additions & 3 deletions test/asm/load-fragment.err

This file was deleted.

Binary file added test/asm/load-fragment.out.bin
Binary file not shown.
12 changes: 12 additions & 0 deletions test/link/load-fragment-jr.asm
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
SECTION "main", ROM0
LOAD FRAGMENT "test", SRAM
ENDL

; The RPN patch for 'jr Label' in section "alt" refers to section "test",
; but the object file puts section "test" after section "alt".
; This case needs to be handled when identifying patches' PC sections.
SECTION "alt", ROM0
LOAD FRAGMENT "test", SRAM
jr Label
Label:
ENDL
Empty file added test/link/load-fragment-jr.out
Empty file.
Binary file added test/link/load-fragment-jr.out.bin
Binary file not shown.
9 changes: 9 additions & 0 deletions test/link/load-fragment/base/a.asm
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
SECTION "Test", ROM0[0]
AA: db 1
LOAD FRAGMENT "RAM section", WRAM0[$c000]
BB: db 2
ENDL
CC: db 3
LOAD FRAGMENT "RAM section", WRAM0
DD: db 4
ENDL
1 change: 1 addition & 0 deletions test/link/load-fragment/base/ref.out.bin
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@

5 changes: 5 additions & 0 deletions test/link/load-fragment/base/ref.out.sym
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
; File generated by rgblink
00:0000 AA
00:0002 CC
00:c000 BB
00:c001 DD
4 changes: 4 additions & 0 deletions test/link/load-fragment/multiple-objects/a.asm
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
SECTION "main", ROM0
LOAD FRAGMENT "test", SRAM
db 0
ENDL
6 changes: 6 additions & 0 deletions test/link/load-fragment/multiple-objects/b.asm
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
SECTION "SECTION2", ROM0
LOAD FRAGMENT "test", SRAM
jr Label
Label:
dw Label
ENDL
Binary file not shown.
8 changes: 8 additions & 0 deletions test/link/load-fragment/section-fragment/a.asm
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
SECTION FRAGMENT "rom", ROM0
Part1::
LOAD FRAGMENT "ram", WRAM0
wPart1::
jr wPart1
jr wPart3
ENDL
Part1End::
4 changes: 4 additions & 0 deletions test/link/load-fragment/section-fragment/b.asm
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
SECTION FRAGMENT "rom", ROM0
Part2::
db "Hello world!"
Part2End::
8 changes: 8 additions & 0 deletions test/link/load-fragment/section-fragment/c.asm
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
SECTION FRAGMENT "rom", ROM0
Part3::
LOAD FRAGMENT "ram", WRAM0
wPart3::
jr wPart1
jr wPart3
ENDL
Part3End::
Binary file not shown.
24 changes: 24 additions & 0 deletions test/link/load-fragment/section-fragment/ref.out.map
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
SUMMARY:
ROM0: 20 bytes used / 16364 free
WRAM0: 8 bytes used / 4088 free

ROM0 bank #0:
SECTION: $0000-$0013 ($0014 bytes) ["rom"]
$0000 = Part1
$0004 = Part1End
; Next fragment
$0010 = Part3
$0014 = Part3End
; Next fragment
$0004 = Part2
$0010 = Part2End
EMPTY: $0014-$3fff ($3fec bytes)
TOTAL EMPTY: $3fec bytes

WRAM0 bank #0:
SECTION: $c000-$c007 ($0008 bytes) ["ram"]
$c000 = wPart1
; Next fragment
$c004 = wPart3
EMPTY: $c008-$cfff ($0ff8 bytes)
TOTAL EMPTY: $0ff8 bytes
9 changes: 9 additions & 0 deletions test/link/load-fragment/section-fragment/ref.out.sym
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
; File generated by rgblink
00:0000 Part1
00:0004 Part1End
00:0004 Part2
00:0010 Part3
00:0010 Part2End
00:0014 Part3End
00:c000 wPart1
00:c004 wPart3
4 changes: 4 additions & 0 deletions test/link/section-fragment/jr-offset-load/a.asm
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
SECTION FRAGMENT "output", ROM0
LOAD FRAGMENT "loaded", SRAM
ds 128
ENDL
6 changes: 6 additions & 0 deletions test/link/section-fragment/jr-offset-load/b.asm
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
SECTION FRAGMENT "output", ROM0
LOAD FRAGMENT "loaded", SRAM
label:
jr nz, label2
label2:
ENDL
Binary file not shown.
39 changes: 39 additions & 0 deletions test/link/test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -172,6 +172,36 @@ rgblinkQuiet -o "$gbtemp2" "$outtemp"
tryCmp "$gbtemp" "$gbtemp2"
evaluateTest

test="load-fragment/base"
startTest
"$RGBASM" -o "$otemp" "$test"/a.asm
continueTest
rgblinkQuiet -o "$gbtemp" -n "$outtemp" "$otemp"
tryCmpRom "$test"/ref.out.bin
tryDiff "$test"/ref.out.sym "$outtemp"
evaluateTest

test="load-fragment/multiple-objects"
startTest
"$RGBASM" -o "$otemp" "$test"/a.asm
"$RGBASM" -o "$gbtemp2" "$test"/b.asm
continueTest
rgblinkQuiet -o "$gbtemp" "$otemp" "$gbtemp2"
tryCmpRom "$test"/ref.out.bin
evaluateTest

test="load-fragment/section-fragment"
startTest
"$RGBASM" -o "$otemp" "$test"/a.asm
"$RGBASM" -o "$outtemp" "$test"/b.asm
"$RGBASM" -o "$outtemp2" "$test"/c.asm
continueTest
rgblinkQuiet -o "$gbtemp" -m "$outtemp3" -n "$gbtemp2" "$otemp" "$outtemp" "$outtemp2"
tryCmpRom "$test"/ref.out.bin
tryDiff "$test"/ref.out.map "$outtemp3"
tryDiff "$test"/ref.out.sym "$gbtemp2"
evaluateTest

test="map-file"
startTest
"$RGBASM" -o "$otemp" "$test"/a.asm
Expand Down Expand Up @@ -257,6 +287,15 @@ rgblinkQuiet -o "$gbtemp" "$otemp" "$gbtemp2"
tryCmpRom "$test"/ref.out.bin
evaluateTest

test="section-fragment/jr-offset-load"
startTest
"$RGBASM" -o "$otemp" "$test"/a.asm
"$RGBASM" -o "$gbtemp2" "$test"/b.asm
continueTest
rgblinkQuiet -o "$gbtemp" "$otemp" "$gbtemp2"
tryCmpRom "$test"/ref.out.bin
evaluateTest

test="section-normal/same-name"
startTest
"$RGBASM" -o "$otemp" "$test"/a.asm
Expand Down

0 comments on commit 5efd303

Please # to comment.