From 327f734e4f2fa7147a0b315b5d41b5146c770d84 Mon Sep 17 00:00:00 2001 From: "Sergio R. Caprile" Date: Tue, 6 Dec 2022 17:09:15 -0300 Subject: [PATCH] Add README --- examples/ti/ek-tm4c1294xl-baremetal/README.md | 2 +- .../ti/ek-tm4c1294xl-freertos-mip/README.md | 40 +++++++++++++++++++ 2 files changed, 41 insertions(+), 1 deletion(-) create mode 100644 examples/ti/ek-tm4c1294xl-freertos-mip/README.md diff --git a/examples/ti/ek-tm4c1294xl-baremetal/README.md b/examples/ti/ek-tm4c1294xl-baremetal/README.md index 2e3c6307..c4ac6a47 100644 --- a/examples/ti/ek-tm4c1294xl-baremetal/README.md +++ b/examples/ti/ek-tm4c1294xl-baremetal/README.md @@ -46,4 +46,4 @@ $ picocom /dev/ttyACM0 -i -b 115200 --imap=lfcrlf There is also a [detailed tutorial on this example](https://mongoose.ws/tutorials/ti/ek-tm4c1294xl-baremetal/) -For more details and benchmark data on MIP, check the [F746ZG example](../nucleo-f746zg-baremetal/) +For more details and benchmark data on MIP, check the [F746ZG example](../../stm32/nucleo-f746zg-baremetal/) diff --git a/examples/ti/ek-tm4c1294xl-freertos-mip/README.md b/examples/ti/ek-tm4c1294xl-freertos-mip/README.md new file mode 100644 index 00000000..8691b7eb --- /dev/null +++ b/examples/ti/ek-tm4c1294xl-freertos-mip/README.md @@ -0,0 +1,40 @@ +# MIP webserver over FreeRTOS on EK-TM4C1294XL + +This firmware uses MIP, an experimental TCP/IP stack of the Mongoose Network Library, running as a FreeRTOS task. +It implements the following: + +- Minimal elementary web server, as simple as possible +- No dependencies: no HAL, no CMSIS +- Hand-written [mcu.h](mcu.h) header based on the [datasheet](https://www.ti.com/lit/pdf/spms433) +- Interrupt-driven [Ethernet driver](../../../drivers/mip_driver_tm4c.c) +- LED blinky, based on another FreeRTOS task +- Debug log on UART0 (ICDI) + +## Requirements + +- [GNU make](http://mongoose.ws/tutorials/tools/#gnu-make) +- [ARM GCC](http://mongoose.ws/tutorials/tools/#arm-gcc) +- [Uniflash](https://mongoose.ws/tutorials/ti/ek-tm4c1294xl-baremetal/#build-and-run) for flashing + +The Makefile defaults to using Docker for the compiler, so you don't actually need to install it if you are using a Linux/Mac workstation. If you are not, or you want to run your local ARM compiler, just append `DOCKER=` to the make commands depicted below to call the compiler directly; it must be in your executable path. + +In any case, the links above will send you to tutorials on how to install each of those tools in your workstation for Linux, Mac, and Windows. + +You'll also need _git_ so the Makefile can clone the FreeRTOS-Kernel repository. We assume you have it since you got to get this repository somehow. If you don't, and don't want to install it, just get the proper [FreeRTOS-Kernel](https://github.com/FreeRTOS/FreeRTOS-Kernel) version (see the Makefile) from its repository, as you did with the Mongoose repository. + +## Usage + +Plugin your board into USB, and attach an Ethernet cable. +To build and flash: + +```sh +$ make clean flash +``` + +To see debug log, use any serial monitor program like `picocom` at 115200 bps and configure it to insert carriage returns after line feeds: + +```sh +$ picocom /dev/ttyACM0 -i -b 115200 --imap=lfcrlf +``` + +For more details and benchmark data on MIP, check the [F746ZG baremetal example](../../stm32/nucleo-f746zg-baremetal/)