diff options
author | Uros Majstorovic <majstor@majstor.org> | 2020-08-05 06:43:12 +0200 |
---|---|---|
committer | Uros Majstorovic <majstor@majstor.org> | 2020-08-05 06:43:12 +0200 |
commit | c7d1773e73f8c8195c30fdf0e5143f61a123338e (patch) | |
tree | 891a00b949886b19d8a9762910fdc4f32b6da4ab /fw/fe310 | |
parent | cf7c06297d04bade9cd04c056f9ed510e64dd7bd (diff) |
added test prg
Diffstat (limited to 'fw/fe310')
-rw-r--r-- | fw/fe310/common.mk | 3 | ||||
-rw-r--r-- | fw/fe310/test/Makefile | 20 | ||||
-rwxr-xr-x | fw/fe310/test/modem | bin | 0 -> 134292 bytes | |||
-rw-r--r-- | fw/fe310/test/modem.c | 167 | ||||
-rw-r--r-- | fw/fe310/test/modem.o | bin | 0 -> 7644 bytes |
5 files changed, 187 insertions, 3 deletions
diff --git a/fw/fe310/common.mk b/fw/fe310/common.mk index e468289..9fddf67 100644 --- a/fw/fe310/common.mk +++ b/fw/fe310/common.mk @@ -3,6 +3,3 @@ AR = $(RISCV_HOME)/bin/riscv64-unknown-elf-ar RANLIB = $(RISCV_HOME)/bin/riscv64-unknown-elf-ranlib CFLAGS = -march=rv32imac -mabi=ilp32 -mcmodel=medlow -ffunction-sections -fdata-sections --specs=nano.specs -O3 -LDFLAGS = $(CFLAGS) -L$(FE310_HOME) -Wl,--gc-sections -nostartfiles -nostdlib -Wl,--start-group -lc -lm -lgcc -leos -Wl,--end-group -T$(FE310_HOME)/bsp/default.lds - -UPARGS = --openocd $(RISCV_OPENOCD_HOME)/bin/openocd --gdb $(RISCV_HOME)/bin/riscv64-unknown-elf-gdb --openocd-config $(FE310_HOME)/bsp/openocd.cfg diff --git a/fw/fe310/test/Makefile b/fw/fe310/test/Makefile new file mode 100644 index 0000000..f6b619c --- /dev/null +++ b/fw/fe310/test/Makefile @@ -0,0 +1,20 @@ +include ../common.mk + +CFLAGS += -I.. -I../bsp/include -I../bsp/drivers +LDFLAGS = $(CFLAGS) -L.. -Wl,--gc-sections -nostartfiles -nostdlib -Wl,--start-group -lc -lm -lgcc -leos -Wl,--end-group -T../bsp/default.lds + +TARGET = modem + +all: $(TARGET) + +%.o: %.c + $(CC) $(CFLAGS) -c $< + +$(TARGET): $(TARGET).o + $(CC) $< $(LDFLAGS) -o $@ + +clean: + rm -f *.o *.a $(TARGET) + +upload: $(TARGET) + ../bsp/upload --elf ./$(TARGET) --openocd $(RISCV_OPENOCD_HOME)/bin/openocd --gdb $(RISCV_HOME)/bin/riscv64-unknown-elf-gdb --openocd-config ../bsp/openocd.cfg diff --git a/fw/fe310/test/modem b/fw/fe310/test/modem Binary files differnew file mode 100755 index 0000000..e7a3c4a --- /dev/null +++ b/fw/fe310/test/modem diff --git a/fw/fe310/test/modem.c b/fw/fe310/test/modem.c new file mode 100644 index 0000000..de6394d --- /dev/null +++ b/fw/fe310/test/modem.c @@ -0,0 +1,167 @@ +#include <stdio.h> +#include <stdlib.h> +#include <unistd.h> + +#include <eos/eos.h> +#include <eos/event.h> +#include <eos/timer.h> +#include <eos/uart.h> +#include <eos/i2s.h> +#include <eos/spi.h> +#include <eos/net.h> +#include <eos/cell.h> +#include <eos/eve/eve.h> +#include <eos/eve/eve_kbd.h> +#include <eos/eve/eve_text.h> + +#define ABUF_SIZE 512 +#define MIC_WM 128 + +static uint8_t mic_arr[ABUF_SIZE]; +static uint8_t spk_arr[ABUF_SIZE]; + +static int audio_on = 0; + +static EVEText box; +static EVEKbd kbd; + +static void key_down(void *p, int c) { + int i = 2; + unsigned char *buf = eos_net_alloc(); + + buf[0] = EOS_CELL_MTYPE_UART_DATA; + if (c == '\n') { + buf[1] = '\r'; + buf[2] = '\n'; + i++; + } else { + buf[1] = c; + } + + eos_net_send(EOS_NET_MTYPE_CELL, buf, i, 0); +} + +static void handle_touch(void *p, uint8_t tag0, int touch_idx) { + eve_kbd_touch(&kbd, tag0, touch_idx); + eve_text_touch(&box, tag0, touch_idx); + + eve_cmd_dl(CMD_DLSTART); + eve_cmd_dl(CLEAR_COLOR_RGB(0,0,0)); + eve_cmd_dl(CLEAR(1,1,1)); + eve_text_draw(&box); + eve_kbd_draw(&kbd); + eve_cmd_dl(DISPLAY()); + eve_cmd_dl(CMD_SWAP); + eve_cmd_exec(1); +} + +static void handle_mic(unsigned char type) { + uint16_t size; + unsigned char *buf = eos_net_alloc(); + + buf[0] = EOS_CELL_MTYPE_PCM_DATA; + size = eos_i2s_mic_read(buf+1, MIC_WM); + eos_net_send(EOS_NET_MTYPE_CELL, buf, size+1, 0); +} + +static void handle_uart(unsigned char type) { + int i = 0; + int c = 0; + unsigned char *buf = NULL; + + c = eos_uart_getc(0); + if (c == EOS_ERR_EMPTY) return; + + buf = eos_net_alloc(); + buf[0] = EOS_CELL_MTYPE_UART_DATA; + buf[1] = c; + i = 2; + while ((c = eos_uart_getc(0)) != EOS_ERR_EMPTY) { + buf[i] = c; + i++; + if (i == EOS_NET_SIZE_BUF) break; + } + eos_net_send(EOS_NET_MTYPE_CELL, buf, i, 0); + eos_uart_rxwm_set(0); +} + +static void handle_cell_msg(unsigned char _type, unsigned char *buffer, uint16_t len) { + int i; + unsigned char type = buffer[0]; + + switch (type) { + case EOS_CELL_MTYPE_READY: + buffer[0] = EOS_CELL_MTYPE_UART_TAKE; + eos_net_send(EOS_NET_MTYPE_CELL, buffer, 1, 0); + eos_uart_rxwm_set(0); + printf("\nREADY.\n"); + break; + + case EOS_CELL_MTYPE_UART_DATA: + eos_spi_dev_start(EOS_DEV_DISP); + for (i=1; i<len; i++) { + if (buffer[i] != '\r') eve_text_putc(&box, buffer[i]); + } + eos_net_free(buffer, 0); + if (box.dirty) handle_touch(NULL, 0, -1); + eos_spi_dev_stop(); + break; + + case EOS_CELL_MTYPE_PCM_DATA: + eos_i2s_spk_write(buffer+1, len-1); + eos_net_free(buffer, 0); + break; + + default: + eos_net_free(buffer, 0); + break; + } +} + +static void audio_toggle(unsigned char *buf) { + if (audio_on) { + audio_on = 0; + buf[0] = EOS_CELL_MTYPE_PCM_STOP; + eos_net_send(EOS_NET_MTYPE_CELL, buf, 1, 0); + eos_i2s_stop(); + } else { + audio_on = 1; + buf[0] = EOS_CELL_MTYPE_PCM_START; + eos_net_send(EOS_NET_MTYPE_CELL, buf, 1, 0); + eos_i2s_start(8000, EOS_I2S_FMT_PCM16); + } +} + +int main() { + EVERect g = {0, 60, 480, 512}; + uint32_t mem_next = EVE_RAM_G; + + eos_init(); + + eos_spi_dev_start(EOS_DEV_DISP); + + eve_text_init(&box, &g, 30, 16, 0x80, 200, mem_next, &mem_next); + eve_kbd_init(&kbd, NULL, mem_next, &mem_next); + eve_kbd_set_handler(&kbd, key_down, NULL); + + eve_touch_set_handler(handle_touch, NULL); + eve_touch_set_opt(0x80, EVE_TOUCH_OPT_TRACK | EVE_TOUCH_OPT_TRACK_EXT); + handle_touch(NULL, 0, -1); + eve_brightness(0x40); + + eos_spi_dev_stop(); + + eos_i2s_mic_init(mic_arr, ABUF_SIZE); + eos_i2s_mic_set_wm(MIC_WM); + eos_i2s_mic_set_handler(handle_mic); + eos_i2s_spk_init(spk_arr, ABUF_SIZE); + + eos_uart_set_handler(EOS_UART_ETYPE_RX, handle_uart); + eos_cell_set_handler(EOS_CELL_MTYPE_DEV, handle_cell_msg); + + eos_net_acquire_for_evt(EOS_EVT_I2S | EOS_I2S_ETYPE_MIC, 1); + eos_net_acquire_for_evt(EOS_EVT_UI | EVE_ETYPE_INTR, 1); + eos_net_acquire_for_evt(EOS_EVT_UART | EOS_UART_ETYPE_RX, 1); + + eos_evtq_loop(); +} diff --git a/fw/fe310/test/modem.o b/fw/fe310/test/modem.o Binary files differnew file mode 100644 index 0000000..4b16a22 --- /dev/null +++ b/fw/fe310/test/modem.o |