增加了一些编译优化,增加了log使用文档,新增部分user_lib功能

This commit is contained in:
NeoZng 2023-06-24 20:29:57 +08:00
parent f51b6fec3d
commit 9ef46e2f88
8 changed files with 61 additions and 48 deletions

View File

@ -199,7 +199,7 @@ FPU = -mfpu=fpv4-sp-d16
FLOAT-ABI = -mfloat-abi=hard FLOAT-ABI = -mfloat-abi=hard
# mcu # mcu
MCU = $(CPU) -mthumb $(FPU) $(FLOAT-ABI) MCU = $(CPU) -mthumb -mthumb-interwork $(FPU) $(FLOAT-ABI)
# macros for gcc # macros for gcc
# AS defines # AS defines
@ -211,7 +211,9 @@ C_DEFS = \
-DSTM32F407xx \ -DSTM32F407xx \
-DARM_MATH_CM4 \ -DARM_MATH_CM4 \
-DARM_MATH_MATRIX_CHECK \ -DARM_MATH_MATRIX_CHECK \
-DARM_MATH_ROUNDING -DARM_MATH_ROUNDING \
-DARM_MATH_LOOPUNROLL \
-DISABLEFLOAT16
# AS includes # AS includes
AS_INCLUDES = \ AS_INCLUDES = \
@ -277,7 +279,7 @@ C_INCLUDES = \
# compile gcc flags # compile gcc flags
ASFLAGS = $(MCU) $(AS_DEFS) $(AS_INCLUDES) $(OPT) -fdata-sections -ffunction-sections ASFLAGS = $(MCU) $(AS_DEFS) $(AS_INCLUDES) $(OPT) -fdata-sections -ffunction-sections
CFLAGS += $(MCU) $(C_DEFS) $(C_INCLUDES) $(OPT) -fdata-sections -ffunction-sections CFLAGS += $(MCU) $(C_DEFS) $(C_INCLUDES) $(OPT) -fdata-sections -ffunction-sections -fmessage-length=0
ifeq ($(DEBUG), 1) ifeq ($(DEBUG), 1)
CFLAGS += -g -gdwarf-2 CFLAGS += -g -gdwarf-2
@ -299,7 +301,7 @@ LIBS = -lc -lm -lnosys \
-l:libarm_cortexM4lf_math.a -l:libarm_cortexM4lf_math.a
LIBDIR = \ LIBDIR = \
-LMiddlewares/ST/ARM/DSP/Lib -LMiddlewares/ST/ARM/DSP/Lib
LDFLAGS = $(MCU) -specs=nano.specs -T$(LDSCRIPT) $(LIBDIR) $(LIBS) -Wl,-Map=$(BUILD_DIR)/$(TARGET).map,--cref -Wl,--gc-sections LDFLAGS = $(MCU) -specs=nano.specs -T$(LDSCRIPT) $(LIBDIR) $(LIBS) -Wl,-Map=$(BUILD_DIR)/$(TARGET).map,--cref -Wl,--gc-sections -flto
# default action: build all # default action: build all
all: $(BUILD_DIR)/$(TARGET).elf $(BUILD_DIR)/$(TARGET).hex $(BUILD_DIR)/$(TARGET).bin all: $(BUILD_DIR)/$(TARGET).elf $(BUILD_DIR)/$(TARGET).hex $(BUILD_DIR)/$(TARGET).bin
@ -339,7 +341,7 @@ $(BUILD_DIR):
# clean up # clean up
####################################### #######################################
clean: clean:
rd /s/q $(BUILD_DIR) rd $(BUILD_DIR) /s/q
####################################### #######################################

View File

@ -36,6 +36,7 @@
/* Private includes ----------------------------------------------------------*/ /* Private includes ----------------------------------------------------------*/
/* USER CODE BEGIN Includes */ /* USER CODE BEGIN Includes */
#include "robot.h" #include "robot.h"
#include "bsp_log.h"
/* USER CODE END Includes */ /* USER CODE END Includes */
/* Private typedef -----------------------------------------------------------*/ /* Private typedef -----------------------------------------------------------*/
@ -120,6 +121,7 @@ int main(void)
MX_DAC_Init(); MX_DAC_Init();
/* USER CODE BEGIN 2 */ /* USER CODE BEGIN 2 */
RobotInit(); // 唯一的初始化函数 RobotInit(); // 唯一的初始化函数
LOGINFO("[main] SystemInit() and RobotInit() done");
/* USER CODE END 2 */ /* USER CODE END 2 */
/* Call init function for freertos objects (in freertos.c) */ /* Call init function for freertos objects (in freertos.c) */

View File

@ -7,8 +7,6 @@
#define BUFFER_INDEX 0 #define BUFFER_INDEX 0
/** /**
* @brief * @brief
* *
@ -19,31 +17,35 @@ void BSPLogInit();
* @brief ,LOGI,LOGW,LOGE等使用 * @brief ,LOGI,LOGW,LOGE等使用
* *
*/ */
#define LOG_PROTO(type,color,format,...) \ #define LOG_PROTO(type, color, format, ...) \
SEGGER_RTT_printf(BUFFER_INDEX," %s%s"format"\r\n%s", \ SEGGER_RTT_printf(BUFFER_INDEX, " %s%s" format "\r\n%s", \
color, \ color, \
type, \ type, \
##__VA_ARGS__, \ ##__VA_ARGS__, \
RTT_CTRL_RESET) RTT_CTRL_RESET)
/*------下面是日志输出的接口--------*/ /*----------------------------------------下面是日志输出的接口-------------------------------------------------*/
/* 清屏 */ /* 清屏 */
#define LOG_CLEAR() SEGGER_RTT_WriteString(0, " "RTT_CTRL_CLEAR) #define LOG_CLEAR() SEGGER_RTT_WriteString(0, " " RTT_CTRL_CLEAR)
/* 无颜色日志输出 */ /* 无颜色日志输出 */
#define LOG(format,...) LOG_PROTO("","",format,##__VA_ARGS__) #define LOG(format, ...) LOG_PROTO("", "", format, ##__VA_ARGS__)
/* 有颜色格式日志输出,建议使用这些宏来输出日志 */ /**
* ,使
* @attention ,,使Float2Str()
*/
// information level // information level
#define LOGINFO(format,...) LOG_PROTO("I:", RTT_CTRL_TEXT_BRIGHT_GREEN , format, ##__VA_ARGS__) #define LOGINFO(format, ...) LOG_PROTO("I:", RTT_CTRL_TEXT_BRIGHT_GREEN, format, ##__VA_ARGS__)
// warning level // warning level
#define LOGWARNING(format,...) LOG_PROTO("W:", RTT_CTRL_TEXT_BRIGHT_YELLOW, format, ##__VA_ARGS__) #define LOGWARNING(format, ...) LOG_PROTO("W:", RTT_CTRL_TEXT_BRIGHT_YELLOW, format, ##__VA_ARGS__)
// error level // error level
#define LOGERROR(format,...) LOG_PROTO("E:", RTT_CTRL_TEXT_BRIGHT_RED , format, ##__VA_ARGS__) #define LOGERROR(format, ...) LOG_PROTO("E:", RTT_CTRL_TEXT_BRIGHT_RED, format, ##__VA_ARGS__)
/** /**
* @brief segger RTT打印日志,,printf. * @brief segger RTT打印日志,,printf.
* @attention !! ,,使Float2Str() !!
* *
* @param fmt * @param fmt
* @param ... * @param ...
@ -53,6 +55,7 @@ int PrintLog(const char *fmt, ...);
/** /**
* @brief sprintf(),float转换为字符串进行打印 * @brief sprintf(),float转换为字符串进行打印
* @attention RTT打印
* *
* @param str * @param str
* @param va float * @param va float

View File

@ -2,10 +2,6 @@
<p align='right'>neozng1@hnu.edu.cn</p> <p align='right'>neozng1@hnu.edu.cn</p>
> TODO:
>
> 1. 在未接入调试器的时候将日志写入flash中并提供接口读取
## 使用说明 ## 使用说明
bsp_log是基于segger RTT实现的日志打印模块。 bsp_log是基于segger RTT实现的日志打印模块。
@ -18,11 +14,11 @@ bsp_log是基于segger RTT实现的日志打印模块。
#define LOGERROR(format,...) #define LOGERROR(format,...)
``` ```
分别用于输出不同等级的日志。 分别用于输出不同等级的日志。注意RTT不支持直接使用`%f`进行浮点格式化,要使用`void Float2Str(char *str, float va);`转化成字符串之后再发送。
**若想启用RTT必须通过`launch.json`的`debug-jlink`启动调试(不论使用什么调试器)。** **若想启用RTT必须通过`launch.json`的`debug-jlink`启动调试(不论使用什么调试器)。** 按照`VSCode+Ozone环境配置`完成配置之后的cmsis dap和daplink是可以支持Jlink全家桶的。
注意若你使用的是cmsis-dap和daplink**请在调试任务启动之后再打开`log`任务。**(均在项目文件夹下的.vsocde/task.json中有注释自行查看 另外若你使用的是cmsis-dap和daplink**请在 *jlink* 调试任务启动之后再打开`log`任务。**(均在项目文件夹下的.vsocde/task.json中有注释自行查看否则可能出线RTT viewer无法连接客户端的情况。
在ozone中查看log输出直接打开console调试任务台和terminal调试中断便可看到调试输出。 在ozone中查看log输出直接打开console调试任务台和terminal调试中断便可看到调试输出。
@ -34,7 +30,7 @@ bsp_log是基于segger RTT实现的日志打印模块。
```c ```c
int printf_log(const char *fmt, ...); int printf_log(const char *fmt, ...);
void Float2Str(char *str, float va); void Float2Str(char *str, float va); // 输出浮点需要先用此函数进行转换
``` ```
调用第一个函数可以通过jlink或dap-link向调试器连接的上位机发送信息格式和printf相同示例如下 调用第一个函数可以通过jlink或dap-link向调试器连接的上位机发送信息格式和printf相同示例如下
@ -52,8 +48,3 @@ char* str_buff[64];
Float2Str(str_buff,current_feedback); Float2Str(str_buff,current_feedback);
printf_log("Motor %d met some problem, error code %d!\n",3,1); printf_log("Motor %d met some problem, error code %d!\n",3,1);
``` ```
或直接通过`%f`格式符直接使用`printf_log()`发送日志,可以设置小数点位数以降低带宽开销。

View File

@ -8,6 +8,8 @@ static PWMInstance *pwm_instance[PWM_DEVICE_CNT] = {NULL}; // 所有的pwm insta
/** /**
* @brief pwm dma传输完成回调函数 * @brief pwm dma传输完成回调函数
* @attention HAL库的设计问题,pulse完成(tim的计数超过比较寄存器)
* PWM的TIM,,DMA传输完成中断打开
* *
* @param htim * @param htim
*/ */

View File

@ -206,3 +206,9 @@ float AverageFilter(float new_data, float *buf, uint8_t len)
return sum / len; return sum / len;
} }
void MatInit(mat *m, uint8_t row, uint8_t col)
{
m->numCols = col;
m->numRows = row;
m->pData = (float *)zmalloc(row * col * sizeof(float));
}

View File

@ -13,14 +13,11 @@
#ifndef _USER_LIB_H #ifndef _USER_LIB_H
#define _USER_LIB_H #define _USER_LIB_H
#include "stdint.h" #include "stdint.h"
#include "main.h" #include "main.h"
#include "cmsis_os.h" #include "cmsis_os.h"
#include "stm32f407xx.h"
#include "arm_math.h"
#define msin(x) (arm_sin_f32(x))
#define mcos(x) (arm_cos_f32(x))
#ifndef user_malloc #ifndef user_malloc
@ -31,6 +28,18 @@
#endif #endif
#endif #endif
#define msin(x) (arm_sin_f32(x))
#define mcos(x) (arm_cos_f32(x))
typedef arm_matrix_instance_f32 mat;
// 若运算速度不够,可以使用q31代替f32,但是精度会降低
#define MatAdd arm_mat_add_f32
#define MatSubtract arm_mat_sub_f32
#define MatMultiply arm_mat_mult_f32
#define MatTranspose arm_mat_trans_f32
#define MatInverse arm_mat_inverse_f32
void MatInit(mat *m, uint8_t row, uint8_t col);
/* boolean type definitions */ /* boolean type definitions */
#ifndef TRUE #ifndef TRUE
#define TRUE 1 /**< boolean true */ #define TRUE 1 /**< boolean true */
@ -40,12 +49,6 @@
#define FALSE 0 /**< boolean fails */ #define FALSE 0 /**< boolean fails */
#endif #endif
/* math relevant */
/* radian coefficient */
#ifndef RADIAN_COEF
#define RADIAN_COEF 57.295779513f
#endif
/* circumference ratio */ /* circumference ratio */
#ifndef PI #ifndef PI
#define PI 3.14159265354f #define PI 3.14159265354f

View File

@ -1,3 +1,7 @@
# 利用Ozone进行model-based PID tunning # 利用Ozone进行model-based PID tunning
Ozone的实时变量可视化监测(示波器)功能可以很好地帮助我们观察控制器在时域的表现,典型的有上升时间、超调量和稳态时间等。 Ozone的实时变量可视化监测(示波器)功能可以很好地帮助我们观察控制器在时域的表现,典型的有上升时间、超调量和稳态时间等。
## 调试顺序
先内环,后外环。若有已知的外部扰动如阻力、重力等可以在**保持kp不变**的情况下添加积分环节,并查看达到稳态时积分的输出,该输出值可以作为**前馈**作用通过feedforward_ptr一同送入下一个串级控制器。