RK3588 PWM调试记录---linux pwm子系统驱动框架

news2025/1/12 7:54:24

一、RK3588 PWM简介

RK3588一共有4组PWM,每组有4个通道,共可以产生4*4=16路PWM波形;
PWM0 开始地址:0xfd8b0000
PWM1 开始地址:0xfebd0000
PWM2 开始地址:0xfebe0000
PWM3 开始地址:0xfebf0000
即每组PWM的地址空间是(0xfd8b0000-0xfebd0000=0x1000)64KB(0x1000/1024)
RK3588的PWM支持捕获、连续和单次触发三种模式。

1.捕获模式

用来测量由PWM通道时钟产生的PWM通道波形的高低有效波形,并且在PWM波形极性翻转时触发中断;高有效周期数记录在PWMx_PERIOD_HPC寄存器,低有效周期数记录在PWMx_DUTY_LPC寄存器中。捕获结果也可以保存在FIFO中,并且FIFO有一个指示器,该指示器也可以触发中断或者DMA请求。

2、连续模式

一旦PWM的通道被连续模式使能,即会产生连续的方波;波形有两种对齐方式:左对齐和中间对齐;
左对齐是先运行一个占空比,然后翻转。中间对齐是先运行占空比的一半,再翻转,再运行占空比的一半;简单来说,左对齐一个设定周期内PWM翻转一次而中间对齐则翻转两次。

3、单次触发模式

设定的周期内触发一次,也分为左对齐和中间对齐。

二、Firefly pwm demo的使用

首先在rk3588-firefly-itx-3588j.dts文件中,将demo的设备树使能;#include "rk3588-firefly-demo.dtsi"注释打开
在该demo的设备树中,有gpio_demo,adc_demo,pwm_demo,led_demo,几个例子,也分别有对应的驱动,有的需要在kernal中打开,有的默认已经打开,例如pwm的驱动程序名字叫pwm-firefly-demo.c,里面有一些具体的驱动实现,是参考rockchip的驱动文件pwm-rockchip.c来写的。但是该demo驱动有个问题,就是用户空间没有接口控制,在linux的pwm子系统的驱动中,我们可以通过命令行的方式来配置pwm,驱动是在/sys/bus/platform/drivers或者/sys/devices/platform中可以看到,例如

root@firefly:/sys/devices/platform# ls
 10f000.sram         fd5b0000.syscon             fdb60f00.iommu         fddf0000.i2s   fdf66400.qos              feaf0000.watchdog         power
 110000.ramoops      fd5b4000.syscon             fdb70000.rga           fddf4000.i2s   fdf66600.qos              feb20000.spi              psci
'Fixed MDIO bus.0'   fd5b5000.syscon             fdb70f00.iommu         fddf8000.i2s   fdf66800.qos              feb40000.serial           psci-cpuidle
 adc-keys            fd5b8000.syscon             fdb80000.rga           fdf35000.qos   fdf66a00.qos              feb60000.serial           pwm_demo
 arm-pmu             fd5bc000.syscon             fdb90000.jpegd         fdf35200.qos   fdf66c00.qos              feb70000.serial           reg-dummy
 av1d-master         fd5c0000.syscon             fdb90480.iommu         fdf35400.qos   fdf66e00.qos              feb90000.serial           regulatory.0
 clocks              fd5c4000.syscon             fdba0000.jpege-core    fdf35600.qos   fdf67000.qos              fec00000.tsadc            rkcif-mipi-lvds2
 cpufreq-dt          fd5c8000.syscon             fdba0800.iommu         fdf36000.qos   fdf67200.qos              fec10000.saradc           rkvenc-ccu
 cpuinfo             fd5cc000.syscon             fdba4000.jpege-core    fdf39000.qos   fdf70000.qos              fec20000.gpio             rockchip-system-monitor
 csi2-dphy0          fd5d0000.syscon             fdba4800.iommu         fdf3d800.qos   fdf71000.qos              fec30000.gpio             serial8250
 display-subsystem   fd5d4000.syscon             fdba8000.jpege-core    fdf3e000.qos   fdf72000.qos              fec40000.gpio             timer
 dmabuf              fd5d8000.syscon             fdba8800.iommu         fdf3e200.qos   fdf72200.qos              fec50000.gpio             uevent
 dmc                 fd5dc000.syscon             fdbac000.jpege-core    fdf3e400.qos   fdf72400.qos              fecc0000.otp              usbdrd3_0
 fb000000.gpu        fd5e0000.syscon             fdbac800.iommu         fdf3e600.qos   fdf80000.qos              fed10000.dma-controller   usbdrd3_1
 fc800000.usb        fd5e4000.syscon             fdbb0000.iep           fdf40000.qos   fdf81000.qos              fed90000.phy              vbus5v0-typec-pwr-en-regulator
 fc840000.usb        fd5e8000.syscon             fdbb0800.iommu         fdf40200.qos   fdf81200.qos              fedc0000.csi2-dphy0-hw    vcc-1v1-nldo-s3
 fc880000.usb        fd5ec000.syscon             fdbd0000.rkvenc-core   fdf40400.qos   fdf82000.qos              fee00000.phy              vcc-hub-reset-regulator
 fc8c0000.usb        fd5f0000.syscon             fdbdf000.iommu         fdf40500.qos   fdf82200.qos              fee10000.phy              vcc-hub3-reset-regulator
 fd104000.debug      fd880000.i2c                fdbe0000.rkvenc-core   fdf40600.qos   fe060000.dfi              fee80000.phy              vcc-sata-pwr-en-regulator
 fd10c000.cspmu      fd890000.serial             fdbef000.iommu         fdf40800.qos   fe170000.pcie             ff001000.sram             vcc12v-dcin
 fd588000.syscon     fd8a0000.gpio               fdc30000.rkvdec-ccu    fdf41000.qos   fe1b0000.ethernet         fiq-debugger              vcc3v3-pcie30
 fd58a000.syscon     fd8b0030.pwm                fdc38100.rkvdec-core   fdf41100.qos   fe1c0000.ethernet         fiq_debugger.0            vcc5v0-host
 fd58c000.syscon     fd8d8000.power-management   fdc38700.iommu         fdf60000.qos   fe210000.sata             firmware:optee            vcc5v0-host3
 fd590000.syscon     fda40000.pvtm               fdc48100.rkvdec-core   fdf60200.qos   fe2e0000.mmc              firmware:scmi             vcc5v0-sys
 fd592000.syscon     fda50000.pvtm               fdc48700.iommu         fdf60400.qos   fe378000.rng              firmware:sdei             vcc5v0-usb
 fd594000.syscon     fda60000.pvtm               fdc70000.av1d          fdf61000.qos   fe5a0000.hwspinlock       hdmiin-dc                 vcc5v0-usbdcin
 fd598000.syscon     fdab0000.npu                fdca0000.iommu         fdf61200.qos   fea10000.dma-controller   jpege-ccu                 wireless-bluetooth
 fd5a0000.syscon     fdab9000.iommu              fdce0000.rkcif         fdf61400.qos   fea30000.dma-controller   leds                      wireless-wlan
 fd5a2000.syscon     fdaf0000.pvtm               fdce0800.iommu         fdf62000.qos   fea50000.can              mpp-srv
 fd5a4000.syscon     fdb30000.pvtm               fdd30000.mipi2-csi2    fdf63000.qos   fea60000.can              mtd_vendor_storage
 fd5a6000.syscon     fdb50400.vdpu               fdd90000.vop           fdf64000.qos   fea90000.i2c              pcie30-avdd0v75
 fd5a8000.syscon     fdb50800.iommu              fdd97e00.iommu         fdf66000.qos   feab0000.i2c              pcie30-avdd1v8
 fd5ac000.syscon     fdb60000.rga                fddb0000.spdif-tx      fdf66200.qos   feae0000.timer            pinctrl

其中的fd8b0030.pwm就是启用的PWM,.前面的即是地址。
这跟设备树中的地址是对应的:
在这里插入图片描述
芯片手册中,也可以看到PWM的地址:
在这里插入图片描述
在这里插入图片描述

基地址0xfd8b0000+0x0030=0xfd8b0030即通道3的起始地址。

如果设备树启用了demo并且在内核也配置了该demo的使能,那么,platform设备和驱动目录下,是可以看到名字为firefy-pwm-demo的驱动和设备,并且在对应的io口也可以测量的设备树中设定的周期和占空比。但是具体的设定频率和占空比还需要在该驱动的基础上增加相关的设置接口才能使用。

三、linux pwm子系统驱动框架

rk3588也支持linux pwm子系统驱动框架下的pwm操作。
例如,我们将上面设备树中的pwm3的状态由disabled改为okay,那么我们可以在/sys/devices/platform/fd8b0030.pwm/pwm/pwmchip0或者/sys/class/pwm/pwmchi0将其导出。pwmchip0是启用的pwm通道数,如果将15路pwm全部启用,就会有15个类似的目录即从pwmchip0pwmchip14;
导出方式跟gpio类似:

# echo 0 > export
# cd pwm0/
# echo 10000 > period
# echo 5000 > duty_cycle
# echo normal > polarity
# echo 1 > enable
# ls
capture  duty_cycle  enable  output_type  period  polarity  power  uevent

上面的指令设置了周期10000,占空比50%,极性为normal的pwm输出。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/720718.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

追着 chatGPT 打的 Claude 跑不动了?!

claude 据说是 openai 公司的副总裁因理念不合,出走创建的 anthropic 公司发明的聊天机器人,和 chatGPT一样,智能聊天功能都很不错。 大致水平在 强chatGPT3.5 左右。 前期因为免费试用,反应速度非常快,对国内也没有…

2. 日志模块(上)

日志需求分析 无论对于业务系统还是中间件来说,日志都是必不可少的基础功能。完善、清晰地日志可以帮助我们观测系统运行的状态,并且快速定位问题。现在让我们站在 MyBatis 框架开发者的角度,来简单做一下日志功能的需求分析: 作…

1760_C语言中选择排序的实现

全部学习汇总: GreyZhang/c_basic: little bits of c. (github.com) 选择排序的实现思想跟冒泡排序的思想非常相近,二者的差一点在于:冒泡排序在比较交换的过程中交换的是两个位置的数据,而选择排序则是在遍历比较的过程中寻找最小…

web安全php基础_echo,print,print_r,var_dump 的用处及区别

echo & print 在 PHP 中有两个基本的输出方式: echo 和 print。 PHP echo 语句 echo 是一个语言结构,使用的时候可以不用加括号,也可以加上括号: echo 或 echo()。 显示字符串 下面的实例演示了如何使用 echo 命令输出字…

QtWebApp介绍、下载和搭建http轻量级服务器Demo

一、QtWebApp介绍 QtWepApp是一个C中的HTTP服务器库,其灵感来自Java Servlet。适用于Linux、Windows、Mac OS和Qt Framework支持的许多其他操作系统。   QtWebApp包含以下组件: • HTTP(S)1.0和1.1服务器 • 模板引擎 • 缓冲记录器   这些组件可以…

暑假第二天打卡

离散: (1)联结词集及其优先级 (2)真值表 真值表,最让人迷糊的就是p的真值是0,q的真值是0,p→q的真值是1,理解话虚假的前提可以推出任意结论 构造真值表关键在于从00……0开始&…

【单例模式】—— 每天一点小知识

💧 单例模式 \color{#FF1493}{单例模式} 单例模式💧 🌷 仰望天空,妳我亦是行人.✨ 🦄 个人主页——微风撞见云的博客🎐 🐳 《数据结构与算法》专栏的文章图文并茂🦕生动形…

点大商城V2_2.4.6 全开源版 百度+支付宝+QQ+头条+小程序端+unipp开源前端系统安装教程

播播资源了解到点大商城V2是一款采用全新界面设计支持多端覆盖的小程序应用,支持H5、微信公众号、微信小程序、头条小程序、支付宝小程序、百度小程序,本次测试全套安装的是序是点大商城V2独立版,包含全部插件,代码全开源&#xf…

java项目之高校二手交易平台(ssm+jsp+mysql)

风定落花生,歌声逐流水,大家好我是风歌,混迹在java圈的辛苦码农。今天要和大家聊的是一款基于ssm的高校二手交易平台。项目源码以及部署相关请联系风歌,文末附上联系信息 。 💕💕作者:风歌&…

Android中级——IPC

IPC IPC是什么?多进程带来的问题IPC前提SerializableParcelableBinder Android中的IPCBundle文件共享MessengerAIDLContentProviderSocket不同IPC优缺点 Binder连接池 IPC是什么? Inter-Process Communcation,含义为进程间通信或者跨进程通信…

NB-IoT学习笔记 —— NB-IoT介绍

一、简介 NB-IoT 是指窄带物联网(Narrow Band Internet of Things)技术,是一种低功耗广域(LPWA)网络技术标准,基于蜂窝技术,用于连接使用无线蜂窝网络的各种智能传感器和设备,聚焦于…

Vite+Vue3+Cesium工程搭建及初始化

现如今的前端更新太快了,我记得我一年前还在写 vue2+cesium 的工程构建方式。现在转眼都 vue3 了。而且 vite 也越来越火逐渐成为趋势。那么这篇文章我们就来介绍一下如何使用 vite 构建一个 vue3+cesium 的工程。 首先我们可以打开 vite 的官网学习如何构建 vite 项目。第一…

Nginx缓存代理服务器

Nginx缓存代理服务器 一、实验部署 二、搭建Nginx缓存代理服务器 1.nginx反向缓存代理服务配置 ###关闭和禁止防火墙开机自启功能 systemctl stop firewalld systemctl disable firewalld setenforce 0 sed -i s/enforcing/disabled/ /etc/selinux/config2.安装nginx服务 v…

基于SSM的人力资源管理系统

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:采用JSP技术开发 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#x…

剑指offer12.矩阵中的路径

太难了&#xff0c;想了一会儿没有头绪就直接看了题解。 class Solution {public boolean exist(char[][] board, String word) {int clowns board.length;int rows board[0].length;boolean[][] visited new boolean[clowns][rows];for(int i 0;i<clowns;i){for(int j0…

【QT】——QWidget窗口类

1.QWidget基本概念 QWidget 类是所有窗口类的父类 (控件类是也属于窗口类),QWidget 类的父类的 QObject, 也就意味着所有的窗口类对象只要指定了父对象, 都可以实现内存资源的自动回收.可以内嵌到其他窗口的内部&#xff0c;没有边框,需要指定父类窗口可以作为独立的窗口显示&…

DBeaver(一款非常好用的数据库管理工具)大批量数据导入导出非常友好

DBeaver(一款非常好用的数据库管理工具)大批量数据导入导出非常友好 背景说明&#xff1a; 最近因工作需要进行大批量的数据导入导出&#xff0c;很多工具都很难完成千万级以上的单表数据导入导出工作。后来找到了DBeaver这款工具&#xff0c;可以将千万级数据进行分批写入或导…

安装部署mysql

1.二进制方式安装 (1)下载压缩包 (2)创建用户和组 (3)解压 &#xff08;4&#xff09;创建软链接 (5)初始化 &#xff08;6&#xff09; 2.使用yum方式安装 (1)用yum install wget unzip bash-completion tree vim lrzsz net-tools -y命令安装常用软件 (2)用yum install mysql…

【数据仓库】FineBI数据可视化使用体验

FineBI介绍 FineBI是新一代自助式BI工具,企业客户多,服务范围广.凭借finebi简单流畅的操作,强劲的大数据性能和自助式的分析体验。 1&#xff0c;对个人用户来说&#xff0c;免费的无限期试用&#xff0c;解锁所有功能&#xff0c;除了限制两个并发访问&#xff0c;个人用户可以…

vue门户系统实现顶部菜单下拉效果

门户系统实现顶部菜单下拉效果 组件封装 直接上代码&#xff0c;已经封装成组件&#xff0c;只要传输正确的数据格式即可使用。 <template> <div class"head-v3" id"index"><div class"navigation-up"><div class"…