2022-05-10 18:20:02 +00:00
|
|
|
#include <cstdint>
|
|
|
|
|
|
|
|
#include "gpio.h"
|
|
|
|
#include "uart.h"
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
uint8_t UartRead() {
|
|
|
|
uint8_t c;
|
2022-05-17 03:57:51 +00:00
|
|
|
while (XUartLite_Recv(uart0, &c, 1) < 1) {
|
|
|
|
}
|
2022-05-10 18:20:02 +00:00
|
|
|
return c;
|
|
|
|
}
|
|
|
|
|
2022-05-17 03:57:51 +00:00
|
|
|
void UartWrite(uint8_t c) { XUartLite_Send(uart0, &c, 1); }
|
2022-05-10 18:20:02 +00:00
|
|
|
|
|
|
|
uint32_t UartRead32() {
|
|
|
|
uint32_t val = 0;
|
|
|
|
|
|
|
|
// little endian
|
2022-05-17 03:57:51 +00:00
|
|
|
val |= (UartRead() << 0);
|
|
|
|
val |= (UartRead() << 8);
|
2022-05-10 18:20:02 +00:00
|
|
|
val |= (UartRead() << 16);
|
|
|
|
val |= (UartRead() << 24);
|
|
|
|
|
|
|
|
return val;
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
gpio0->data = 1;
|
|
|
|
|
|
|
|
InitUarts();
|
|
|
|
|
2022-05-17 03:57:51 +00:00
|
|
|
while (1) {
|
2022-05-10 18:20:02 +00:00
|
|
|
uint8_t c = UartRead();
|
|
|
|
if (c == 'c') {
|
|
|
|
uint32_t addr = UartRead32();
|
|
|
|
uint32_t bytes = UartRead32();
|
|
|
|
|
|
|
|
uint8_t* start = reinterpret_cast<uint8_t*>(addr);
|
|
|
|
uint8_t* end = reinterpret_cast<uint8_t*>(addr + bytes);
|
|
|
|
for (uint8_t* ptr = start; ptr < end; ptr++) {
|
|
|
|
*ptr = UartRead();
|
|
|
|
}
|
|
|
|
|
|
|
|
UartWrite('a');
|
|
|
|
UartWrite(bytes);
|
|
|
|
gpio0->data = 0xf0;
|
|
|
|
} else if (c == 'j') {
|
|
|
|
uint32_t addr = UartRead32();
|
|
|
|
|
|
|
|
gpio0->data = 0x55;
|
|
|
|
|
|
|
|
addr |= 0x0001;
|
|
|
|
|
2022-05-17 03:57:51 +00:00
|
|
|
auto jump = reinterpret_cast<void (*)()>(addr);
|
2022-05-10 18:20:02 +00:00
|
|
|
jump();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|