add LIBALEE_SECTION; minor fixes

master
Clyne
parent 5162349f92
commit af51fb5bdf
Signed by: clyne
GPG Key ID: 3267C8EBF3F9AFC7

@ -15,6 +15,7 @@ msp430: AR := msp430-elf-gcc-ar
msp430: CXXFLAGS += -I. -I/usr/msp430-elf/usr/include msp430: CXXFLAGS += -I. -I/usr/msp430-elf/usr/include
msp430: CXXFLAGS += -Os -mmcu=msp430fr2476 -ffunction-sections -fdata-sections msp430: CXXFLAGS += -Os -mmcu=msp430fr2476 -ffunction-sections -fdata-sections
msp430: CXXFLAGS += -flto -fno-asynchronous-unwind-tables -fno-threadsafe-statics -fno-stack-protector msp430: CXXFLAGS += -flto -fno-asynchronous-unwind-tables -fno-threadsafe-statics -fno-stack-protector
msp430: CXXFLAGS += -DALEE_MSP430_HOST
msp430: LDFLAGS += -L msp430 -T msp430fr2476.ld -Wl,-gc-sections -Wl,--no-warn-rwx-segments msp430: LDFLAGS += -L msp430 -T msp430fr2476.ld -Wl,-gc-sections -Wl,--no-warn-rwx-segments
msp430: msp430/alee-msp430 msp430: msp430/alee-msp430

@ -16,7 +16,7 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>. * along with this program. If not, see <https://www.gnu.org/licenses/>.
*/ */
#include "alee.hpp" #include "libalee/alee.hpp"
#include "splitmemdict.hpp" #include "splitmemdict.hpp"
#include <array> #include <array>

@ -16,7 +16,7 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>. * along with this program. If not, see <https://www.gnu.org/licenses/>.
*/ */
#include "alee.hpp" #include "libalee/alee.hpp"
#include "memdict.hpp" #include "memdict.hpp"
#include <charconv> #include <charconv>

@ -1,3 +0,0 @@
#include "libalee/parser.hpp"
#include "libalee/state.hpp"

@ -0,0 +1,7 @@
#include "config.hpp"
#include "corewords.hpp"
#include "ctype.hpp"
#include "dictionary.hpp"
#include "parser.hpp"
#include "state.hpp"
#include "types.hpp"

@ -0,0 +1,5 @@
#ifndef ALEE_MSP430_HOST
#define LIBALEE_SECTION
#else
#define LIBALEE_SECTION __attribute__((section(".libalee")))
#endif

@ -16,11 +16,11 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>. * along with this program. If not, see <https://www.gnu.org/licenses/>.
*/ */
#include "corewords.hpp" #include "alee.hpp"
#include "parser.hpp"
#include <utility> #include <utility>
LIBALEE_SECTION
void find(State& state, Word word) void find(State& state, Word word)
{ {
Cell tok = 0; Cell tok = 0;
@ -37,6 +37,7 @@ void find(State& state, Word word)
state.push(imm); state.push(imm);
} }
LIBALEE_SECTION
void CoreWords::run(Cell ins, State& state) void CoreWords::run(Cell ins, State& state)
{ {
Cell cell; Cell cell;
@ -252,6 +253,7 @@ execute:
ip += sizeof(Cell); ip += sizeof(Cell);
} }
LIBALEE_SECTION
Cell CoreWords::findi(State& state, Word word) Cell CoreWords::findi(State& state, Word word)
{ {
return findi(word.begin(&state.dict), word.size()); return findi(word.begin(&state.dict), word.size());

@ -19,9 +19,9 @@
#ifndef ALEEFORTH_COREWORDS_HPP #ifndef ALEEFORTH_COREWORDS_HPP
#define ALEEFORTH_COREWORDS_HPP #define ALEEFORTH_COREWORDS_HPP
#include "ctype.hpp" #include "config.hpp"
#include "types.hpp" #include "types.hpp"
#include "state.hpp" #include "dictionary.hpp"
/** /**
* To be implemented by the user, this function is called when the `sys` word * To be implemented by the user, this function is called when the `sys` word
@ -61,6 +61,7 @@ public:
private: private:
template<typename Iter> template<typename Iter>
LIBALEE_SECTION
constexpr static Cell findi(Iter it, std::size_t size) constexpr static Cell findi(Iter it, std::size_t size)
{ {
const char *ptr = CoreWords::wordsarr; const char *ptr = CoreWords::wordsarr;

@ -43,6 +43,10 @@ constexpr inline bool isupper(uint8_t c) {
return c >= 'A' && c <= 'Z'; return c >= 'A' && c <= 'Z';
} }
constexpr inline bool islower(uint8_t c) {
return c >= 'a' && c <= 'z';
}
constexpr inline bool isalpha(uint8_t c) { constexpr inline bool isalpha(uint8_t c) {
return isupper(c) || (c >= 'a' && c <= 'z'); return isupper(c) || (c >= 'a' && c <= 'z');
} }

@ -16,8 +16,9 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>. * along with this program. If not, see <https://www.gnu.org/licenses/>.
*/ */
#include "dictionary.hpp" #include "alee.hpp"
LIBALEE_SECTION
void Dictionary::initialize() void Dictionary::initialize()
{ {
write(Base, 10); write(Base, 10);
@ -27,6 +28,7 @@ void Dictionary::initialize()
write(Source, Input + sizeof(Cell)); write(Source, Input + sizeof(Cell));
} }
LIBALEE_SECTION
Addr Dictionary::allot(Cell amount) noexcept Addr Dictionary::allot(Cell amount) noexcept
{ {
Addr old = here(); Addr old = here();
@ -41,22 +43,26 @@ Addr Dictionary::allot(Cell amount) noexcept
return old; return old;
} }
LIBALEE_SECTION
void Dictionary::add(Cell value) noexcept void Dictionary::add(Cell value) noexcept
{ {
write(allot(sizeof(Cell)), value); write(allot(sizeof(Cell)), value);
} }
LIBALEE_SECTION
Addr Dictionary::aligned(Addr addr) Addr Dictionary::aligned(Addr addr)
{ {
return (addr + (sizeof(Cell) - 1)) & ~(sizeof(Cell) - 1); return (addr + (sizeof(Cell) - 1)) & ~(sizeof(Cell) - 1);
} }
LIBALEE_SECTION
Addr Dictionary::alignhere() noexcept Addr Dictionary::alignhere() noexcept
{ {
here(aligned(here())); here(aligned(here()));
return here(); return here();
} }
LIBALEE_SECTION
void Dictionary::addDefinition(Word word) noexcept void Dictionary::addDefinition(Word word) noexcept
{ {
Cell wsize = word.size(); Cell wsize = word.size();
@ -75,6 +81,7 @@ void Dictionary::addDefinition(Word word) noexcept
alignhere(); alignhere();
} }
LIBALEE_SECTION
Addr Dictionary::find(Word word) noexcept Addr Dictionary::find(Word word) noexcept
{ {
Addr lt = latest(); Addr lt = latest();
@ -106,6 +113,7 @@ Addr Dictionary::find(Word word) noexcept
return 0; return 0;
} }
LIBALEE_SECTION
Addr Dictionary::getexec(Addr addr) noexcept Addr Dictionary::getexec(Addr addr) noexcept
{ {
const Addr l = read(addr); const Addr l = read(addr);
@ -119,6 +127,7 @@ Addr Dictionary::getexec(Addr addr) noexcept
return aligned(addr); return aligned(addr);
} }
LIBALEE_SECTION
bool Dictionary::hasInput() const noexcept bool Dictionary::hasInput() const noexcept
{ {
const Addr src = read(Dictionary::Source); const Addr src = read(Dictionary::Source);
@ -140,6 +149,7 @@ bool Dictionary::hasInput() const noexcept
return false; return false;
} }
LIBALEE_SECTION
Word Dictionary::input() noexcept Word Dictionary::input() noexcept
{ {
const Addr src = read(Dictionary::Source); const Addr src = read(Dictionary::Source);
@ -169,11 +179,13 @@ Word Dictionary::input() noexcept
return Word(wstart, wend); return Word(wstart, wend);
} }
LIBALEE_SECTION
bool Dictionary::equal(Word word, const char *str, unsigned len) const noexcept bool Dictionary::equal(Word word, const char *str, unsigned len) const noexcept
{ {
return word.size() == len && equal(word.begin(this), word.end(this), str); return word.size() == len && equal(word.begin(this), word.end(this), str);
} }
LIBALEE_SECTION
bool Dictionary::equal(Word word, Word other) const noexcept bool Dictionary::equal(Word word, Word other) const noexcept
{ {
return word.size() == other.size() && equal(word.begin(this), word.end(this), other.begin(this)); return word.size() == other.size() && equal(word.begin(this), word.end(this), other.begin(this));

@ -19,8 +19,9 @@
#ifndef ALEEFORTH_DICTIONARY_HPP #ifndef ALEEFORTH_DICTIONARY_HPP
#define ALEEFORTH_DICTIONARY_HPP #define ALEEFORTH_DICTIONARY_HPP
#include "ctype.hpp" #include "config.hpp"
#include "types.hpp" #include "types.hpp"
#include "ctype.hpp"
#include <algorithm> #include <algorithm>
#include <cstddef> #include <cstddef>
@ -72,10 +73,14 @@ struct Dictionary
*/ */
void initialize(); void initialize();
LIBALEE_SECTION
Addr here() const noexcept { return read(Here); } Addr here() const noexcept { return read(Here); }
LIBALEE_SECTION
void here(Addr l) noexcept { write(Here, l); } void here(Addr l) noexcept { write(Here, l); }
LIBALEE_SECTION
Addr latest() const noexcept { return read(Latest); } Addr latest() const noexcept { return read(Latest); }
LIBALEE_SECTION
void latest(Addr l) noexcept { write(Latest, l); } void latest(Addr l) noexcept { write(Latest, l); }
// Aligns the given address. // Aligns the given address.
@ -124,6 +129,7 @@ struct Dictionary
// Used for case-insensitive comparison between two iterators. // Used for case-insensitive comparison between two iterators.
template<typename Iter1, typename Iter2> template<typename Iter1, typename Iter2>
LIBALEE_SECTION
constexpr static bool equal(Iter1 b1, Iter1 e1, Iter2 b2) { constexpr static bool equal(Iter1 b1, Iter1 e1, Iter2 b2) {
return std::equal(b1, e1, b2, eqchars); return std::equal(b1, e1, b2, eqchars);
} }
@ -132,6 +138,7 @@ struct Dictionary
private: private:
// Case-insensitive comparison. // Case-insensitive comparison.
LIBALEE_SECTION
constexpr static bool eqchars(char c1, char c2) { constexpr static bool eqchars(char c1, char c2) {
if (isalpha(static_cast<uint8_t>(c1))) if (isalpha(static_cast<uint8_t>(c1)))
c1 |= 32; c1 |= 32;
@ -140,7 +147,6 @@ private:
return c1 == c2; return c1 == c2;
} }
}; };
#endif // ALEEFORTH_DICTIONARY_HPP #endif // ALEEFORTH_DICTIONARY_HPP

@ -16,12 +16,11 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>. * along with this program. If not, see <https://www.gnu.org/licenses/>.
*/ */
#include "corewords.hpp" #include "alee.hpp"
#include "ctype.hpp"
#include "parser.hpp"
Error (*Parser::customParse)(State&, Word) = nullptr; Error (*Parser::customParse)(State&, Word) = nullptr;
LIBALEE_SECTION
Error Parser::parse(State& state, const char *str) Error Parser::parse(State& state, const char *str)
{ {
auto addr = Dictionary::Input; auto addr = Dictionary::Input;
@ -40,6 +39,7 @@ Error Parser::parse(State& state, const char *str)
return parseSource(state); return parseSource(state);
} }
LIBALEE_SECTION
Error Parser::parseSource(State& state) Error Parser::parseSource(State& state)
{ {
auto err = Error::none; auto err = Error::none;
@ -50,6 +50,7 @@ Error Parser::parseSource(State& state)
return err; return err;
} }
LIBALEE_SECTION
Error Parser::parseWord(State& state, Word word) Error Parser::parseWord(State& state, Word word)
{ {
bool imm; bool imm;
@ -81,6 +82,7 @@ Error Parser::parseWord(State& state, Word word)
return Error::none; return Error::none;
} }
LIBALEE_SECTION
Error Parser::parseNumber(State& state, Word word) Error Parser::parseNumber(State& state, Word word)
{ {
const auto base = state.dict.read(Dictionary::Base); const auto base = state.dict.read(Dictionary::Base);
@ -113,6 +115,7 @@ Error Parser::parseNumber(State& state, Word word)
return Error::none; return Error::none;
} }
LIBALEE_SECTION
void Parser::processLiteral(State& state, Cell value) void Parser::processLiteral(State& state, Cell value)
{ {
if (state.compiling()) { if (state.compiling()) {

@ -19,7 +19,9 @@
#ifndef ALEEFORTH_PARSER_HPP #ifndef ALEEFORTH_PARSER_HPP
#define ALEEFORTH_PARSER_HPP #define ALEEFORTH_PARSER_HPP
#include "config.hpp"
#include "types.hpp" #include "types.hpp"
#include "state.hpp"
#include <string_view> #include <string_view>

@ -16,31 +16,35 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>. * along with this program. If not, see <https://www.gnu.org/licenses/>.
*/ */
#include "corewords.hpp" #include "alee.hpp"
#include "state.hpp"
#include <iterator> #include <iterator>
LIBALEE_SECTION
bool State::compiling() const bool State::compiling() const
{ {
return dict.read(Dictionary::Compiling); return dict.read(Dictionary::Compiling);
} }
LIBALEE_SECTION
void State::compiling(bool yes) void State::compiling(bool yes)
{ {
dict.write(Dictionary::Compiling, yes); dict.write(Dictionary::Compiling, yes);
} }
LIBALEE_SECTION
State::Context State::save() State::Context State::save()
{ {
return context; return context;
} }
LIBALEE_SECTION
void State::load(const State::Context& ctx) void State::load(const State::Context& ctx)
{ {
context = ctx; context = ctx;
} }
LIBALEE_SECTION
Error State::execute(Addr addr) Error State::execute(Addr addr)
{ {
auto stat = static_cast<Error>(setjmp(context.jmpbuf)); auto stat = static_cast<Error>(setjmp(context.jmpbuf));
@ -63,6 +67,7 @@ Error State::execute(Addr addr)
return stat; return stat;
} }
LIBALEE_SECTION
void State::reset() void State::reset()
{ {
while (size()) while (size())
@ -74,11 +79,13 @@ void State::reset()
context.ip = 0; context.ip = 0;
} }
LIBALEE_SECTION
std::size_t State::size() const noexcept std::size_t State::size() const noexcept
{ {
return dsp - dstack; return dsp - dstack;
} }
LIBALEE_SECTION
std::size_t State::rsize() const noexcept std::size_t State::rsize() const noexcept
{ {
return rsp - rstack; return rsp - rstack;

@ -19,6 +19,7 @@
#ifndef ALEEFORTH_STATE_HPP #ifndef ALEEFORTH_STATE_HPP
#define ALEEFORTH_STATE_HPP #define ALEEFORTH_STATE_HPP
#include "config.hpp"
#include "dictionary.hpp" #include "dictionary.hpp"
#include "types.hpp" #include "types.hpp"
@ -57,10 +58,12 @@ public:
*/ */
void reset(); void reset();
LIBALEE_SECTION
Addr& ip() noexcept { Addr& ip() noexcept {
return context.ip; return context.ip;
} }
LIBALEE_SECTION
void input() noexcept { void input() noexcept {
inputfunc(*this); inputfunc(*this);
} }
@ -82,42 +85,50 @@ public:
*/ */
void load(const Context&); void load(const Context&);
LIBALEE_SECTION
inline void push(Cell value) { inline void push(Cell value) {
verify(dsp < dstack + DataStackSize, Error::push); verify(dsp < dstack + DataStackSize, Error::push);
*dsp++ = value; *dsp++ = value;
} }
LIBALEE_SECTION
inline Cell pop() { inline Cell pop() {
verify(dsp > dstack, Error::pop); verify(dsp > dstack, Error::pop);
return *--dsp; return *--dsp;
} }
LIBALEE_SECTION
inline void pushr(Cell value) { inline void pushr(Cell value) {
verify(rsp < rstack + ReturnStackSize, Error::pushr); verify(rsp < rstack + ReturnStackSize, Error::pushr);
*rsp++ = value; *rsp++ = value;
} }
LIBALEE_SECTION
inline Cell popr() { inline Cell popr() {
verify(rsp > rstack, Error::popr); verify(rsp > rstack, Error::popr);
return *--rsp; return *--rsp;
} }
LIBALEE_SECTION
inline Cell& top() { inline Cell& top() {
verify(dsp > dstack, Error::top); verify(dsp > dstack, Error::top);
return *(dsp - 1); return *(dsp - 1);
} }
LIBALEE_SECTION
inline Cell& pick(std::size_t i) { inline Cell& pick(std::size_t i) {
verify(dsp - i > dstack, Error::pick); verify(dsp - i > dstack, Error::pick);
return *(dsp - i - 1); return *(dsp - i - 1);
} }
// Advances the instruction pointer and returns that cell's contents. // Advances the instruction pointer and returns that cell's contents.
LIBALEE_SECTION
inline Cell beyondip() { inline Cell beyondip() {
context.ip += sizeof(Cell); context.ip += sizeof(Cell);
return dict.read(context.ip); return dict.read(context.ip);
} }
LIBALEE_SECTION
inline void verify(bool condition, Error error) { inline void verify(bool condition, Error error) {
if (!condition) if (!condition)
std::longjmp(context.jmpbuf, static_cast<int>(error)); std::longjmp(context.jmpbuf, static_cast<int>(error));

@ -16,30 +16,34 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>. * along with this program. If not, see <https://www.gnu.org/licenses/>.
*/ */
#include "dictionary.hpp" #include "alee.hpp"
#include "types.hpp"
LIBALEE_SECTION
Addr Word::size() const noexcept Addr Word::size() const noexcept
{ {
return wend - start; return wend - start;
} }
LIBALEE_SECTION
Word::iterator Word::begin(const Dictionary *dict) Word::iterator Word::begin(const Dictionary *dict)
{ {
return iterator(start, dict); return iterator(start, dict);
} }
LIBALEE_SECTION
Word::iterator Word::end(const Dictionary *dict) Word::iterator Word::end(const Dictionary *dict)
{ {
return iterator(wend, dict); return iterator(wend, dict);
} }
LIBALEE_SECTION
Word::iterator& Word::iterator::operator++() Word::iterator& Word::iterator::operator++()
{ {
addr++; addr++;
return *this; return *this;
} }
LIBALEE_SECTION
Word::iterator Word::iterator::operator++(int) Word::iterator Word::iterator::operator++(int)
{ {
const auto copy = *this; const auto copy = *this;
@ -47,12 +51,15 @@ Word::iterator Word::iterator::operator++(int)
return copy; return copy;
} }
LIBALEE_SECTION
Word::iterator::value_type Word::iterator::operator*() Word::iterator::value_type Word::iterator::operator*()
{ {
return dict->readbyte(addr); return dict->readbyte(addr);
} }
LIBALEE_SECTION
bool Word::iterator::operator!=(const iterator& other) bool Word::iterator::operator!=(const iterator& other)
{ {
return dict != other.dict || addr != other.addr; return dict != other.dict || addr != other.addr;
} }

@ -61,6 +61,7 @@ public:
constexpr explicit Word(Addr s = 0, Addr e = 0): constexpr explicit Word(Addr s = 0, Addr e = 0):
start(s), wend(e) {} start(s), wend(e) {}
LIBALEE_SECTION
static constexpr Word fromLength(Addr s, Addr l) { static constexpr Word fromLength(Addr s, Addr l) {
return Word(s, s + l); return Word(s, s + l);
} }

@ -19,7 +19,7 @@
#ifndef ALEEFORTH_MEMDICT_HPP #ifndef ALEEFORTH_MEMDICT_HPP
#define ALEEFORTH_MEMDICT_HPP #define ALEEFORTH_MEMDICT_HPP
#include "alee.hpp" #include "libalee/alee.hpp"
#ifndef MEMDICTSIZE #ifndef MEMDICTSIZE
#define MEMDICTSIZE (65536) #define MEMDICTSIZE (65536)

@ -16,8 +16,7 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>. * along with this program. If not, see <https://www.gnu.org/licenses/>.
*/ */
#include "alee.hpp" #include "libalee/alee.hpp"
#include "libalee/ctype.hpp"
#include "lzss.h" #include "lzss.h"
static const static const
#include "msp430fr2476_all.h" #include "msp430fr2476_all.h"
@ -41,7 +40,9 @@ static void initUART();
static void Software_Trim(); static void Software_Trim();
#define MCLK_FREQ_MHZ (16) #define MCLK_FREQ_MHZ (16)
#define ALEE_RODICTSIZE (9400) static void alee_main();
#define ALEE_RODICTSIZE (9088)
__attribute__((section(".lodict"))) __attribute__((section(".lodict")))
#include "core.fth.h" #include "core.fth.h"
@ -55,11 +56,23 @@ static auto& dict = *(new (__dict) DictType (alee_dat, 0x10000));
int main() int main()
{ {
WDTCTL = WDTPW | WDTHOLD; WDTCTL = WDTPW | WDTHOLD;
extern char __libaleebegin;
extern char __libaleeend;
extern char __libaleedst;
std::copy(&__libaleebegin, &__libaleeend, &__libaleedst);
initGPIO(); initGPIO();
initClock(); initClock();
initUART(); initUART();
SYSCFG0 = FRWPPW; SYSCFG0 = FRWPPW;
alee_main();
}
LIBALEE_SECTION
void alee_main()
{
(void)alee_dat_len; (void)alee_dat_len;
State state (dict, readchar); State state (dict, readchar);
Parser::customParse = findword; Parser::customParse = findword;
@ -105,6 +118,7 @@ int main()
} }
} }
LIBALEE_SECTION
void readchar(State& state) void readchar(State& state)
{ {
auto idx = state.dict.read(Dictionary::Input); auto idx = state.dict.read(Dictionary::Input);
@ -117,18 +131,21 @@ void readchar(State& state)
state.dict.writebyte(addr, c ? c : ' '); state.dict.writebyte(addr, c ? c : ' ');
} }
LIBALEE_SECTION
void serput(int c) void serput(int c)
{ {
while (!(UCA0IFG & UCTXIFG)); while (!(UCA0IFG & UCTXIFG));
UCA0TXBUF = static_cast<char>(c); UCA0TXBUF = static_cast<char>(c);
} }
LIBALEE_SECTION
void serputs(const char *s) void serputs(const char *s)
{ {
while (*s) while (*s)
serput(*s++); serput(*s++);
} }
LIBALEE_SECTION
void printint(DoubleCell n, char *buf, int base) void printint(DoubleCell n, char *buf, int base)
{ {
static const char digit[] = "0123456789ABCDEF"; static const char digit[] = "0123456789ABCDEF";
@ -152,6 +169,7 @@ void printint(DoubleCell n, char *buf, int base)
serput(' '); serput(' ');
} }
LIBALEE_SECTION
void user_sys(State& state) void user_sys(State& state)
{ {
switch (state.pop()) { switch (state.pop()) {
@ -191,6 +209,11 @@ void user_sys(State& state)
case 17: case 17:
exitLpm |= true; exitLpm |= true;
break; break;
case 50:
Parser::customParse = nullptr;
extern char _etext;
state.push((Addr)&_etext);
break;
default: default:
break; break;
} }
@ -208,7 +231,7 @@ Error findword(State& state, Word word)
uint8_t *ptr = lzword; uint8_t *ptr = lzword;
for (auto it = word.begin(&state.dict); it != word.end(&state.dict); ++it) { for (auto it = word.begin(&state.dict); it != word.end(&state.dict); ++it) {
*ptr = *it; *ptr = *it;
if (!isupper(*ptr)) if (islower(*ptr))
*ptr -= 32; *ptr -= 32;
++ptr; ++ptr;
} }

@ -44,7 +44,7 @@ MEMORY {
BOOTCODE : ORIGIN = 0x1C00, LENGTH = 0x0400 /* END=0x1FFF, size 1024 */ BOOTCODE : ORIGIN = 0x1C00, LENGTH = 0x0400 /* END=0x1FFF, size 1024 */
ROMLIB : ORIGIN = 0xC0000, LENGTH = 0x4000 /* END=0xC3FFF, size 16384 */ ROMLIB : ORIGIN = 0xC0000, LENGTH = 0x4000 /* END=0xC3FFF, size 16384 */
BSL1 : ORIGIN = 0xFFC00, LENGTH = 0x0400 /* END=0xFFFFF, size 1024 */ BSL1 : ORIGIN = 0xFFC00, LENGTH = 0x0400 /* END=0xFFFFF, size 1024 */
RAM : ORIGIN = 0x2000, LENGTH = 0x2000 /* END=0x3FFF, size 8192 */ RAM (rwx) : ORIGIN = 0x2000, LENGTH = 0x2000 /* END=0x3FFF, size 8192 */
INFOMEM : ORIGIN = 0x1800, LENGTH = 0x0200 /* END=0x19FF, size 512 */ INFOMEM : ORIGIN = 0x1800, LENGTH = 0x0200 /* END=0x19FF, size 512 */
FRAM (rwx) : ORIGIN = 0x8000, LENGTH = 0x7F80 /* END=0xFF7F, size 32640 */ FRAM (rwx) : ORIGIN = 0x8000, LENGTH = 0x7F80 /* END=0xFF7F, size 32640 */
HIFRAM (rxw) : ORIGIN = 0x10000, LENGTH = 0x00007FFF HIFRAM (rxw) : ORIGIN = 0x10000, LENGTH = 0x00007FFF
@ -218,6 +218,14 @@ SECTIONS
PROVIDE (__dict = .); PROVIDE (__dict = .);
} > TINYRAM } > TINYRAM
.libalee : {
. = ALIGN(2);
PROVIDE (__libaleedst = .);
*(.libalee)
} > RAM AT> FRAM
PROVIDE(__libaleebegin = LOADADDR(.libalee));
PROVIDE (__libaleeend = LOADADDR(.libalee) + SIZEOF(.libalee));
.data : .data :
{ {
. = ALIGN(2); . = ALIGN(2);
@ -295,11 +303,14 @@ SECTIONS
KEEP (*(.init)) KEEP (*(.init))
KEEP (*(.fini)) KEEP (*(.fini))
KEEP (*(.tm_clone_table)) KEEP (*(.tm_clone_table))
. = ALIGN(2);
PROVIDE (_etext = .);
} > FRAM } > FRAM
.lodict : .lodict :
{ {
. = ALIGN(2); . = ALIGN(1024);
*(.lodict) *(.lodict)
} > FRAM } > FRAM

@ -19,7 +19,7 @@
#ifndef ALEEFORTH_SPLITMEMDICT_HPP #ifndef ALEEFORTH_SPLITMEMDICT_HPP
#define ALEEFORTH_SPLITMEMDICT_HPP #define ALEEFORTH_SPLITMEMDICT_HPP
#include "alee.hpp" #include "libalee/alee.hpp"
#include <algorithm> #include <algorithm>

@ -19,7 +19,7 @@
#ifndef ALEEFORTH_SPLITMEMDICTRW_HPP #ifndef ALEEFORTH_SPLITMEMDICTRW_HPP
#define ALEEFORTH_SPLITMEMDICTRW_HPP #define ALEEFORTH_SPLITMEMDICTRW_HPP
#include "alee.hpp" #include "libalee/alee.hpp"
#include <algorithm> #include <algorithm>

Loading…
Cancel
Save