add dict impl to libalee section

master
Clyne 11 months ago
parent ebbde43fa9
commit 9ac70bfc0e
Signed by: clyne
GPG Key ID: 3267C8EBF3F9AFC7

@ -35,6 +35,7 @@ class SplitMemDict : public Dictionary
uint8_t rwdict[MemDictSize - Dictionary::Begin] = {0}; uint8_t rwdict[MemDictSize - Dictionary::Begin] = {0};
uint8_t extra[Dictionary::Begin]; uint8_t extra[Dictionary::Begin];
LIBALEE_SECTION
Addr convertAddress(Addr addr) const noexcept { Addr convertAddress(Addr addr) const noexcept {
return addr < RON ? addr : static_cast<Addr>(addr - RON); return addr < RON ? addr : static_cast<Addr>(addr - RON);
} }
@ -53,6 +54,7 @@ public:
return *this; return *this;
} }
LIBALEE_SECTION
virtual Cell read(Addr addr) const noexcept final { virtual Cell read(Addr addr) const noexcept final {
const uint8_t *dict; const uint8_t *dict;
if (addr < RON) if (addr < RON)
@ -63,6 +65,7 @@ public:
return *reinterpret_cast<const Cell *>(dict + convertAddress(addr)); return *reinterpret_cast<const Cell *>(dict + convertAddress(addr));
} }
LIBALEE_SECTION
virtual void write(Addr addr, Cell value) noexcept final { virtual void write(Addr addr, Cell value) noexcept final {
if (addr >= RON) if (addr >= RON)
*reinterpret_cast<Cell *>(rwdict + addr - RON) = value; *reinterpret_cast<Cell *>(rwdict + addr - RON) = value;
@ -70,6 +73,7 @@ public:
*reinterpret_cast<Cell *>(extra + addr) = value; *reinterpret_cast<Cell *>(extra + addr) = value;
} }
LIBALEE_SECTION
virtual uint8_t readbyte(Addr addr) const noexcept final { virtual uint8_t readbyte(Addr addr) const noexcept final {
const uint8_t *dict; const uint8_t *dict;
if (addr < RON) if (addr < RON)
@ -80,6 +84,7 @@ public:
return dict[convertAddress(addr)]; return dict[convertAddress(addr)];
} }
LIBALEE_SECTION
virtual void writebyte(Addr addr, uint8_t value) noexcept final { virtual void writebyte(Addr addr, uint8_t value) noexcept final {
if (addr >= RON) if (addr >= RON)
rwdict[addr - RON] = value; rwdict[addr - RON] = value;
@ -87,6 +92,7 @@ public:
extra[addr] = value; extra[addr] = value;
} }
LIBALEE_SECTION
virtual unsigned long int capacity() const noexcept final { virtual unsigned long int capacity() const noexcept final {
return RON + sizeof(extra) + sizeof(rwdict); return RON + sizeof(extra) + sizeof(rwdict);
} }

Loading…
Cancel
Save