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 ...
随机推荐
- spark向量
转自 1.本地向量MLlib的本地向量主要分为两种,DenseVector和SparseVector,顾名思义,前者是用来保存稠密向量,后者是用来保存稀疏向量,其创建方式主要有一下三种(三种方式均创建 ...
- 外部表查询时出现ORA-29913和ORA-29400错误
create table t_ext_tab(id char(1),name char(6)) organization external( type oracle_loader default di ...
- java第一课:环境、变量、数据类型
一.java编程注意事项1.java区分大小写2.每条语句结尾有分号3.上下级代码注意缩进4.大括号要成对出现5.标点符号要用英文半角(半角全角区别)二.eclipse1.eclipse是自编译及时编 ...
- 第二天就跳票 将wikipedia上的英文词条翻译为中文 手动
忙着改简历一整天,刚说完一天一博,就要跳票了. 还是写点东西吧. 今天又翻译了一个维基百科上的条目,刚过一天就忘了怎么弄,还得回头翻帖子.在这先记一下,省的以后找不到. 1.注册个wiki账号,轻松过 ...
- AnimateWindow 阻塞当前线程问题
今天查了蛮多的,虽然不是系统的学习,收获也不小.下面说一下我的解决方法: 问题一:采用 AnimateWindow API实现消息窗体FormMsg的动画出现,但由于该方法会阻塞当前线程,造成其他窗体 ...
- 1042: [HAOI2008]硬币购物 - BZOJ
Description 硬币购物一共有4种硬币.面值分别为c1,c2,c3,c4.某人去商店买东西,去了tot次.每次带di枚ci硬币,买si的价值的东西.请问每次有多少种付款方法.Input 第一行 ...
- mysql 获取季度的第一天 本月的第一天,本周的第一天sql语句(转)
感谢:http://www.111cn.net/database/110/d45124323da8d2d87b80f78319987eda.htm 查看同主题的另一篇博客:http://blog.cs ...
- uva 825
这个......小学生就会的 坑在输入输出了 两个数之间可能不止一个空格....wa了好几遍啊 #include <cstdio> #include <cstring> # ...
- [mock]12月28日
假设我们有一个全局升序数组,这个数组长度unlimited现在我们有一个全局的指针和一个目标target值,target和指针你不可见.但是有以下几个操作bool istag();void gorig ...
- iOS开发--TableView详细解释
-.建立 UITableView DataTable = [[UITableView alloc] initWithFrame:CGRectMake(0, 0, 320, 420)]; [Data ...