106 lines
4.6 KiB
C
106 lines
4.6 KiB
C
/*********************************************************************************************************************
|
||
* CH32V307VCT6 Opensourec Library 即(CH32V307VCT6 开源库)是一个基于官方 SDK 接口的第三方开源库
|
||
* Copyright (c) 2022 SEEKFREE 逐飞科技
|
||
*
|
||
* 本文件是CH32V307VCT6 开源库的一部分
|
||
*
|
||
* CH32V307VCT6 开源库 是免费软件
|
||
* 您可以根据自由软件基金会发布的 GPL(GNU General Public License,即 GNU通用公共许可证)的条款
|
||
* 即 GPL 的第3版(即 GPL3.0)或(您选择的)任何后来的版本,重新发布和/或修改它
|
||
*
|
||
* 本开源库的发布是希望它能发挥作用,但并未对其作任何的保证
|
||
* 甚至没有隐含的适销性或适合特定用途的保证
|
||
* 更多细节请参见 GPL
|
||
*
|
||
* 您应该在收到本开源库的同时收到一份 GPL 的副本
|
||
* 如果没有,请参阅<https://www.gnu.org/licenses/>
|
||
*
|
||
* 额外注明:
|
||
* 本开源库使用 GPL3.0 开源许可证协议 以上许可申明为译文版本
|
||
* 许可申明英文版在 libraries/doc 文件夹下的 GPL3_permission_statement.txt 文件中
|
||
* 许可证副本在 libraries 文件夹下 即该文件夹下的 LICENSE 文件
|
||
* 欢迎各位使用并传播本程序 但修改内容时必须保留逐飞科技的版权声明(即本声明)
|
||
*
|
||
* 文件名称 zf_common_debug
|
||
* 公司名称 成都逐飞科技有限公司
|
||
* 版本信息 查看 libraries/doc 文件夹内 version 文件 版本说明
|
||
* 开发环境 MounRiver Studio V1.8.1
|
||
* 适用平台 CH32V307VCT6
|
||
* 店铺链接 https://seekfree.taobao.com/
|
||
*
|
||
* 修改记录
|
||
* 日期 作者 备注
|
||
* 2022-09-15 大W first version
|
||
********************************************************************************************************************/
|
||
|
||
#ifndef _zf_common_debug_h_
|
||
#define _zf_common_debug_h_
|
||
|
||
#include "zf_common_typedef.h"
|
||
#define PRINTF_ENABLE (1) // 使能 printf
|
||
|
||
// 如果修改串口并开启了 debug UART 的中断接收 需要同步更换 debug_interrupr_handler 函数到对应的中断服务函数
|
||
// 如果修改串口并开启了 debug UART 的中断接收 需要同步更换 debug_interrupr_handler 函数到对应的中断服务函数
|
||
// 如果修改串口并开启了 debug UART 的中断接收 需要同步更换 debug_interrupr_handler 函数到对应的中断服务函数
|
||
#define DEBUG_UART_INDEX (UART_1) // 指定 debug uart 所使用的的串口
|
||
#define DEBUG_UART_BAUDRATE (115200) // 指定 debug uart 所使用的的串口波特率
|
||
#define DEBUG_UART_TX_PIN (UART1_MAP0_TX_A9) // 指定 debug uart 所使用的的串口引脚
|
||
#define DEBUG_UART_RX_PIN (UART1_MAP0_RX_A10) // 指定 debug uart 所使用的的串口引脚
|
||
|
||
#define DEBUG_UART_USE_INTERRUPT (1) // 是否启用 debug uart 接收中断
|
||
|
||
//-------------------------------------------------------------------------------------------------------------------
|
||
// 函数简介 断言
|
||
// 参数说明 x 判断是否触发断言 0-触发断言 1-不触发断言
|
||
// 返回参数 void
|
||
// 使用示例 zf_assert(0);
|
||
// 备注信息 一般用于参数判断 zf_assert(0) 就断言报错
|
||
// 默认情况下会在 Debug UART 输出
|
||
// 但如果使用开源库内屏幕接口初始化了屏幕 则会在屏幕上显示
|
||
//-------------------------------------------------------------------------------------------------------------------
|
||
#define zf_assert(x) (debug_assert_handler((x), __FILE__, __LINE__))
|
||
|
||
//-------------------------------------------------------------------------------------------------------------------
|
||
// 函数简介 Log 信息输出
|
||
// 参数说明 x 判断是否触发输出 0-触发输出 1-不触发输出
|
||
// 参数说明 *str 需要输出的 Log 信息
|
||
// 返回参数 void
|
||
// 使用示例 zf_log(0, "Error");
|
||
// 备注信息 调试信息输出 用来做一些报错或者警告之类的输出
|
||
// 默认情况下会在 Debug UART 输出
|
||
// 但如果使用开源库内屏幕接口初始化了屏幕 则会在屏幕上显示
|
||
//-------------------------------------------------------------------------------------------------------------------
|
||
#define zf_log(x, str) (debug_log_handler((x), (str), __FILE__, __LINE__))
|
||
|
||
typedef struct
|
||
{
|
||
uint16 type_index;
|
||
|
||
uint16 display_x_max;
|
||
uint16 display_y_max;
|
||
|
||
uint8 font_x_size;
|
||
uint8 font_y_size;
|
||
|
||
void (*output_uart)(const char *str);
|
||
void (*output_screen)(uint16 x, uint16 y, const char *str);
|
||
void (*output_screen_clear)(void);
|
||
} debug_output_struct;
|
||
|
||
uint32 debug_send_buffer(const uint8 *buff, uint32 len);
|
||
#if DEBUG_UART_USE_INTERRUPT // 如果启用 debug uart 接收中断
|
||
#define DEBUG_RING_BUFFER_LEN (64) // 定义环形缓冲区大小 默认 64byte
|
||
void debug_interrupr_handler(void);
|
||
#endif
|
||
|
||
uint32 debug_read_ring_buffer(uint8 *buff, uint32 len);
|
||
void debug_assert_enable(void);
|
||
void debug_assert_disable(void);
|
||
void debug_assert_handler(uint8 pass, char *file, int line);
|
||
void debug_log_handler(uint8 pass, char *str, char *file, int line);
|
||
void debug_output_struct_init(debug_output_struct *info);
|
||
void debug_output_init(debug_output_struct *info);
|
||
void debug_init(void);
|
||
|
||
#endif
|