共2条
1/1 1 跳转至页

问
我在xilinx 中想对flash进行擦除和写入操作,先发擦除命令,但不知为什么总是擦除不成功,感觉时序也没有问题了,想不出问题还能在哪里?我用的flash 是 am29lv040b,512k, 8位的。
//====================================================
#include "xparameters.h"
#include "xcache_l.h"
#include "stdio.h"
#include "xutil.h"
//====================================================
int main (void)
{
long int i=0;
int j=0;
char*cmdAddr=
(char*)XPAR_GENERIC_EXTERNAL_MEMORY_MEM0_BASEADDR;
XCache_EnableICache(0x80000000);
XCache_EnableDCache(0x80000000);
print("-- Entering main() --\r\n");
xil_printf("enter erase\n ");
{
cmdAddr[0x555] = 0xaa;
cmdAddr[0x2aa] = 0x55;
cmdAddr[0x555] = 0x80;
cmdAddr[0x555] = 0xaa;
cmdAddr[0x2aa] = 0x55;
cmdAddr[0x555] = 0x10;
xil_printf("%08x \n",cmdAddr); //此处可以正常输出为 0x05000000,flash的基址
for(i=0;i<500000000;i++); // 大约20多秒的延时,以便擦除完成
}
for(i=0;i<2*1024;i++) //输出前2K个字节与原来的进行比较,看是否擦除了。
{ //事实上并没有擦除。不知为何
xil_printf(" %02x ",cmdAddr[i]);
if((i+1)%16==0)
xil_printf("\n ");
}
print("-- Exiting main() --\r\n");
return 0;
}
以下是MHS部分文档
//emc
BEGIN opb_emc
PARAMETER INSTANCE = Generic_External_Memory
PARAMETER HW_VER = 2.00.a
PARAMETER C_MAX_MEM_WIDTH = 8
PARAMETER C_MEM0_WIDTH = 8
PARAMETER C_SYNCH_MEM_0 = 0
PARAMETER C_OPB_CLK_PERIOD_PS = 15151
PARAMETER C_NUM_BANKS_MEM = 1
PARAMETER C_INCLUDE_DATAWIDTH_MATCHING_0 = 1
PARAMETER C_TCEDV_PS_MEM_0 = 150000
PARAMETER C_TWC_PS_MEM_0 = 150000
PARAMETER C_TAVDV_PS_MEM_0 = 150000
PARAMETER C_TWP_PS_MEM_0 = 60000
PARAMETER C_THZCE_PS_MEM_0 = 70000
PARAMETER C_TLZWE_PS_MEM_0 = 0
PARAMETER C_MEM0_BASEADDR = 0x05000000
PARAMETER C_MEM0_HIGHADDR = 0x0507ffff
BUS_INTERFACE SOPB = opb
PORT OPB_Clk = sys_clk_s
PORT Mem_DQ = fpga_0_Generic_External_Memory_Mem_DQ
PORT Mem_A = fpga_0_Generic_External_Memory_Mem_A
# PORT Mem_BEN = fpga_0_Generic_External_Memory_Mem_BEN #datasheet 中没有这一位
PORT Mem_WEN = fpga_0_Generic_External_Memory_Mem_WEN
PORT Mem_OEN = fpga_0_Generic_External_Memory_Mem_OEN
PORT Mem_CEN = fpga_0_Generic_External_Memory_Mem_CEN
# PORT Mem_RPN = fpga_0_Generic_External_Memory_Mem_RPN #不知#道这个做什么的,对读出并没有影响,对擦除呢??
END
这个问题我做了好久了,还是没有解决。大家帮忙看看
答 1: 帮忙看看.帮忙看看. 答 2: 时序没问题了?呵呵。
先看看DataSheet吧。
可以先试着读出几个ID,确认硬件OK......
//====================================================
#include "xparameters.h"
#include "xcache_l.h"
#include "stdio.h"
#include "xutil.h"
//====================================================
int main (void)
{
long int i=0;
int j=0;
char*cmdAddr=
(char*)XPAR_GENERIC_EXTERNAL_MEMORY_MEM0_BASEADDR;
XCache_EnableICache(0x80000000);
XCache_EnableDCache(0x80000000);
print("-- Entering main() --\r\n");
xil_printf("enter erase\n ");
{
cmdAddr[0x555] = 0xaa;
cmdAddr[0x2aa] = 0x55;
cmdAddr[0x555] = 0x80;
cmdAddr[0x555] = 0xaa;
cmdAddr[0x2aa] = 0x55;
cmdAddr[0x555] = 0x10;
xil_printf("%08x \n",cmdAddr); //此处可以正常输出为 0x05000000,flash的基址
for(i=0;i<500000000;i++); // 大约20多秒的延时,以便擦除完成
}
for(i=0;i<2*1024;i++) //输出前2K个字节与原来的进行比较,看是否擦除了。
{ //事实上并没有擦除。不知为何
xil_printf(" %02x ",cmdAddr[i]);
if((i+1)%16==0)
xil_printf("\n ");
}
print("-- Exiting main() --\r\n");
return 0;
}
以下是MHS部分文档
//emc
BEGIN opb_emc
PARAMETER INSTANCE = Generic_External_Memory
PARAMETER HW_VER = 2.00.a
PARAMETER C_MAX_MEM_WIDTH = 8
PARAMETER C_MEM0_WIDTH = 8
PARAMETER C_SYNCH_MEM_0 = 0
PARAMETER C_OPB_CLK_PERIOD_PS = 15151
PARAMETER C_NUM_BANKS_MEM = 1
PARAMETER C_INCLUDE_DATAWIDTH_MATCHING_0 = 1
PARAMETER C_TCEDV_PS_MEM_0 = 150000
PARAMETER C_TWC_PS_MEM_0 = 150000
PARAMETER C_TAVDV_PS_MEM_0 = 150000
PARAMETER C_TWP_PS_MEM_0 = 60000
PARAMETER C_THZCE_PS_MEM_0 = 70000
PARAMETER C_TLZWE_PS_MEM_0 = 0
PARAMETER C_MEM0_BASEADDR = 0x05000000
PARAMETER C_MEM0_HIGHADDR = 0x0507ffff
BUS_INTERFACE SOPB = opb
PORT OPB_Clk = sys_clk_s
PORT Mem_DQ = fpga_0_Generic_External_Memory_Mem_DQ
PORT Mem_A = fpga_0_Generic_External_Memory_Mem_A
# PORT Mem_BEN = fpga_0_Generic_External_Memory_Mem_BEN #datasheet 中没有这一位
PORT Mem_WEN = fpga_0_Generic_External_Memory_Mem_WEN
PORT Mem_OEN = fpga_0_Generic_External_Memory_Mem_OEN
PORT Mem_CEN = fpga_0_Generic_External_Memory_Mem_CEN
# PORT Mem_RPN = fpga_0_Generic_External_Memory_Mem_RPN #不知#道这个做什么的,对读出并没有影响,对擦除呢??
END
这个问题我做了好久了,还是没有解决。大家帮忙看看
答 1: 帮忙看看.帮忙看看. 答 2: 时序没问题了?呵呵。
先看看DataSheet吧。
可以先试着读出几个ID,确认硬件OK......
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【EEPW电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
“我踩过的那些坑”主题活动——第001期 | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
多组DCTODC电源方案被打赏50分 | |
【我踩过的那些坑】STM32cubeMX软件的使用过程中的“坑”被打赏50分 | |
新手必看!C语言精华知识:表驱动法被打赏50分 | |
【我踩过的那些坑】杜绑线问题被打赏50分 | |
【我踩过的那些坑】STM32的硬件通讯调试过程的“坑”被打赏50分 | |
【我踩过的那些坑】晶振使用的问题被打赏100分 | |
【我踩过的那些坑】电感选型错误导致的处理器连接不上被打赏50分 | |
【我踩过的那些坑】工作那些年踩过的记忆深刻的坑被打赏10分 | |
【我踩过的那些坑】DRC使用位置错误导致的问题被打赏100分 | |
我踩过的那些坑之混合OTL功放与落地音箱被打赏50分 |