| Index: platforms/stm/event_handler_test/src/fletch_entry.cc
|
| diff --git a/platforms/stm/event_handler_test/src/fletch_entry.cc b/platforms/stm/event_handler_test/src/fletch_entry.cc
|
| deleted file mode 100644
|
| index 127464472f2501742ba9bd88feae868e36f6720f..0000000000000000000000000000000000000000
|
| --- a/platforms/stm/event_handler_test/src/fletch_entry.cc
|
| +++ /dev/null
|
| @@ -1,132 +0,0 @@
|
| -// Copyright (c) 2015, the Dartino project authors. Please see the AUTHORS file
|
| -// for details. All rights reserved. Use of this source code is governed by a
|
| -// BSD-style license that can be found in the LICENSE.md file.
|
| -
|
| -#include <stdlib.h>
|
| -
|
| -#include <cmsis_os.h>
|
| -extern "C" {
|
| - #include <lcd_log.h>
|
| -}
|
| -#include <stm32746g_discovery.h>
|
| -#include <stm32746g_discovery_lcd.h>
|
| -
|
| -#include "include/fletch_api.h"
|
| -#include "include/static_ffi.h"
|
| -
|
| -#include "platforms/stm/disco_fletch/src/fletch_entry.h"
|
| -#include "platforms/stm/disco_fletch/src/page_allocator.h"
|
| -#include "platforms/stm/disco_fletch/src/uart.h"
|
| -#include "src/shared/platform.h"
|
| -#include "src/shared/utils.h"
|
| -
|
| -extern unsigned char _binary_event_handler_test_snapshot_start;
|
| -extern unsigned char _binary_event_handler_test_snapshot_end;
|
| -extern unsigned char _binary_event_handler_test_snapshot_size;
|
| -
|
| -extern PageAllocator* page_allocator;
|
| -
|
| -// `MessageQueueProducer` will send a message every `kMessageFrequency`
|
| -// millisecond.
|
| -const int kMessageFrequency = 400;
|
| -
|
| -// Sends a message on a port_id with a fixed interval.
|
| -static void MessageQueueProducer(const void *argument) {
|
| - uint16_t counter = 0;
|
| - for (;;) {
|
| - counter++;
|
| - int port_id = 1;
|
| - int status = fletch::SendMessageCmsis(port_id, counter);
|
| - if (status != osOK) {
|
| - fletch::Print::Error("Error Sending %d\n", status);
|
| - }
|
| - osDelay(kMessageFrequency);
|
| - }
|
| -}
|
| -
|
| -// Implementation of write used from syscalls.c to redirect all printf
|
| -// calls to the print interceptors.
|
| -extern "C" int Write(int file, char *ptr, int len) {
|
| - for (int i = 0; i < len; i++) {
|
| - if (file == 2) {
|
| - fletch::Print::Error("%c", *ptr++);
|
| - } else {
|
| - fletch::Print::Out("%c", *ptr++);
|
| - }
|
| - }
|
| - return len;
|
| -}
|
| -
|
| -FLETCH_EXPORT_TABLE_BEGIN
|
| - FLETCH_EXPORT_TABLE_ENTRY("BSP_LED_On", BSP_LED_On)
|
| - FLETCH_EXPORT_TABLE_ENTRY("BSP_LED_Off", BSP_LED_Off)
|
| -FLETCH_EXPORT_TABLE_END
|
| -
|
| -// Run fletch on the linked in snapshot.
|
| -void StartFletch(void const * argument) {
|
| - fletch::Print::Out("Setup fletch\n");
|
| - FletchSetup();
|
| - fletch::Print::Out("Read fletch snapshot\n");
|
| - unsigned char *snapshot = &_binary_event_handler_test_snapshot_start;
|
| - int snapshot_size =
|
| - reinterpret_cast<int>(&_binary_event_handler_test_snapshot_size);
|
| - FletchProgram program = FletchLoadSnapshot(snapshot, snapshot_size);
|
| - fletch::Print::Out("Run fletch program\n");
|
| - FletchRunMain(program);
|
| - fletch::Print::Out("Fletch program exited\n");
|
| -}
|
| -
|
| -// LCDLogPutchar is defined by the STM LCD log utility
|
| -// (Utilities/Log/lcd_log.c) by means of the macro definitions of
|
| -// LCD_LOG_PUTCHAR in lcd_log_conf.h.
|
| -extern "C" int LCDLogPutchar(int ch);
|
| -void LCDPrintIntercepter(const char* message, int out, void* data) {
|
| - int len = strlen(message);
|
| - if (out == 3) {
|
| - LCD_LineColor = LCD_COLOR_RED;
|
| - } else {
|
| - LCD_LineColor = LCD_COLOR_BLACK;
|
| - }
|
| - for (int i = 0; i < len; i++) {
|
| - LCDLogPutchar(message[i]);
|
| - }
|
| -}
|
| -
|
| -// Main entry point from FreeRTOS. Running in the default task.
|
| -void FletchEntry(void const * argument) {
|
| - // Add an arena of the 8Mb of external memory.
|
| - uint32_t ext_mem_arena =
|
| - page_allocator->AddArena("ExtMem", 0xc0000000, 0x800000);
|
| - BSP_LED_Init(LED1);
|
| -
|
| - // Initialize the LCD.
|
| - size_t fb_bytes = (RK043FN48H_WIDTH * RK043FN48H_HEIGHT * 2);
|
| - size_t fb_pages = page_allocator->PagesForBytes(fb_bytes);
|
| - void* fb = page_allocator->AllocatePages(fb_pages, ext_mem_arena);
|
| - BSP_LCD_Init();
|
| - BSP_LCD_LayerDefaultInit(1, reinterpret_cast<uint32_t>(fb));
|
| - BSP_LCD_SelectLayer(1);
|
| - BSP_LCD_SetFont(&LCD_DEFAULT_FONT);
|
| -
|
| - fletch::Platform::Setup();
|
| -
|
| - // Initialize LCD Log module.
|
| - LCD_LOG_Init();
|
| - LCD_LOG_SetHeader(reinterpret_cast<uint8_t*>(const_cast<char*>("Fletch")));
|
| - LCD_LOG_SetFooter(reinterpret_cast<uint8_t*>(const_cast<char*>(
|
| - "STM32746G-Discovery")));
|
| - FletchRegisterPrintInterceptor(LCDPrintIntercepter, NULL);
|
| - fletch::Print::DisableStandardOutput();
|
| -
|
| - osThreadDef(START_FLETCH, StartFletch, osPriorityNormal, 0,
|
| - 3 * 1024 /* stack size */);
|
| - osThreadCreate(osThread(START_FLETCH), NULL);
|
| -
|
| - osThreadDef(PRODUCER, MessageQueueProducer, osPriorityNormal, 0, 2 * 1024);
|
| - osThreadCreate(osThread(PRODUCER), NULL);
|
| -
|
| - // No more to do right now.
|
| - for (;;) {
|
| - osDelay(1);
|
| - }
|
| -}
|
|
|