当前文档版本为 v0.4.1,您可以访问当前页面的 开发中 版本以获取最近可能的更新。

Driver: QDEC & PWM

1 功能概述

本文主要介绍PAN1080 EVB板QDEC外设模块的使用,检测外部PWM信号,触发QDEC计数。

2 环境要求

  • board: pan1080a_afld_evb

  • uart (option): 显示串口log

  • Panchip Serial Assistant V0.0.006.exe

3 编译和烧录

项目位置:zephyr\samples_panchip\drivers\qdec\qdec_pwm

目前可使用ZAL工具或quick build脚本进行编译和下载。

脚本位置:quick_build_samples\drivers\qdec_pwm.bat

打开脚本后默认会编译项目,编译完成时,可输入字符进行后续下载等操作:

Input the keyword to continue:
  'b' build                         编译项目
  'r' make clean and rebuild        重新编译项目
  'f' flash download                下载
  'e' erase chip                    擦除芯片
  'o' open project by VS Code       打开 `VS Code`,可查看源码,执行编译下载等
  others exit                       退出
wait input:

4 演示说明

  1. PAN1080 EVB板PIN脚接线说明:

    通道

    PIN脚

    PWM

    通道X0

    P04

    P02 PWM CH2

    通道X1

    P05

    P03 PWM CH3

    通道Y0

    P06

    P02 PWM CH2

    通道Y1

    P07

    P03 PWM CH3

    通道Z0

    P20

    P02 PWM CH2

    通道Z1

    P21

    P03 PWM CH3

  2. 例程中默认使用的是通道X0、和X1,向上计数和向下计数的结果如下图所示:

    向上计数:

    image

    QDEC例程向上计数Log

    向下计数:

    image

    QDEC例程向下计数Log

5 开发说明

5.1 启用QDEC模块

在prj.conf文件中添加“CONFIG_QDEC=y”启用qdec模块。

CONFIG_QDEC=y

5.2 初始QDEC

const struct device *qdec_dev = DEVICE_DT_GET(DT_NODELABEL(qdec));

5.3 配置QDEC

在“pan1080a_afld_evb.overlay”文件中添加QDEC参数配置:

&qdec {
	event-threshold = <100>;
	polarity = "polarity-low";
	resolution = "cnt-resolution-1x";
	filter-threshold = "filter-threshold-3";
	pinctrl-0 = <&p0_4_qdec_x0 &p0_5_qdec_x1>;
	status = "okay";
};

Config Type

Description

event-threshold

设置qdec事件触发阈值(此处是100)

polarity

设置qdec电平极性,可设置为高或者低电平有效(此处是低电平有效)

resolution

设置qdec分辨率,可设置为1x、2x、4x(此处是1x)

filter-threshold

设置qdec短脉冲过滤,设置范围为0~7(此处是3)

QDEC PIN脚配置:

pinctrl-0 = <&p0_4_qdec_x0 &p0_5_qdec_x1>;

配置X0、X1两个通道。

同理配置Y0、Y1和Z0、Z1两个通道

pinctrl-0 = <&p0_4_qdec_x0 &p0_5_qdec_x1 &p0_6_qdec_y0 &p0_7_qdec_y1 &p2_0_qdec_z0 &p2_1_qdec_z1>;

5.4 QDEC中断配置使能

通道配置:

uint8_t channel = QDEC_CNT_IDX_X;

qdec_clear_event_cnt(qdec_dev, channel);

代码默认配置通道X,也可配置成QDEC_CNT_IDX_Y、QDEC_CNT_IDX_Z。

qdec_irq_add_cb(qdec_dev, qdec_irq_cb);

qdec_clear_int_msk(qdec_dev, ENABLE, QDEC_INT_CNT_OVERFLOW_Msk | QDEC_INT_CNT_UNDERFLOW_Msk);
qdec_clear_event_cnt(qdec_dev, channel);
qdec_clear_int_flag(qdec_dev, QDEC_FUNC_ALL);
qdec_clear_raw_int_flag(qdec_dev, QDEC_FUNC_ALL);

qdec_set_enable(qdec_dev, ENABLE, QDEC_EN_Msk | QDEC_FILTER_EN_Msk |  (QDEC_CHANNEL_X_EN_Msk << channel) | QDEC_EVENT_EN_Msk);

注册中断回调函数“qdec_irq_cb”,配置通道X、向上计数和向下计数中断,清中断标志位。