嵌入式驱动开发之解码器tvp5150---tvp5150am1基于8148vpss的添加调试
(1)i2c
(2)注册设备
(3)寄存器
--------------author:pkf
------------------------time:2015-4-5
-------------------------------qq:1327706646
(1)i2c
#define I2C_READ_REG_BYTE(reg) (*(volatile unsigned char *)(reg))
#define I2C_READ_REG_WORD(reg) (*(volatile unsigned short *)(reg))
#define I2C_READ_REG_LONG(reg) (*(volatile unsigned int *)(reg))
#define I2C_WRITE_REG_BYTE(val, reg) (*(volatile unsigned char *)(reg) = (val))
#define I2C_WRITE_REG_WORD(val, reg) (*(volatile unsigned short *)(reg) = (val))
#define I2C_WRITE_REG_LONG(val, reg) (*(volatile unsigned int *)(reg) = (val))
#define是预处理命令, 用来对关键字进行文本替换, 这里是不带参数的简单替换
把代码中I2C0CONSET替换为(*((volatile unsigned char *) 0xE001C000)) (volatile unsigned char *)括号里是类型, 是强制类型转换
把0xE001C000转换为这个类型的指针
指针除了要有地址,还要有地址里数据的类型, 没有类型的话计算机不知道是要读2个字节还是4个字节,也不知道是无符号还是有符号等等 volatile 是告诉编译器变量的值可能在不知道的情况下改变,防止编译器自动优化 再前面的*是指针解引用, 指针是unsigned char*的, 地址是0xE001C000, 解引用后就是0xE001C000里存的unsigned char值
(2)注册设备
gVps_tvp5150CommonObj.fvidDrvOps.create
= (FVID2_DrvCreate)Vps_tvp5150Create;
gVps_tvp5150CommonObj.fvidDrvOps.delete = Vps_tvp5150Delete;
gVps_tvp5150CommonObj.fvidDrvOps.control = Vps_tvp5150Control;
gVps_tvp5150CommonObj.fvidDrvOps.queue = NULL;
gVps_tvp5150CommonObj.fvidDrvOps.dequeue = NULL;
gVps_tvp5150CommonObj.fvidDrvOps.processFrames = NULL;
gVps_tvp5150CommonObj.fvidDrvOps.getProcessedFrames = NULL;
gVps_tvp5150CommonObj.fvidDrvOps.drvId = FVID2_VPS_VID_DEC_TVP5150_DRV;
status = FVID2_registerDriver ( &gVps_tvp5150CommonObj.fvidDrvOps );//registerDriver !!!!
(3)寄存器
static const UInt8 gTvp5150DefAddrList[] =
{
/* 0x00 */
TVP5150_VD_IN_SRC_SEL_1,
/* 0x01 */
TVP5150_ANAL_CHL_CTL,
/* 0x02 */
TVP5150_OP_MODE_CTL,
/* 0x03 */
TVP5150_MISC_CTL,
/* 0x06 */
TVP5150_COLOR_KIL_THSH_CTL,
/* 0x07 */
TVP5150_LUMA_PROC_CTL_1,
/* 0x08 */
TVP5150_LUMA_PROC_CTL_2,
/* 0x09 */
TVP5150_BRIGHT_CTL,
/* 0x0a */
TVP5150_SATURATION_CTL,
/* 0x0b */
TVP5150_HUE_CTL,
/* 0x0c */
TVP5150_CONTRAST_CTL,
/* 0x0d */
TVP5150_DATA_RATE_SEL,
/* 0x0e */
TVP5150_LUMA_PROC_CTL_3,
/* 0x0f */
TVP5150_CONF_SHARED_PIN,
/* 0x11 */
TVP5150_ACT_VD_CROP_ST_MSB,
/* 0x12 */
TVP5150_ACT_VD_CROP_ST_LSB,
/* 0x13 */
TVP5150_ACT_VD_CROP_STP_MSB,
/* 0x14 */
TVP5150_ACT_VD_CROP_STP_LSB,
/* 0x15 */
TVP5150_GENLOCK,
/* 0x16 */
TVP5150_HORIZ_SYNC_START,
/* 0x18 */
TVP5150_VERT_BLANKING_START,
/* 0x19 */
TVP5150_VERT_BLANKING_STOP,
/* 0x1a */
TVP5150_CHROMA_PROC_CTL_1,
/* 0x1b */
TVP5150_CHROMA_PROC_CTL_2,
/* 0x1c */
TVP5150_INT_RESET_REG_B,
/* 0x1d */
TVP5150_INT_ENABLE_REG_B,
/* 0x1e */
TVP5150_INTT_CONFIG_REG_B,
/* 0x28 */
TVP5150_VIDEO_STD,
/* 0x2e */
TVP5150_MACROVISION_ON_CTR,
/* 0x2f */
TVP5150_MACROVISION_OFF_CTR,
/* 0xbb */
TVP5150_TELETEXT_FIL_ENA,
/* 0xc0 */
TVP5150_INT_STATUS_REG_A,
/* 0xc1 */
TVP5150_INT_ENABLE_REG_A,
/* 0xc2 */
TVP5150_INT_CONF,
/* 0xc8 */
TVP5150_FIFO_INT_THRESHOLD,
/* 0xc9 */
TVP5150_FIFO_RESET,
/* 0xca */
TVP5150_LINE_NUMBER_INT,
/* 0xcb */
TVP5150_PIX_ALIGN_REG_LOW,
/* 0xcc */
TVP5150_PIX_ALIGN_REG_HIGH,
/* 0xcd */
TVP5150_FIFO_OUT_CTRL,
/* 0xcf */
TVP5150_FULL_FIELD_ENA,
/* 0xd0 */
TVP5150_LINE_MODE_INI,
/* 0xfc */
TVP5150_FULL_FIELD_MODE_REG,
/* end of data */
};
bug:
两边黑边条
http://www.deyisupport.com/question_answer/dsp_arm/f/22/t/78878.aspx
http://wenku.baidu.com/link?url=YLPPzB8Oi8HyhJ18SatBVb-KKaZhvMZfa6-sJEVLeXS49ke73jKWnTO-NbNZMCZ-oH21XslAwKICrEOF-vzUbP6XbrP20d6jW6COdDC8_9W
http://wenku.baidu.com/link?url=x4DUS1hsOaIRCWPAVEmJiPDWcLRjhVR-KQS3miT43B8LoiiRRQFkvEkwOICDwDgGHzB25yK8slMtCjwd9-cqWUTFhkhUxNAYH9tPjbnmEdG
http://wenku.baidu.com/view/d7e6b81810a6f524ccbf8508.html?re=view
http://wenku.baidu.com/view/4a5a957502768e9951e7385b.html?re=view
http://www.deyisupport.com/question_answer/dsp_arm/davinci_digital_media_processors/f/39/t/69596.aspx
http://www.ti.com/product/tvp5150am1 ti官网文档
http://www.ti.com/product/TVP5150AM1/technicaldocuments
http://www.deyisupport.com/question_answer/dsp_arm/f/22/t/17389.aspx?pi2132219853=2
http://www.deyisupport.com/question_answer/dsp_arm/f/22/t/22508.aspx
http://www.deyisupport.com/question_answer/dsp_arm/f/22/p/17389/96069.aspx#96069
http://e2e.ti.com/support/dsp/davinci_digital_media_processors/f/100/p/314811/1095670#1095670
http://www.deyisupport.com/question_answer/dsp_arm/davinci_digital_media_processors/f/39/t/52747.aspx?pi2132219853=3 集成
http://blog.csdn.net/duloveding/article/details/7756328 问题
http://www.deyisupport.com/question_answer/dsp_arm/davinci_digital_media_processors/f/39/t/13981.aspx 移植
http://blog.chinaunix.net/uid-21354120-id-1827536.html i2c
http://www.deyisupport.com/blog/b/av_tech/archive/2011/07/20/tvp5150xxx-tvp5151.aspx ti 官网提供
http://e2e.ti.com/support/data_converters/videoconverters/f/918/t/319432 am1
http://e2e.ti.com/support/data_converters/videoconverters/f/918/tags/TVP5150
http://www.ti.com/lit/ug/sleu044/sleu044.pdf 手册
http://e2e.ti.com/support/dsp/davinci_digital_media_processors/f/100/p/314811/1095670#1095670 grey
http://www.cnblogs.com/syfwhu/p/4432736.html 腾讯前端
http://www.cnblogs.com/tracyone/p/4431698.html ipnc web dba
http://www.ti.com/lit/sg/slyb112a/slyb112a.pdf 手册
http://www.ti.com/lit/ug/sleu044/sleu044.pdf
http://www.ti.com/lit/ug/sleu044/sleu044.pdf
http://blog.csdn.net/linglongyouzhi/article/details/4284581 赛灵思fpga 处理
http://www.ic37.com/TI/TVP51_datasheet_9586173/TVP51_35.html
http://www.ti.com.cn/cn/lit/ml/sprt552/sprt552.pdf
http://wenku.baidu.com/link?url=x4DUS1hsOaIRCWPAVEmJiPDWcLRjhVR-KQS3miT43B8LoiiRRQFkvEkwOICDwDgGHzB25yK8slMtCjwd9-cqWUTFhkhUxNAYH9tPjbnmEdG 5150a 中文手册
http://blog.163.com/laorenyuhai126@126/blog/static/19350779201111223328406/
嵌入式驱动开发之解码器tvp5150---tvp5150am1基于8148vpss的添加调试的更多相关文章
- 驱动开发学习笔记. 0.02 基于EASYARM-IMX283 烧写uboot和linux系统
驱动开发读书笔记. 0.02 基于EASYARM-IMX283 怎么烧写自己裁剪的linux内核?(非所有arm9通用) 手上有一块tq2440,但是不知道什么原因,没有办法烧boot进norflas ...
- 嵌入式驱动开发之---Linux ALSA音频驱动(一)
本文的部分内容参考来自DroidPhone的博客(http://blog.csdn.net/droidphone/article/details/6271122),关于ALSA写得很不错的文章,只是少 ...
- IT自由职业者的第一个月(下)——为什么放弃5年嵌入式驱动开发转到WEB开发?
如果单从兴趣来看,其实我对Linux内核,Android中间件的兴趣要高于WEB,何况还有这么多年的经验积累,何必从头探索一个新的技术方向呢? 这里面原因是很多的,最核心的大概是以下4 ...
- 嵌入式驱动开发之--- 虚拟磁盘SBULL块设备驱动程序分析
#define SBULL_MINORS 16 /* 每个sbull设备所支持的次设备号的数量 */ #define KERNEL_SECTOR_SIZE 512 // 本地定 ...
- 嵌入式驱动开发之内核态spi ---module_spi_driver
http://blog.csdn.net/dearsq/article/details/51839083 http://blog.csdn.net/alleincao/article/details/ ...
- 嵌入式驱动开发只设备数---dts
http://blog.sina.com.cn/s/blog_ad64b8200101e7q0.html
- 嵌入式驱动开发之采集方式bypass mode---bypass mode
http://baike.baidu.com/link?url=HifFTlNRROR24lW_gSdTiG-eXooi08O0Eeq1mU6Yy0I1LOMW4kdumv25BOQbohV_428M ...
- 嵌入式驱动开发之---dm8127 中sensor 驱动的改变
#IPNC_DEVICE := DM385IPNC_DEVICE := DM812x # Values are "LOW_POWER" and "FULL_FEATURE ...
- 转: 嵌入式linux下usb驱动开发方法--看完少走弯路【转】
转自:http://blog.csdn.net/jimmy_1986/article/details/5838297 嵌入式linux下的usb属于所有驱动中相当复杂的一个子系统,要想将她彻底征服,至 ...
随机推荐
- vue 项目心得
v-bind 数据绑定 可以简写成 : 通过 props 将数据对象 传给 组件 export default { props: { seller: { type: Object } } } crea ...
- 生成批量删除多个表sql语句
--批量删除多个表 select 'drop table ' +name from sysobjects where type = 'U' order by name
- SSH面试题目
一简答 spring工作原理 为什么要用spring 3.请你谈谈SSH整合 4.介绍一下Spring的事务管理 5.Struct2基本流程 6.在Hibernate应用中Java对象的状态有哪些? ...
- winfrom cahce 问题
.Clear()不能随便用 .Clear()的比较没有什么意思,因为只是把DataTable清空而已,在堆中任然分配内存,一般要比较也是比较Close()方法,不过DataTable没有这个方法 至于 ...
- oracle 事务多表查询以及额外的用处
/* 以下代码是对emp表进行显示宽度设置*/ col empno for 9999;col ename for a10;col job for a10;col mgr for 9999;col hi ...
- 使用Nexus创建私服
原文链接:http://www.cnblogs.com/helong/articles/2254446.html 注意:nexus2.6.0版本以后不支持jdk6了,必须jdk1.7或以上. 参考:h ...
- JS经验库
1.IE状态栏无法结束的问题 function clearStatusBar(){ this.bd = document.body; this.tmp = document.creatElement( ...
- C语言指针的易错点
1.内存泄漏:申请的堆内存没有释放. 2.内存污染:前面非法操作使用内存(没有报错),后面写着写着就出错.如下代码: 当结构体中只有划线部分代码时,在编译器中编写不会报错,但此时已经造成非法操作内存, ...
- STM32关总中断的语句
__set_PRIMASK();//关总中断 /************ **********/ __set_PRIMASK();//开总中断
- 点滴积累【C#】---C#实现下载word
效果: 思路: 简单的有两种方式下载,一种是流下载,一种是WriteFile下载.以下是使用WriteFile下载. 代码: protected void LinkButton1_Click(obje ...