I.MX6 U-boot PWM hacking
/*******************************************************************************
* I.MX6 U-boot PWM hacking
* 说明:
* 本文主要记录I.MX6 U-boot是如何配置PWM,发现文中的pwm0对应的引脚和真正的
* 电路板的pwm0不是一个,也就意味着其实是引脚连接错了,另外之前一直有一个
* 疑问:为什么双屏显示的时候,有一个屏在U-boot阶段和Kernel阶段总是不亮。原因
* 应该是这里只初始化了一个显示控制部分,也就是不会初始两个PWM。
*
* 2016-3-7 深圳 南山平山村 曾剑锋
******************************************************************************/ cat bootable/bootloader/uboot-imx/board/freescale/mx6q_sabresd/mx6q_sabresd.c
......
#ifdef CONFIG_LCD
void lcd_enable(void)
{
......
imx_pwm_config(pwm0, , ); ------------+
imx_pwm_enable(pwm0); ------------*-+
| |
#if defined CONFIG_MX6Q | |
/* PWM backlight */ | |
mxc_iomux_v3_setup_pad(MX6Q_PAD_SD1_DAT3__PWM1_PWMO); | |
/* LVDS panel CABC_EN0 */ | |
mxc_iomux_v3_setup_pad(MX6Q_PAD_NANDF_CS2__GPIO_6_15); | |
/* LVDS panel CABC_EN1 */ | |
mxc_iomux_v3_setup_pad(MX6Q_PAD_NANDF_CS3__GPIO_6_16); | |
#elif defined CONFIG_MX6DL | |
/* PWM backlight */ | |
mxc_iomux_v3_setup_pad(MX6DL_PAD_SD1_DAT3__PWM1_PWMO); | |
/* LVDS panel CABC_EN0 */ | |
mxc_iomux_v3_setup_pad(MX6DL_PAD_NANDF_CS2__GPIO_6_15); | |
/* LVDS panel CABC_EN1 */ | |
mxc_iomux_v3_setup_pad(MX6DL_PAD_NANDF_CS3__GPIO_6_16); | |
#endif | |
...... | |
} | |
...... | |
| |
static struct pwm_device pwm0 = { <-----------+ |
.pwm_id = , | |
.pwmo_invert = , | |
}; | |
| |
| |
int imx_pwm_config(struct pwm_device pwm, int duty_ns, int period_ns) <----+ |
{ |
unsigned long long c; |
unsigned long period_cycles, duty_cycles, prescale; |
u32 cr; |
|
if (period_ns == || duty_ns > period_ns) |
return -; |
|
pwm.mmio_base = pwm.pwm_id ? (unsigned long)IMX_PWM2_BASE: |
(unsigned long)IMX_PWM1_BASE; |
|
if (pwm.pwmo_invert) |
duty_ns = period_ns - duty_ns; |
|
c = mxc_get_clock(MXC_IPG_PERCLK); |
c = c * period_ns; |
do_div(c, ); |
period_cycles = c; |
|
prescale = period_cycles / 0x10000 + ; |
|
period_cycles /= prescale; |
c = (unsigned long long)period_cycles * duty_ns; |
do_div(c, period_ns); |
duty_cycles = c; |
|
writel(duty_cycles, pwm.mmio_base + MX_PWMSAR); |
writel(period_cycles, pwm.mmio_base + MX_PWMPR); |
|
cr = MX_PWMCR_PRESCALER(prescale) | |
MX_PWMCR_STOPEN | MX_PWMCR_DOZEEN | |
MX_PWMCR_WAITEN | MX_PWMCR_DBGEN; |
|
cr |= MX_PWMCR_CLKSRC_IPG_HIGH; |
|
writel(cr, pwm.mmio_base + MX_PWMCR); |
|
return ; |
} |
|
int imx_pwm_enable(struct pwm_device pwm) <----------------+
{
unsigned long reg;
int rc = ; if (pwm.enable_pwm_clk)
pwm.enable_pwm_clk(); pwm.mmio_base = pwm.pwm_id ? (unsigned long)IMX_PWM2_BASE:
(unsigned long)IMX_PWM1_BASE; reg = readl(pwm.mmio_base + MX_PWMCR);
reg |= MX_PWMCR_EN;
writel(reg, pwm.mmio_base + MX_PWMCR); if (pwm.enable_pwm_pad)
pwm.enable_pwm_pad(); return rc;
}
I.MX6 U-boot PWM hacking的更多相关文章
- I.MX6 U-boot lvds display hacking
/*********************************************************************************** * I.MX6 U-boot ...
- I.MX6 Power off register hacking
/*********************************************************************** * I.MX6 Power off register ...
- I.MX6 android BatteryService jni hacking
/**************************************************************************** * I.MX6 android Batter ...
- I.MX6 Ar8031 device register hacking
/***************************************************************************** * I.MX6 Ar8031 device ...
- I.MX6 change boot partition 1 to User area
/************************************************************************************ * I.MX6 change ...
- I.MX6 PWM buzzer driver hacking with Demo test
/***************************************************************************** * I.MX6 PWM buzzer dr ...
- I.MX6 天嵌 E9 U-boot menu hacking
/************************************************************************************ * I.MX6 天嵌 E9 ...
- I.MX6 mfgtool2-android-mx6q-sabresd-emmc.vbs hacking
/******************************************************************** * I.MX6 mfgtool2-android-mx6q- ...
- I.MX6 gpio-keys driver hacking
/**************************************************************************** * I.MX6 gpio-keys driv ...
随机推荐
- Java单例模式--------懒汉式和饿汉式
单件模式用途:单件模式属于工厂模式的特例,只是它不需要输入参数并且始终返回同一对象的引用.单件模式能够保证某一类型对象在系统中的唯一性,即某类在系统中只有一个实例.它的用途十分广泛,打个比方,我们开发 ...
- iomanip,setw(),setw: undeclared identifier
今天使用setw(),提示setw: undeclared identifier,上网查了下,原来是没有包含头文件iomanip,现摘录如下: iomanip #include <iomanip ...
- 1 server - n clients 模型实现(select)
拓扑结构: 各个客户端创建读写管道,通过“上下线信息管道”向服务器发送上下线信息和读写管道名称.服务器接受信息,修改链表(存储客户端信息).客户端.服务器打开读写管道,服务器通过“W”管道接收从客户端 ...
- PAT乙级真题1005. 继续(3n+1)猜想 (25)(解题)
原题: 卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数.例如对n=3进行验证 ...
- (转)Qt Model/View 学习笔记 (七)——Delegate类
Qt Model/View 学习笔记 (七) Delegate 类 概念 与MVC模式不同,model/view结构没有用于与用户交互的完全独立的组件.一般来讲, view负责把数据展示 给用户,也 ...
- Android判断用户是平板还是手机的方法
public boolean isTabletDevice() { TelephonyManager telephony = (TelephonyManager) mContext.ge ...
- hadoop分布式安装教程(转)
from:http://www.cnblogs.com/xia520pi/archive/2012/05/16/2503949.html 1.集群部署介绍 1.1 Hadoop简介 Hadoop是Ap ...
- maven eclipse web项目流程(简化内容)
1.maven eclipse 环境搭建 1.1 下载解压配置环境变量(解压.环境变量maven目录到bin.setting.xml 改本地仓库) 1.2 eclipse插件安装配置(link安装.加 ...
- java8 新特性
[转载]:http://www.importnew.com/11908.html 本文由 ImportNew - 刘 家财 翻译自 javacodegeeks.欢迎加入翻译小组.转载请见文末要求. 编 ...
- A geometric interpretation of the covariance matrix
A geometric interpretation of the covariance matrix Contents [hide] 1 Introduction 2 Eigendecomposit ...