发 帖  
[问答] 请问如何编写程序控制flash,来定义一段的指定空间作为自由存储区?
2018-6-12 19:42:08  519
收藏 0 收藏 推荐 0 推荐
分享
要在flash中开辟一段存储空间,能够自由地进行读写,请问应该如何编写程序?
2018-6-12 19:42:08   评论 邀请回答
4个回答
设置一个读指针,一个写指针,一个读信号,一个写信号。
然后来写信号时,把数据存入写指针对应的地址。然后写指针加1,达到地址极限后复位指针地址
如果来读信号,就把读指针对应的地址的数据取出来,然后读指针+1,达到地址极限后复位指针地址
中间自己加一个空信号满信号的判断就可以了。
最佳答案
2018-6-12 19:42:09 评论

举报

asuyyy 发表于 2018-6-13 13:52
设置一个读指针,一个写指针,一个读信号,一个写信号。
然后来写信号时,把数据存入写指针对应的地址。然后写指针加1,达到地址极限后复位指针地址
如果来读信号,就把读指针对应的地址的数据取出来,然后读指针+1,达到地址极限后复位指针地址

谢谢,指针的话是只要用parameter定义一个地址大小,然后就可以了,还是要结合其他一些东西啊?
2018-6-13 14:13:52 评论

举报

我的代码大概是这样的。
Write_en_posedge是写完了一次数据的上升沿。
每次写完就+1,因为我的Sram地址是0~255999,
所以每次写到255999的时候就会复位到0,
如果你是要取500~2000的地址存东西。
就把复位的        w_addr[17:0] = 18'b00_0000_0000_0000_0000
改成        w_addr[17:0] = 18'd500 好了。同时计算到2000的时候复位
直接套用我的代码应该是不适合你的。
我只是提供一个思路给你。

always@(posedge Sysclk or negedge Rst_n)
                if(!Rst_n)
                        w_addr = 19'b000_0000_0000_0000_0000;
                else if(Write_en_posedge && w_addr[17:0] == 18'd255999)begin
                        w_addr[17:0] = 18'b00_0000_0000_0000_0000;
                        w_addr[18] = ~w_addr[18];
                        end
                else if(Write_en_posedge)
                        w_addr = w_addr + 1'b1;
2018-6-19 09:28:43 评论

举报

asuyyy 发表于 2018-6-19 09:28
我的代码大概是这样的。
Write_en_posedge是写完了一次数据的上升沿。
每次写完就+1,因为我的Sram地址是0~255999,

好的好的,非常感谢
2018-6-19 15:42:31 评论

举报

撰写答案

你正在撰写答案

如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。

高级模式
您需要登录后才可以回帖 登录 | 注册

提问题
关闭

站长推荐 上一条 /9 下一条

快速回复 返回顶部 返回列表
-

推荐专区

技术干货集中营

专家问答

用户帮助┃咨询与建议┃版主议事

工程师杂谈

项目|工程师创意

招聘|求职}工程师职场

论坛电子赛事

社区活动专版

发烧友活动

-

嵌入式论坛

ARM技术论坛

Linux论坛

单片机/MCU论坛

MSP430技术论坛

FPGA|CPLD|ASIC论坛

STM32/STM8技术论坛

NXP MCU 技术论坛

DSP论坛

嵌入式系统论坛

-

电源技术论坛

电源技术论坛

无线充电技术

-

硬件设计论坛

电路设计论坛

电子元器件论坛

传感技术

总线技术|接口技术

-

测试测量论坛

LabVIEW论坛

Matlab论坛

测试测量技术专区

-

EDA设计论坛

multisim论坛

PCB设计论坛

PADS技术论坛

Protel|AD|DXP论坛

Allegro论坛

proteus论坛|仿真论坛

Orcad论坛

-

综合技术与应用

电机控制

工程资源中心

汽车电子技术论坛

医疗电子论坛

-

开源硬件

-

无线通信论坛

物联网技术

天线|RF射频|微波|雷达技术

-

IC设计论坛

芯片测试与失效分析

Analog/RF IC设计

设计与制造封装测试

-

厂商专区

TI论坛

TI Deyisupport社区

-

检测技术与质量

电磁兼容(EMC)设计与整改

安规知识论坛

检测与认证

-

消费电子论坛

手机技术论坛

平板电脑/mid论坛

音视/视频/机顶盒论坛

-

电子论坛综合区

聚丰众筹官方社区

新人报道区

聚丰供应链

-

论坛服务区

-

高校联盟

西藏民族学院电子设计协会

西安电子科技大学西电实验室

桂林电子科技大学机电工程协会

鉴鹰电子科技协会

广东海洋大学科技创新协会

福建农林大学电子科技创新协会

湖北理工学院电子技术协会

深圳职业技术学院电子精英训练营

浙江科技学院Zuster

湘潭大学电子科技协会

青岛理工大学琴岛学院天宏开发团队

河南理工大学大学生电器开发部

广西科技大学电气信息创新协会

浙江机电职业技术学院电子制作协会

郑州大学西亚斯国际学院爱电工作室

新乡学院电子创新工作室

洛阳理工学院SmartTeam

苏州工业职业技术学院创新工作室

浙江工业大学GC315团队

杭电-微芯大学生科技创新孵化器

西安工业大学电信科协

商洛学院科技创新协会

大连民族学院创新工作室

南京信息工程大学帆木工作室

-

供求信息发布

方案交易

供需广告

芯片求购|供应发布区