summaryrefslogtreecommitdiff
path: root/src/stm8
Commit message (Collapse)AuthorAgeFilesLines
* Fixed github sdcc-gas issues #1, #2 and #4Xavi Del Campo2019-11-061-0/+17
| | | | | | | | | | | | | | | | | | | Issue #1 was caused because code_name and data_name had been incorrectly defined as const-qualified pointers, but this must be an exception for the z80 backend, as stated by the comments. Issue #2 has been solved by removing the --gas switch from SDCCmain.c, renaming it to "--asm=" (as requested by PKK) and moved to STM8's main.c, so the option is limited to those targets supporting it. Issue #4 was because of SDCCglue.c, that generated local labels using "!labeldef" instead of "!slabeldef", causing those __str_%d labels to be printed as "__str_%d::" (the double colons stand for globa label according to asxxx documentation) instead of "__str_%d":". I ran the regression tests and most of them passed, but "wchar" returned another "Multiple definition of..." error that I cannot explain so far. It is better than nothing, though.
* _Noreturn-qualified functions now do not generate any ret/iret instructionXavier ASUS2019-10-301-21/+31
|
* BugfixesXavier ASUS2019-10-301-2/+8
|
* Bugfixes on startup routineXavier ASUS2019-10-251-8/+16
| | | | Memory addresses should be preceded by '#' when referring to them as integers
* DWARF2 debugging (almost) workingXavier ASUS2019-10-251-10/+10
| | | | | Stack pointer setup is removed since it is already set to 0x3FF for the STM8S003F3/K3, according to the datasheet.
* Removed intermediate filesXavier ASUS2019-10-241-7/+0
|
* Got hi8/lo8 asm instructions workingXavier ASUS2019-10-241-3/+25
| | | | | | | | | | | | GNU as does not support the #</#> notation asxxx uses to determine address LSB and MSB. Instead, two instructions have been created on GNU as and ld (see my stm8-binutils-gdb fork) for this purpose. On the other hand, I'm upset to see gen.c does not provide an assembler-agnostic implementation when SDCCasm.c already provides tools already meant for this. OTOH, support for the "-C" has been added for --gas.
* Implemented -c support for --gasXavier ASUS2019-10-232-9/+23
| | | | | | | | | | | | STM8 code generator was generating some instructions in a "ld register, (#%d, register)" way, causing assembling errors on stm8-as. This is because stm8-as does not require the '#' character. A quick and dirty workaround has been implemented for this. Added new warning W_IGNORED_OPT_IN_ASM, which warns the user when both "--no-optsdcc-in-asm" and "--gas" are used (the first is ignored when the latter is active since GNU as does not accept the .optsdcc directive, as opposed to asxxx).
* First working example!Xavier ASUS2019-10-222-5/+11
| | | | | | stm8/main.c: 0x8000 must contain the entry point aka "_start" for GNU as. Some work on supporting debugging symbols with --gas. Not finished yet.
* Implemented --ffunction-sectionsXavier ASUS2019-10-212-46/+52
| | | | | | | Interrupt vector must be placed on section .vectors, according to the default linker script file. Intermediate labels must be $-terminated so they are not listed by nm.
* GNU as now assembles successfullyXavier ASUS2019-10-211-34/+57
| | | | | A new (untested) startup routine has been written for GNU as. Section names have been considered from stm8-binutils linker script.
* More work on GNU as generationXavier ASUS2019-10-211-4/+16
| | | | | | | | | | | | | | | | | | On _gas_mapping, label definitions do not allow "::". ":" must be used instead. gasOutput is now part of "options". Unneeded sections, such as HOME/GSINIT/etc., are no longer declared and/or defined. GNU as just does not need them. Startup function name must equal "_start" for GNU ld. The value of some macros, such as CODE_NAME or DATA_NAME, must change according to options.gasOutput, as "CODE" or "DATA" (among many others) are not understood by GNU as. STM8 port now selects GNU as format on --gas switch enabled.
* sdcc-3.9.0 fork implementing GNU assembler syntaxXavier ASUS2019-10-1813-0/+13403
This fork aims to provide better support for stm8-binutils