Chipscope 仿真VmodCAM IIC程序
Chipscope 仿真VmodCAM IIC程序:
目的:熟悉EDK中建立chipscope
注意:zedboard使用digilent USB下载时,chipscope不能和SDK同时使用,否则芯片会死机。要用仿真器烧写程序。
1:搭建硬件平台
2:编写SDK软件
0x30,0x00,0x00,0x00, // Chip version. Default 0x1580 !! only for read !!
0x33,0x86,0x05,0x01, // MCU Reset
0x32,0x90,0x00,0x01, // test pattern
0x32,0x92,0x00,0x00, // R pattern
0x32,0x94,0x00,0xff, // G pattern
0x32,0x96,0x00,0x00, // B pattern
0x33,0x86,0x05,0x00, // MCU Release from reset
0x32,0x14,0x0D,0x85, // Slew rate control, PCLK 5, D 5
0x34,0x1E,0x8F,0x09, // PLL control; bypassed, powered down
0x34,0x1C,0x02,0x30, // PLL dividers; M=80,N=2,fMCLK=fCLKIN*M/(N+1)/8=24MHz
0x34,0x1E,0x8F,0x09, // PLL control; Power-up PLL; wait 1ms after this!
0x34,0x1E,0x8F,0x08, // PLL control; Turn off bypass
0x32,0x02,0x00,0x08, // Standby control; Wake up
0x33,0x8C,0x27,0x97, // Output format; Context B shadow
0x33,0x90,0x00,0x20, // RGB with BT656 codes
0x33,0x8C,0x27,0x2F, // Sensor Row Start Context B
0x33,0x90,0x00,0x04, // 4
0x33,0x8C,0x27,0x33, // Sensor Row End Context B
0x33,0x90,0x04,0xBB, // 1211
0x33,0x8C,0x27,0x31, // Sensor Column Start Context B
0x33,0x90,0x00,0x04, // 4
0x33,0x8C,0x27,0x35, // Sensor Column End Context B
0x33,0x90,0x06,0x4B, // 1611
0x33,0x8C,0x27,0x07, // Output width; Context B
0x33,0x90,0x02,0x80, // 640
0x33,0x8C,0x27,0x09, // Output height; Context B
0x33,0x90,0x01,0xE0, // 480
0x33,0x8C,0x27,0x5F, // Crop X0; Context B
0x33,0x90,0x00,0x00, // 0
0x33,0x8C,0x27,0x63, // Crop Y0; Context B
0x33,0x90,0x00,0x00, // 0
0x33,0x8C,0x27,0x61, // Crop X1; Context B
0x33,0x90,0x06,0x40, // 1600
0x33,0x8C,0x27,0x65, // Crop Y1; Context B
0x33,0x90,0x04,0xB0, // 1200
0x33,0x8C,0x27,0x41, // Sensor_Fine_IT_min B
0x33,0x90,0x01,0x69, // 361
0x33,0x8C,0xA1,0x20, // Capture mode options
0x33,0x90,0x00,0xF2, // Turn on AWB, AE, HG, Video
0x33,0x8C,0xA1,0x03, // Refresh Sequencer Mode
0x33,0x90,0x00,0x02, // Capture
0x33,0x90,0x00,0x00, // Read until sequencer in mode 0 (run)
0x30,0x1A,0x02,0xCC, // reset/output control; parallel enable, drive pins, start streaming
/*****************************************************************************/
/**
* This function is initial the iic_0.
*
* @param None.
*
* @return The number of bytes sent.
*
* @note None.
*
****************************************************************************/ int IIC_Initial( XIic *IicInstance, u16 DeviceId)
{ XIic_Config *IICConfigPtr; /* Pointer to configuration data */
Xil_AssertNonvoid(IicInstance != NULL);
/*
* Initialize the IIC driver so that it is ready to use.
*/
IICConfigPtr = XIic_LookupConfig(DeviceId);
if (IICConfigPtr == (XIic_Config *) NULL) {
IicInstance->IsReady = 0;
return (XST_DEVICE_NOT_FOUND);
}
return XIic_CfgInitialize(IicInstance, IICConfigPtr,IICConfigPtr->BaseAddress); }
int Vmod_CameraA_IIC_Config()
{
unsigned ByteCount=0;
int i = 0;
u8 ReadCamera_ChipVersion_Add[2] = {0x30,0x00};
u8 ReadCamera_ChipVersion_Rdata[2];
u16 Chip_Version = 0; printf("Here we go\n");
printf("Config the Camera\n");
read_camera_config(XPAR_CAMER_IIC_A_BASEADDR,ReadCamera_ChipVersion_Add,ReadCamera_ChipVersion_Rdata);
Chip_Version = (ReadCamera_ChipVersion_Rdata[0] << 8) | ReadCamera_ChipVersion_Rdata[1];
printf("Read Chip Version is:0x%x\n",Chip_Version);
for(i=0;i<MT9D112_CONFIG_BUFFER_ROWS;i++)
{
ByteCount += XIic_Send(XPAR_CAMER_IIC_A_BASEADDR,CAMERA_ADDRESS_ID,MT9D112_CONFIG_BUFFER[i],4,XIIC_STOP);
}
if(MT9D112_CONFIG_BUFFER_ROWS*4 == ByteCount)
{
printf("Camera Initialize success\n");
printf("Camera Initialize ByteCount is:%d\n",ByteCount);
return ByteCount;
}
else printf("Camera Initialize fail\n");
}
void read_camera_config (u32 BaseAddress, u8 *sub_addr, u8 *RdData)
{
u8 sent_byte_count;
u8 received_byte_count; RdData[0] = 0;
RdData[1] = 0; xil_printf("Read\t"); sent_byte_count = XIic_Send(BaseAddress, 0x78>>1, sub_addr, 2, XIIC_STOP); //write sub-address if (sent_byte_count != 2)
xil_printf("Sent %d bytes\t", sent_byte_count); received_byte_count = XIic_Recv(BaseAddress, 0x79>>1, RdData, 2, XIIC_STOP); //read 2 byte datas if (received_byte_count != 2)
xil_printf("Received %d bytes\r\n", received_byte_count);
else
xil_printf("0x%02x 0x%02x\r\n", RdData[0], RdData[1]); }
3:ChipScope 调试
4 VmodCAM
硬件写地址0x78 读地址0x79
访问方式:
1、通过直接的硬件寄存器访问
2、通过驱动变量进行配置,这种配置都是靠R[0X338C]与R[0X3390]两个硬件寄存器间接访问,R[0X338C]是选择驱动变量的寄存器,R[0X3390]则是设置对应驱动变量的值。
图 1 驱动变量地址
供电与复位:
配置操作:
寄存器上电的初始值
首先就可以读取摄像头的ID 地址是R[0X3000],读取的ID应该是0X1580.
然后复位MCU
PLL 时钟配置:
PLL配置包括R[0X341C]用于PLL输出(PCLK)频率设置。PCLK = MCLK*M/((N+1)/8), R[0X341E]用于设置PLL工作与否 还有旁路有否。如果想要旁路掉PLL那么R[0X341E]【0】必须设置为1,如果有功耗要求,可以将R[0X341E]【1】设置为1来关闭PLL 。如果要打开PLL,那么以上两位必须设置为0.在默认情况下,都是关闭和旁路掉PLL的。
Any changes to PLL settings must be done with PLL bypassed (R0x341E[0]=1). (当需要修改PLL的参数时必须保持PLL在旁路状态)
PLL programming and power-up sequence is as follows:
1. Program PLL frequency settings, R0x341C (pll_m, pll_n) (master clock frequency is
equal to fVCO_pll/8). With default settings master clock frequency of 80 MHz is
obtained with fCLKIN=16MHz.
2. Power up PLL, R0x341E[1] = 0.
3. Wait for PLL settling time > 1ms.
4. Turn off PLL bypass, R0x341E[0] = 0.
Chipscope 仿真VmodCAM IIC程序的更多相关文章
- STM32F10X -- 模拟IIC程序
听说STM32的IIC硬件做的很鸡肋,所以在这里通过模拟的方式实现IIC协议.此程序能成功对AT24C02操作. 程序中的带参数宏 IIC_DELAY(time)的功能是延时time us,在实际中具 ...
- 第2章 PLC1200 与HMI (TP900) 组合仿真连接 编写1200程序,编写HMI 仿真过程拍摄视频
博途V13 与 WINCC PROFESSIONAL V13 创建一个PLC工程 和屏幕的 练习. 在做S1200与 HMI的仿真之前 需要设置控制面板 设置PG/PC口 巡视窗口用于看设备的一些属性 ...
- matlab 调用C程序进行simulink仿真
文章目录 simulink仿真 创建C程序 编译C程序 运行结果 simulink仿真 simulink仿真中需要使用S-Function模块,可以实现调用C程序进行仿真,下面先建立一个简单的仿真: ...
- 基于KEIL4开发ARM9(S3C2440)的裸机程序
本文主要介绍如何使用Keil4开发ARM9(S3C2440)裸机程序. 说明: 一.平台: 操作系统:Windows XP系统 KEIL版本:4.73 开发板:ARM9(S3C2440) 二.建立工程 ...
- stm32软件模拟IIC读取PX4FLOW光流传感器数据
这段时间在做全国光电设计大赛,用到了px4的px4flow光流传感器,用软件模拟iic读取数据不定期会导致px4flow死机,查了资料和光流的源码,发现这个光流用了stm32的硬件iic,所以对软件模 ...
- ModelSim仿真入门
ModelSim仿真入门之一:软件介绍 编写这个教程之前,为了让不同水平阶段的人都能阅读,我尽量做到了零基础入门这个目标,所有的操作步骤都经过缜密的思考,做到了详细再详细的程度. 如果您是FPGA开发 ...
- 【译】基于主机的卡仿真(Host-based Card Emulation)
基于主机的卡仿真(Host-based Card Emulation) 能提供NFC功能很多Android手机已经支持NFC卡模拟.在大多数情况下,该卡是由设备中的单独的芯片仿真,所谓的安全元件.由无 ...
- ROS_Kinetic_x 基於ROS和Gazebo的RoboCup中型組仿真系統(多機器人協作)
國防科學技術大學發布了RoboCup中型組仿真平臺,基於ROS和Gazebo設計. 該平臺可以用於多機器人協作研究.參考資料如下: ROS新聞:1 http://www.ros.org/news ...
- DVB-C系统中QAM调制与解调仿真
本文简单记录一下自己学习<通信原理>的时候调试的一个仿真DVB-C(Cable,数字有线电视)系统中QAM调制和解调的程序.自己一直是研究"信源"方面的东西,所以对&q ...
随机推荐
- Android自定义窗口动画
第一步,设置出现和消失的xml 1.在res/anim下创建enter_anim.xml,设置窗口出现的动画 <?xml version="1.0" encoding=&qu ...
- WPF 之 资源(Resource)
1.什么叫WPF的资源(Resource)? 资源是保存在可执行文件中的一种不可执行数据.在WPF的资源中,几乎可以包含图像.字符串等所有的任意CLR对象,只要对象有一个默认的构造函数和独立的属性. ...
- Java连接mysql数据库并进行内容查询
最近用框架做了几个项目,感觉当初底层的东西有点忘了,写一个JDBC的简单的连接代码来熟悉回顾一下,也希望对刚接触的新手能有所帮助.这也是我的第一篇随笔,废话不多说,直接上代码: public Conn ...
- 小小的封装了一个pie的echarts
function showData(ele,arr1,arr2){ var myChart2 = echarts.init(document.getElementById(ele)); var opt ...
- setcookie 之 我见
$default_currency=get_default_currency(); $_COOKIE['currency'] = $default_currency['currency']; $_CO ...
- iOS - UI - UIStepper
7.UIStepper //计数器控件 固定宽高 UIStepper * stepper = [[UIStepper alloc] initWithFrame:CGRectMake(100, 10 ...
- 使用Xcode5开发时的icon取消高光效果
.在General中App Icons 使用Source--> AppIcon .在Images.xcassets 中依次添加对应尺寸的icon. .选中AppIcon ,在右侧第三个按钮下,勾 ...
- 关于MSSQL导入导出时主键与约束丢失的问题解决
导入数据时,使用默认选项,会丢失主键.约束.默认值等属性,按如下步骤操作: -->导出向导 -->选择数据源 -->选择目的 -->指定表复制或查询:不要使用默认选项,选择“在 ...
- php学习笔记7--php中的数组
php中的数组 1.数组的定义:显式方式:$arr = array(1,2,3,4,5); $arr1 = array('name'=>'dqrcsc','age'=>'24');隐式方式 ...
- DDL、DML和DCL的理解
一.DDL 1.DDL的概述 DDL(Data Definition Language 数据定义语言)用于操作对象和对象的属性,这种对象包括数据库本身,以及数据库对象,像:表.视图等等, ...