write_chip,read_chip
int write_chip(UINT32 addr, UINT32 data)
{
if(0 == fpgaRWMode) /* localbus mode */
{
UINT16 datah, datal;
UINT32 dataread;
datah = (UINT16)(data >> 16);
FPGA_REG(addr) = datah;
rwWait(60);
datal = (UINT16)(data & 0xFFFF);
FPGA_REG(addr) = datal;
rwWait(60);
#if 0
read_chip(addr, &dataread);
if (data != dataread)
{
printf("ERROR:write 0x%08X; read 0x%08X\n", data, dataread);
return OK;
}
#endif
read_chip(addr, (UINT32 *)(&dataread));
if(print_level == 1)
printf("spi write 0x%05X: 0x%08X\n", addr, data);
return OK;
}
else if(1 == fpgaRWMode) /* i2c mode */
{
int ret = 0;
ret = fpgaMAC_i2c_write(0,0,0,addr,(unsigned char *)(&data),4);
if(print_level == 1)
{
if(ret != 0)
printf("spi write failed! read 0x%05x: 0x%08x\n", addr, data);
else
printf("spi write 0x%05x: 0x%08x\n", addr, data);
}
if(!ret)
return OK;
else
return ERROR;
}
else if(2 == fpgaRWMode) /* spi mode */
{
int ret = 0;
unsigned char *wtBuff = (unsigned char *)malloc(8);
if(NULL == wtBuff)
{
printf("No memory!\n");
return -1;
}
*wtBuff = (unsigned char)((data>>24) & 0xff);
*(wtBuff+1) = (unsigned char)((data>>16) & 0xff);
*(wtBuff+2) = (unsigned char)((data>>8 ) & 0xff);
*(wtBuff+3) = (unsigned char)((data ) & 0xff);
ret = fpga_spi_write(addr,(unsigned char *)(wtBuff),4);
if(print_level == 1)
{
if(ret != 0)
printf("spi write failed! read 0x%05x: 0x%08x\n", addr, data);
else
printf("spi write 0x%05x: 0x%08x\n", addr, data);
}
free(wtBuff);
if(!ret)
return OK;
else
return ERROR;
}
else
{
return ERROR;
}
}
int read_chip(UINT32 addr, UINT32 *data)
{
if(data == NULL)
return ERROR;
if(0 == fpgaRWMode) /* localbus mode */
{
UINT16 datah, datal;
datah = FPGA_REG(addr);
rwWait(60);
datal = FPGA_REG(addr);
rwWait(60);
*data = datal + (((UINT32)datah) << 16);
if(print_level == 1)
printf("localbus read 0x%05X: 0x%08X\n", addr, *data);
return OK;
}
else if(1 == fpgaRWMode) /* i2c mode */
{
int ret = 0;
ret = fpgaMAC_i2c_read(0,0,0,addr,(unsigned char *)data,4);
if(print_level == 1)
{
if(ret != 0)
printf("i2c read failed! read 0x%05x: 0x%08x\n", addr, *data);
else
printf("i2c read 0x%05x: 0x%08x\n", addr, *data);
}
if(!ret)
return OK;
else
return ERROR;
}
else if(2 == fpgaRWMode) /* spi mode */
{
int ret = 0;
ret = fpga_spi_read(addr,(unsigned char *)data,4);
if(print_level == 1)
{
if(ret != 0)
printf("spi read failed! read 0x%05x: 0x%08x\n", addr, *data);
else
printf("spi read 0x%05x: 0x%08x\n", addr, *data);
}
if(!ret)
return OK;
else
return ERROR;
}
else
{
return ERROR;
}
}
write_chip,read_chip的更多相关文章
- Pyhton开源框架(加强版)
info:Djangourl:https://www.oschina.net/p/djangodetail: Django 是 Python 编程语言驱动的一个开源模型-视图-控制器(MVC)风格的 ...
- MPlayer
名称 mplayer − 电影播放器 mencoder − 电影编解码器 概要 mplayer [选项] [文件|URL|播放列表|−] mplayer [选项] 文件1 [指定选项] [文件 ...
- python 爬取腾讯微博并生成词云
本文以延参法师的腾讯微博为例进行爬取并分析 ,话不多说 直接附上源代码.其中有比较详细的注释. 需要用到的包有 BeautifulSoup WordCloud jieba # coding:utf-8 ...
- 面经 cisco
1. 优先级反转问题及解决方法 (1)什么是优先级反转 简单从字面上来说,就是低优先级的任务先于高优先级的任务执行了,优先级搞反了.那在什么情况下会生这种情况呢? 假设三个任务准备执行,A,B,C,优 ...
- linux驱动(续)
网络通信 --> IO多路复用之select.poll.epoll详解 IO多路复用之select.poll.epoll详解 目前支持I/O多路复用的系统调用有 select,psel ...
- HttpServletRequest对象(一)
javaweb学习总结(十)——HttpServletRequest对象(一) 一.HttpServletRequest介绍 HttpServletRequest对象代表客户端的请求,当客户端通过HT ...
- 故障重现(内存篇2),JAVA内存不足导致频繁回收和swap引起的性能问题
背景起因: 记起以前的另一次也是关于内存的调优分享下 有个系统平时运行非常稳定运行(没经历过大并发考验),然而在一次活动后,人数并发一上来后,系统开始卡. 我按经验开始调优,在每个关键步骤的加入如 ...
- 先说IEnumerable,我们每天用的foreach你真的懂它吗?
我们先思考几个问题: 为什么在foreach中不能修改item的值? 要实现foreach需要满足什么条件? 为什么Linq to Object中要返回IEnumerable? 接下来,先开始我们的正 ...
- JavaScript之父Brendan Eich,Clojure 创建者Rich Hickey,Python创建者Van Rossum等编程大牛对程序员的职业建议
软件开发是现时很火的职业.据美国劳动局发布的一项统计数据显示,从2014年至2024年,美国就业市场对开发人员的需求量将增长17%,而这个增长率比起所有职业的平均需求量高出了7%.很多人年轻人会选择编 ...
随机推荐
- [译]Java Thread Sleep示例
Java Thread Sleep示例 java.lang.Thread sleep(long millis)方法被用来暂停当前线程的执行,暂停时间由方法参数指定,单位为毫秒.注意参数不能为负数,否则 ...
- tortoiseGit的SHH秘钥设置
tortoiseGit如果安装时使用默认的putty方式,因为putty的秘钥格式和SSH的不一样,所以要使用自带的工具重新生成一次秘钥. 具体的方式是:用puttyGen工具来生成公钥和秘钥,公钥( ...
- CCNP第二天 帧中继综合实验
实验题如图所示: 要求全网可达 R5为帧中继交换机 R6 和 R1之间为快速以太网接口 所使用的拓扑为CCNA标准版拓扑图,如下所示: -------------------------------- ...
- 1079. Total Sales of Supply Chain (25)
时间限制 250 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue A supply chain is a network of r ...
- JS禁用浏览器退格键
我们在真实的项目开发中经常会使用JS 对键盘上的一些按键进行禁用,常见的比如说退格键(backspace/ 后退键),我在一个项目中就遇到过在页面编辑的时候禁用掉退格键,因为退格键会发生页面后退,代码 ...
- C#...何时需要重写ToString()方法?
一般类型,都是继承自System.Object类,默认情况下,object类的ToString方法会返回当前类的类型的字符串表达形式.但也有例外!! DateTime,它就重写ToString方法,D ...
- Ubuntu Linux启用root用户登录
Ubuntu Linux有一个与众不同的特点,那就是初次使用时,你无法作为root来登录系统,为什么会这样?这就要从系统的安装说起.对于其他Linux系统来 说,一般在安装过程就设定root密码,这样 ...
- 1054: [HAOI2008]移动玩具 - BZOJ
Description 在一个4*4的方框内摆放了若干个相同的玩具,某人想将这些玩具重新摆放成为他心中理想的状态,规定移动时只能将玩具向上下左右四个方向移动,并且移动的位置不能有玩具,请你用最少的移动 ...
- JS日期格式化(网上转载)
JS日期格式化(网上转载) <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <ht ...
- js中批量处理样式——cssText的使用
http://www.cnblogs.com/snandy/archive/2011/03/12/1980444.html