WIP target lo
custom debug stream run docker with project dir, specify dir to makefile remove unused includes fix broken F1
This commit is contained in:
parent
419a7644a4
commit
0980775f01
12
app/app.cpp
12
app/app.cpp
@ -1,12 +1,20 @@
|
|||||||
#include "Arduino.h"
|
#include "flipper.h"
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
FILE* get_debug();
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" void app() {
|
extern "C" void app() {
|
||||||
printf("hello Flipper!\n");
|
FILE* debug_uart = get_debug();
|
||||||
|
|
||||||
|
fprintf(debug_uart, "hello Flipper!\n");
|
||||||
|
|
||||||
GpioPin red_led = {LED_RED_GPIO_Port, LED_RED_Pin};
|
GpioPin red_led = {LED_RED_GPIO_Port, LED_RED_Pin};
|
||||||
|
|
||||||
app_gpio_init(red_led, GpioModeOutput);
|
app_gpio_init(red_led, GpioModeOutput);
|
||||||
|
|
||||||
|
|
||||||
while(1) {
|
while(1) {
|
||||||
delay(100);
|
delay(100);
|
||||||
app_gpio_write(red_led, true);
|
app_gpio_write(red_led, true);
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
|
#include "flipper_hal.h"
|
||||||
#include "cmsis_os.h"
|
#include "cmsis_os.h"
|
||||||
#include "app_hal.h"
|
|
||||||
#include <stdio.h>
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Arduino defines
|
||||||
|
|
||||||
#define pinMode app_gpio_init
|
#define pinMode app_gpio_init
|
||||||
#define digitalWrite app_gpio_write
|
#define digitalWrite app_gpio_write
|
||||||
#define digitalRead app_gpio_read
|
#define digitalRead app_gpio_read
|
52
app/write.c
52
app/write.c
@ -1,39 +1,10 @@
|
|||||||
/*******************
|
#define _GNU_SOURCE
|
||||||
*
|
|
||||||
* Copyright 1998-2010 IAR Systems AB.
|
|
||||||
*
|
|
||||||
* This is a template implementation of the "__write" function used by
|
|
||||||
* the standard library. Replace it with a system-specific
|
|
||||||
* implementation.
|
|
||||||
*
|
|
||||||
* The "__write" function should output "size" number of bytes from
|
|
||||||
* "buffer" in some application-specific way. It should return the
|
|
||||||
* number of characters written, or _LLIO_ERROR on failure.
|
|
||||||
*
|
|
||||||
* If "buffer" is zero then __write should perform flushing of
|
|
||||||
* internal buffers, if any. In this case "handle" can be -1 to
|
|
||||||
* indicate that all handles should be flushed.
|
|
||||||
*
|
|
||||||
* The template implementation below assumes that the application
|
|
||||||
* provides the function "MyLowLevelPutchar". It should return the
|
|
||||||
* character written, or -1 on failure.
|
|
||||||
*
|
|
||||||
********************/
|
|
||||||
|
|
||||||
// #include <yfuns.h>
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "cmsis_os.h"
|
#include <stdio.h>
|
||||||
|
|
||||||
extern UART_HandleTypeDef DEBUG_UART;
|
extern UART_HandleTypeDef DEBUG_UART;
|
||||||
|
|
||||||
|
ssize_t uart_write(void* cookie, const char * buffer, size_t size) {
|
||||||
/*
|
|
||||||
* If the __write implementation uses internal buffering, uncomment
|
|
||||||
* the following line to ensure that we are called with "buffer" as 0
|
|
||||||
* (i.e. flush) when the application terminates.
|
|
||||||
*/
|
|
||||||
|
|
||||||
size_t _write(int handle, const unsigned char * buffer, size_t size) {
|
|
||||||
if (buffer == 0) {
|
if (buffer == 0) {
|
||||||
/*
|
/*
|
||||||
* This means that we should flush internal buffers. Since we
|
* This means that we should flush internal buffers. Since we
|
||||||
@ -43,7 +14,18 @@ size_t _write(int handle, const unsigned char * buffer, size_t size) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
HAL_UART_Transmit(&DEBUG_UART, (uint8_t*)buffer, (uint16_t)size, HAL_MAX_DELAY);
|
return (ssize_t)HAL_UART_Transmit(&DEBUG_UART, (uint8_t*)buffer, (uint16_t)size, HAL_MAX_DELAY);
|
||||||
|
}
|
||||||
return (int)size;
|
|
||||||
|
FILE* get_debug() {
|
||||||
|
FILE* fp = fopencookie(NULL,"w+", (cookie_io_functions_t){
|
||||||
|
.read = NULL,
|
||||||
|
.write = uart_write,
|
||||||
|
.seek = NULL,
|
||||||
|
.close = NULL
|
||||||
|
});
|
||||||
|
|
||||||
|
setvbuf(fp, NULL, _IONBF, 0);
|
||||||
|
|
||||||
|
return fp;
|
||||||
}
|
}
|
@ -9,8 +9,6 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
- .:/project
|
- .:/project
|
||||||
# - /dev/bus/usb:/dev/bus/usb
|
# - /dev/bus/usb:/dev/bus/usb
|
||||||
# working_dir: "/project/target_nucleo476"
|
working_dir: "/project"
|
||||||
# working_dir: "/project/target_bluepill"
|
|
||||||
working_dir: "/project/target_f1"
|
|
||||||
environment:
|
environment:
|
||||||
DISPLAY: $DISPLAY
|
DISPLAY: $DISPLAY
|
||||||
|
@ -96,7 +96,7 @@ startup_stm32l476xx.s
|
|||||||
CPP_SOURCES = ../app/app.cpp
|
CPP_SOURCES = ../app/app.cpp
|
||||||
|
|
||||||
C_SOURCES += ../app/write.c
|
C_SOURCES += ../app/write.c
|
||||||
C_SOURCES += ../app/app_hal.c
|
C_SOURCES += Src/flipper_hal.c
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
# binaries
|
# binaries
|
||||||
|
@ -5,7 +5,7 @@ GPIO and HAL implementations
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "app_hal.h"
|
#include "flipper_hal.h"
|
||||||
|
|
||||||
void app_gpio_init(GpioPin gpio, GpioMode mode) {
|
void app_gpio_init(GpioPin gpio, GpioMode mode) {
|
||||||
if(gpio.pin != 0) {
|
if(gpio.pin != 0) {
|
3
target_lo/Inc/cmsis_os.h
Normal file
3
target_lo/Inc/cmsis_os.h
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
#include "main.h"
|
||||||
|
|
||||||
|
void osDelay(uint32_t ms);
|
61
target_lo/Inc/flipper_hal.h
Normal file
61
target_lo/Inc/flipper_hal.h
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
/*
|
||||||
|
Flipper devices inc.
|
||||||
|
|
||||||
|
GPIO and HAL implementations
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include "main.h"
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
GpioModeInput,
|
||||||
|
GpioModeOutput,
|
||||||
|
GpioModeOpenDrain
|
||||||
|
} GpioMode;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint32_t port;
|
||||||
|
uint32_t pin;
|
||||||
|
GpioMode mode;
|
||||||
|
} GpioPin;
|
||||||
|
|
||||||
|
void app_gpio_init(GpioPin gpio, GpioMode mode);
|
||||||
|
|
||||||
|
inline void app_gpio_write(GpioPin gpio, bool state) {
|
||||||
|
if(gpio.pin != 0) {
|
||||||
|
if(state) {
|
||||||
|
printf("[GPIO] %d:%d on\n", gpio.port, gpio.pin);
|
||||||
|
} else {
|
||||||
|
printf("[GPIO] %d:%d off\n", gpio.port, gpio.pin);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
printf("[GPIO] no pin\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool app_gpio_read(GpioPin gpio) {
|
||||||
|
// TODO emulate pin state?
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void delay_us(uint32_t time);
|
||||||
|
|
||||||
|
void pwm_set(float value, float freq, TIM_HandleTypeDef* tim, uint32_t channel);
|
||||||
|
|
||||||
|
extern TIM_HandleTypeDef htim8;
|
||||||
|
|
||||||
|
inline void app_tim_ic_init(bool both) {
|
||||||
|
printf("[TIM] init\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void app_tim_pulse(uint32_t width) {
|
||||||
|
printf("[TIM] pulse %d\n", width);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void app_tim_stop() {
|
||||||
|
printf("[TIM] stop\n");
|
||||||
|
}
|
18
target_lo/Inc/main.h
Normal file
18
target_lo/Inc/main.h
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
#include <stdint.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <limits.h>
|
||||||
|
|
||||||
|
#define HAL_MAX_DELAY INT_MAX
|
||||||
|
|
||||||
|
typedef uint32_t UART_HandleTypeDef;
|
||||||
|
uint16_t HAL_UART_Transmit(
|
||||||
|
UART_HandleTypeDef* handle,
|
||||||
|
uint8_t* bufer,
|
||||||
|
uint16_t size,
|
||||||
|
uint32_t wait_ms
|
||||||
|
);
|
||||||
|
|
||||||
|
typedef uint32_t TIM_HandleTypeDef;
|
||||||
|
|
||||||
|
#define LED_RED_GPIO_Port 1
|
||||||
|
#define LED_RED_Pin 1
|
121
target_lo/Makefile
Normal file
121
target_lo/Makefile
Normal file
@ -0,0 +1,121 @@
|
|||||||
|
TARGET = target_lo
|
||||||
|
|
||||||
|
|
||||||
|
######################################
|
||||||
|
# building variables
|
||||||
|
######################################
|
||||||
|
# debug build?
|
||||||
|
DEBUG = 1
|
||||||
|
# optimization
|
||||||
|
OPT = -Og
|
||||||
|
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# paths
|
||||||
|
#######################################
|
||||||
|
# Build path
|
||||||
|
BUILD_DIR = build
|
||||||
|
|
||||||
|
######################################
|
||||||
|
# source
|
||||||
|
######################################
|
||||||
|
# C sources
|
||||||
|
C_SOURCES = \
|
||||||
|
Src/main.c
|
||||||
|
|
||||||
|
CPP_SOURCES = ../app/app.cpp
|
||||||
|
|
||||||
|
C_SOURCES += ../app/write.c
|
||||||
|
C_SOURCES += Src/flipper_hal.c
|
||||||
|
C_SOURCES += Src/lo_os.c
|
||||||
|
C_SOURCES += Src/lo_hal.c
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# binaries
|
||||||
|
#######################################
|
||||||
|
|
||||||
|
CC = gcc
|
||||||
|
CPP = g++
|
||||||
|
AS =
|
||||||
|
CP = objcopy
|
||||||
|
SZ = size
|
||||||
|
HEX = $(CP) -O ihex
|
||||||
|
BIN = $(CP) -O binary -S
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# CFLAGS
|
||||||
|
#######################################
|
||||||
|
|
||||||
|
# C defines
|
||||||
|
C_DEFS = \
|
||||||
|
-DUSE_HAL_DRIVER \
|
||||||
|
-DSTM32L476xx \
|
||||||
|
-DBUTON_INVERT=false \
|
||||||
|
-DDEBUG_UART=huart1
|
||||||
|
|
||||||
|
# C includes
|
||||||
|
C_INCLUDES = \
|
||||||
|
-IInc \
|
||||||
|
-I../app
|
||||||
|
|
||||||
|
# compile gcc flags
|
||||||
|
CFLAGS = $(C_DEFS) $(C_INCLUDES) $(OPT) -Wall -fdata-sections -ffunction-sections
|
||||||
|
|
||||||
|
ifeq ($(DEBUG), 1)
|
||||||
|
CFLAGS += -g -gdwarf-2
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
|
# Generate dependency information
|
||||||
|
CFLAGS += -MMD -MP -MF"$(@:%.o=%.d)"
|
||||||
|
|
||||||
|
CPPFLAGS = -fno-threadsafe-statics
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# LDFLAGS
|
||||||
|
#######################################
|
||||||
|
|
||||||
|
# libraries
|
||||||
|
LIBS = -lc -lm
|
||||||
|
LIBDIR =
|
||||||
|
LDFLAGS = $(LIBDIR) $(LIBS) -Wl,-Map=$(BUILD_DIR)/$(TARGET).map,--cref -Wl,--gc-sections
|
||||||
|
|
||||||
|
# default action: build all
|
||||||
|
all: $(BUILD_DIR)/$(TARGET)
|
||||||
|
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# build the application
|
||||||
|
#######################################
|
||||||
|
# list of objects
|
||||||
|
OBJECTS = $(addprefix $(BUILD_DIR)/,$(notdir $(C_SOURCES:.c=.o)))
|
||||||
|
vpath %.c $(sort $(dir $(C_SOURCES)))
|
||||||
|
|
||||||
|
OBJECTS += $(addprefix $(BUILD_DIR)/,$(notdir $(CPP_SOURCES:.cpp=.o)))
|
||||||
|
vpath %.cpp $(sort $(dir $(CPP_SOURCES)))
|
||||||
|
|
||||||
|
$(BUILD_DIR)/%.o: %.c Makefile | $(BUILD_DIR)
|
||||||
|
$(CC) -c $(CFLAGS) -Wa,-a,-ad,-alms=$(BUILD_DIR)/$(notdir $(<:.c=.lst)) $< -o $@
|
||||||
|
|
||||||
|
$(BUILD_DIR)/%.o: %.cpp Makefile | $(BUILD_DIR)
|
||||||
|
$(CPP) -c $(CFLAGS) $(CPPFLAGS) -Wa,-a,-ad,-alms=$(BUILD_DIR)/$(notdir $(<:.c=.lst)) $< -o $@
|
||||||
|
|
||||||
|
$(BUILD_DIR)/$(TARGET): $(OBJECTS) Makefile
|
||||||
|
$(CPP) $(OBJECTS) $(LDFLAGS) -o $@
|
||||||
|
$(SZ) $@
|
||||||
|
|
||||||
|
$(BUILD_DIR):
|
||||||
|
mkdir $@
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# clean up
|
||||||
|
#######################################
|
||||||
|
clean:
|
||||||
|
-rm -fR $(BUILD_DIR)
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# dependencies
|
||||||
|
#######################################
|
||||||
|
-include $(wildcard $(BUILD_DIR)/*.d)
|
||||||
|
|
||||||
|
# *** EOF ***
|
41
target_lo/Src/flipper_hal.c
Normal file
41
target_lo/Src/flipper_hal.c
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
/*
|
||||||
|
Flipper devices inc.
|
||||||
|
|
||||||
|
GPIO and HAL implementations
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "main.h"
|
||||||
|
#include "flipper_hal.h"
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
void app_gpio_init(GpioPin gpio, GpioMode mode) {
|
||||||
|
if(gpio.pin != 0) {
|
||||||
|
|
||||||
|
switch(mode) {
|
||||||
|
case GpioModeInput:
|
||||||
|
printf("[GPIO] %d:%d input\n", gpio.port, gpio.pin);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GpioModeOutput:
|
||||||
|
printf("[GPIO] %d:%d push pull\n", gpio.port, gpio.pin);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GpioModeOpenDrain:
|
||||||
|
printf("[GPIO] %d:%d open drain\n", gpio.port, gpio.pin);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
gpio.mode = mode;
|
||||||
|
} else {
|
||||||
|
printf("[GPIO] no pin\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void delay_us(uint32_t time) {
|
||||||
|
// How to deal with it
|
||||||
|
printf("[DELAY] %d us\n", time);
|
||||||
|
}
|
||||||
|
|
||||||
|
void pwm_set(float value, float freq, TIM_HandleTypeDef* tim, uint32_t channel) {
|
||||||
|
printf("[TIM] set pwm %d:%d %f Hz, %f%%\n", *tim, channel, freq, value * 100.);
|
||||||
|
}
|
21
target_lo/Src/lo_hal.c
Normal file
21
target_lo/Src/lo_hal.c
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
/*
|
||||||
|
Flipper devices inc.
|
||||||
|
|
||||||
|
Dummy hal for local fw build
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include "main.h"
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
UART_HandleTypeDef DEBUG_UART = 0;
|
||||||
|
|
||||||
|
uint16_t HAL_UART_Transmit(
|
||||||
|
UART_HandleTypeDef* handle,
|
||||||
|
uint8_t* bufer,
|
||||||
|
uint16_t size,
|
||||||
|
uint32_t wait_ms
|
||||||
|
) {
|
||||||
|
uint16_t res = write(1, (const char*)bufer, size);
|
||||||
|
return res;
|
||||||
|
}
|
8
target_lo/Src/lo_os.c
Normal file
8
target_lo/Src/lo_os.c
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
#include "cmsis_os.h"
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
void osDelay(uint32_t ms) {
|
||||||
|
usleep(ms * 1000);
|
||||||
|
printf("[DELAY] %d ms\n", ms);
|
||||||
|
}
|
13
target_lo/Src/main.c
Normal file
13
target_lo/Src/main.c
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
/*
|
||||||
|
Flipper devices inc.
|
||||||
|
|
||||||
|
Local fw build entry point.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void app();
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
app();
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
@ -107,7 +107,7 @@ After start, bootloader run first. It can:
|
|||||||
|
|
||||||
1. Install [docker compose](https://docs.docker.com/compose/install/)
|
1. Install [docker compose](https://docs.docker.com/compose/install/)
|
||||||
2. After startup you should run `docker-compose up -d` to run the container.
|
2. After startup you should run `docker-compose up -d` to run the container.
|
||||||
3. Then you can run `docker-compose exec dev make` to build application.
|
3. Then you can run `docker-compose exec dev make -C <target_dir>` to build application.
|
||||||
|
|
||||||
If Dockerfile is changed you should run `docker-compose down` and `docker-compose build` for rebuild the image.
|
If Dockerfile is changed you should run `docker-compose down` and `docker-compose build` for rebuild the image.
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user