Primace 5.0软件与KEIL单片机软件联合在线仿真步骤

Primace 软件是CME(京微雅格)公司的FPGA芯片开发专用软件。因为CME的FPGA,如M5、M7等内嵌有8051核,所以可以和MCU联合在线仿真,虽然FPGA内的程序不可控,不能一步一步的仿真,但是因为MCU程序可控,可以一步一步的运行,所以可以利用此特性,用MCU给FPGA发送命令,然后控制FPGA的运行与操作。

所以此FPGA开发板也可以做8051单片机开发板。

这里主要介绍FPGA与keiLl联合仿真的时候的关于KEIL的工程的建立与设置。主要是做的比较简单的仿真,比较粗俗。简单。

首先要安装8051的专用驱动,京微雅格的官网上有,

步骤:建立工程

如果安装过驱动,在会在下面界面的下拉菜单内出现下面的这个选项,选择

为工程简历文件,不要忘记了把文件加入工程内,头文件也要加入,一般就如下图所示即可。

M5.h 驱动里面应该会有,也会贴在下面,找不到的话,复制即可建立M5.h 。直接加在工程目录下即可,因为做的只是简单的仿真。

下面的设置很重要:

优化级别的选择有助于keil软件的单步执行,防止有些关键步骤被软件优化掉

ok,这里连上USB下载器,就可以仿真了。当然要先把FPGA程序下载到芯片里。

附: M5.h

/*--------------------------------------------------------------------------
M5.H

Header file for M5 Embedded 8051 microcontroller.
--------------------------------------------------------------------------*/

#ifndef __M5_H__
#define __M5_H__

/* Byte Register */
/*Register Location     Reset value     Description */
sfr P0                     = 0x80;      //    FFh         Port 0
sfr P1                     = 0x90;    //    FFh         Port 1
sfr P2                     = 0xA0;    //    FFh         Port 2
sfr P3                     = 0xB0;    //    FFh         Port 3
sfr PSW                    = 0xD0;    //    FFh         Program Status Word
sfr ACC                    = 0xE0;    //    FFh         Accumulator
sfr B                      = 0xF0;    //    FFh         B Register

sfr SP                     = 0x81;      //    07h         Stack Pointer
sfr DPL                    = 0x82;    //    00h         Data Pointer Low
sfr DPH                    = 0x83;    //    00h         Data Pointer High
sfr DPL1                   = 0x84;    //    00h         Data Pointer 1 Low
sfr DPH1                   = 0x85;    //    00h         Data Pointer 1 High
sfr WDTREL                 = 0x86;    //    00h         Watchdog Timer Reload register
sfr PCON                   = 0x87;    //    00h         Power Control
sfr TCON                   = 0x88;    //    00h         Timer/Counter Control Register
sfr TMOD                   = 0x89;    //    00h         Timer Mode Register
sfr TL0                    = 0x8A;    //    00h         Timer 0, low byte
sfr TL1                    = 0x8B;    //    00h         Timer 1, low byte
sfr TH0                    = 0x8C;    //    00h         Timer 0, high byte
sfr TH1                    = 0x8D;    //    00h         Timer 1, high byte
sfr CKCON                  = 0x8E;    //    71h         Clock Control Register

sfr DPSEL                  = 0x92;    //    00h         Data Pointer Select Register
sfr DPC                    = 0x93;    //    00h         Data Pointer Control Register
sfr PAGESEL                = 0x94;    //    01h         Program Memory Page selector
sfr D_PAGESEL            = 0x95;    //    01h         External Data Memory Page selector
sfr S0CON                  = 0x98;    //    00h         Serial Port 0, Control Register
sfr S0BUF                  = 0x99;    //    00h         Serial Port 0, Data Buffer
sfr IEN2                   = 0x9A;    //    00h         Interrupt Enable Register 2
sfr S1CON                  = 0x9B;    //    00h         Serial Port 1, Control Register
sfr S1BUF                  = 0x9C;    //    00h         Serial Port 1, Data Buffer
sfr S1RELL                 = 0x9D;    //    00h         Serial Port 1, Reload Register, low byte                     

sfr DMAS0                  = 0xA1;    //    00h         DMA Source Address Register 0
sfr DMAS1                  = 0xA2;    //    00h         DMA Source Address Register 1
sfr DMAS2                  = 0xA3;    //    00h         DMA Source Address Register 2
sfr DMAT0                  = 0xA4;    //    00h         DMA Source Target Register 0
sfr DMAT1                  = 0xA5;    //    00h         DMA Source Target Register 1
sfr DMAT2                  = 0xA6;    //    00h         DMA Source Target Register 2
sfr IEN0                   = 0xA8;    //    00h         Interrupt Enable Register 0
sfr IP0                    = 0xA9;    //    00h         Interrupt Priority Register 0
sfr S0RELL                 = 0xAA;    //    D9h         Serial Port 0, Reload Register, low byte
sfr I2CSPISEL            = 0xAB;    //    00h         I2C source and fixed or user IO select
sfr ISCDATA0             = 0xAC;    //    00h         In System Configuration Data[7:0]
sfr ISCDATA1             = 0xAD;    //    00h         In System Configuration Data[15:8]
sfr ISCDATA2             = 0xAE;    //    00h         In System Configuration Data[23:16]
sfr ISCDATA3             = 0xAF;    //    00h         In System Configuration Data[31:24] 

sfr DMAC0                  = 0xB1;    //    00h         DMA Byte Counter Register 0
sfr DMAC1                  = 0xB2;    //    00h         DMA Byte Counter Register 1
sfr DMAC2                  = 0xB3;    //    00h         DMA Byte Counter Register 2
sfr DMASEL                 = 0xB4;    //    00h         DMA Channel Select Register
sfr DMAM0                  = 0xB5;    //    00h         DMA Mode Register 0
sfr DMAM1                  = 0xB6;    //    1Fh         DMA Mode Register 1
sfr IEN1                   = 0xB8;    //    00h         Interrupt Enable Register 1
sfr IP1                    = 0xB9;    //    00h         Interrupt Priority Register 1
sfr S0RELH                 = 0xBA;    //    03h         Serial Port 0, Reload Register, high byte
sfr S1RELH                 = 0xBB;    //    03h         Serial Port 1, Reload Register, high byte
sfr IRCON2                 = 0xBF;    //    00h         Interrupt Request Control 2 Register  

sfr IRCON                  = 0xC0;    //    00h         Interrupt Request Control Register
sfr CCEN                   = 0xC1;    //    00h         Compare/Capture Enable Register
sfr CCL1                   = 0xC2;    //    00h         Compare/Capture Register 1, low byte
sfr CCH1                   = 0xC3;    //    00h         Compare/Capture Register 1, high byte
sfr CCL2                   = 0xC4;    //    00h         Compare/Capture Register 2, low byte
sfr CCH2                   = 0xC5;    //    00h         Compare/Capture Register 2, low byte
sfr CCL3                   = 0xC6;    //    00h         Compare/Capture Register 3, low byte
sfr CCH3                   = 0xC7;    //    00h         Compare/Capture Register 3, high byte
sfr T2CON                  = 0xC8;    //    00h         Timer 2 Control Register
sfr CRCL                   = 0xCA;    //    00h         Compare/Reload/Capture Register, low byte
sfr CRCH                   = 0xCB;    //    00h         Compare/Reload/Capture Register, high byte
sfr TL2                    = 0xCC;    //    00h         Timer 2, low byte
sfr TH2                    = 0xCD;    //    00h         Timer 2, high byte

sfr IEN4                  = 0xD1;    //    00h         Interrupt Enable Register 4
sfr ADCON                  = 0xD8;    //    00h         Serial Port 0 Baud Rate Select register (only adcon.7 bit used)
sfr I2CDAT                 = 0xDA;    //    00h         I2C Data Register
sfr I2CADR                 = 0xDB;    //    00h         I2C Address Register
sfr I2CCON                 = 0xDC;    //    00h         I2C Control Register
sfr I2CSTA                 = 0xDD;    //    00h         I2C Status Register 

sfr SPSTA                  = 0xE1;    //    00h         Serial Peripheral(SPI) Status Register
sfr SPCON                  = 0xE2;    //    14h         Serial Peripheral(SPI) Control Register
sfr SPDAT                  = 0xE3;    //    00h         Serial Peripheral(SPI) Data Register
sfr SPSSN                  = 0xE4;    //    FFh         Serial Peripheral(SPI) Slave Select Register
sfr RTCCMD                 = 0xE5;    //    00h         RTC Command Register
sfr RTCSEL                 = 0xE6;    //    00h         RTC Select Register
sfr RTCDATA                = 0xE7;    //    00h         RTC Data Register
sfr MD0                    = 0xE9;    //    00h         Multiplication/Division Register 0
sfr MD1                    = 0xEA;    //    00h         Multiplication/Division Register 1
sfr MD2                    = 0xEB;    //    00h         Multiplication/Division Register 2
sfr MD3                    = 0xEC;    //    00h         Multiplication/Division Register 3
sfr MD4                    = 0xED;    //    00h         Multiplication/Division Register 4
sfr MD5                    = 0xEE;    //    00h         Multiplication/Division Register 5
sfr ARCON                  = 0xEF;    //    00h         Arithmetic Control Register

sfr ISCCMD              = 0xF2;    //    00h         In System Configuration Command
sfr ISCHEADER0      = 0xF3;    //    00h         In System Configuration Header[7:0]
sfr ISCHEADER1      = 0xF4;    //    00h         In System Configuration Header[15:8]
sfr ISCHEADER2      = 0xF5;    //    00h         In System Configuration Header[23:9]
sfr ISCHEADER3      = 0xF6;    //    00h         In System Configuration Header[31:24]
sfr SRST                   = 0xF7;    //    00h         Software Reset Register
sfr GCLKCMD                = 0xF8;    //    00h         Global Clock Command Register
sfr GCLKADDR            = 0xF9;    //    00h      Global Clock Address Register
sfr GCLKDATA            = 0xFA;    //    00h         Global Clock Data Register
sfr ISMDIRCTRL        = 0xFB;    //    00h        In System Management Control Register 

/* BIT Register */

/* PSW:Program Status Word->Byte Address:0xD0,bit Address:0xD0~0xD7 */
sbit CY            = 0xD7;
sbit AC            = 0xD6;
sbit F0            = 0xD5;
sbit RS1           = 0xD4;
sbit RS0           = 0xD3;
sbit OV            = 0xD2;
sbit F1            = 0xD1;
sbit P             = 0xD0; 

/* TCON:Timer/Counter Control Register->Byte Address:0x88,bit Address:0x88~0x8F */
sbit TF1           = 0x8F;
sbit TR1           = 0x8E;
sbit TF0           = 0x8D;
sbit TR0           = 0x8C;
sbit IE1           = 0x8B;
sbit IT1           = 0x8A;
sbit IE0           = 0x89;
sbit IT0           = 0x88;

/* T2CON:Timer 2 Control Register->Byte Address:0xC8,bit Address:0xC8~0xCF */
sbit T2PS          = 0xCF;
sbit I3FR          = 0xCE;
sbit I2FR          = 0xCD;
sbit T2R1          = 0xCC;
sbit T2R0          = 0xCB;
sbit T2CM          = 0xCA;
sbit T2I1          = 0xC9;
sbit T2I0          = 0xC8;

/* S0CON:Serial Port 0,Control Register->Byte Address:0x98,bit Address:0x98~0x9F */
sbit SM0           = 0x9F;
sbit SM1           = 0x9E;
sbit SM20          = 0x9D;
sbit REN0          = 0x9C;
sbit TB80          = 0x9B;
sbit RB80          = 0x9A;
sbit TI0           = 0x99;
sbit RI0           = 0x98;

/* IEN0:Interrupt Enable Register 0->Byte Address:0xA8,bit Address:0xA8~0xAF */
sbit EAL           = 0xAF;
sbit WDT           = 0xAE;
sbit ET2           = 0xAD;
sbit ES0           = 0xAC;
sbit ET1           = 0xAB;
sbit EX1           = 0xAA;
sbit ET0           = 0xA9;
sbit EX0           = 0xA8;

/* IEN1:Interrupt Priority Register/Enable Register 1 */
sbit EXEN2         = 0xBF;
sbit SWDT          = 0xBE;
sbit EX6           = 0xBD;
sbit EX5           = 0xBC;
sbit EX4           = 0xBB;
sbit EX3           = 0xBA;
sbit EX2           = 0xB9;
sbit EX7           = 0xB8;

/* IRCON:Interrupt Request Control Register->Byte Address:0xC0,bit Address:0xC0~0xC7 */
sbit EXF2          = 0xC7;
sbit TF2           = 0xC6;
sbit IEX6          = 0xC5;
sbit IEX5          = 0xC4;
sbit IEX4          = 0xC3;
sbit IEX3          = 0xC2;
sbit IEX2          = 0xC1;
sbit IADC          = 0xC0;

/* ADCON:Serial Port 0 Baud Rate Select register (only adcon.7 bit used) */
sbit BD            = 0xDF;

/* P0:Port 0->Byte Address:0x80,bit Address:0x80~0x87 */
sbit P0_0         = 0x80;
sbit P0_1         = 0x81;
sbit P0_2         = 0x82;
sbit P0_3         = 0x83;
sbit P0_4         = 0x84;
sbit P0_5         = 0x85;
sbit P0_6         = 0x86;
sbit P0_7         = 0x87; 

/* P1:Port 1->Byte Address:0x90,bit Address:0x90~0x97 */
sbit P1_0         = 0x90;
sbit P1_1         = 0x91;
sbit P1_2         = 0x92;
sbit P1_3         = 0x93;
sbit P1_4         = 0x94;
sbit P1_5         = 0x95;
sbit P1_6         = 0x96;
sbit P1_7         = 0x97; 

/* P2:Port 2->Byte Address:0xA0,bit Address:0xA0~0xA7 */
sbit P2_0         = 0xA0;
sbit P2_1         = 0xA1;
sbit P2_2         = 0xA2;
sbit P2_3         = 0xA3;
sbit P2_4         = 0xA4;
sbit P2_5         = 0xA5;
sbit P2_6         = 0xA6;
sbit P2_7         = 0xA7; 

/* P3:Port 3->Byte Address:0xB0,bit Address:0xB0~0xB7 */
sbit P3_0         = 0xB0;
sbit P3_1         = 0xB1;
sbit P3_2         = 0xB2;
sbit P3_3         = 0xB3;
sbit P3_4         = 0xB4;
sbit P3_5         = 0xB5;
sbit P3_6         = 0xB6;
sbit P3_7         = 0xB7; 

/* MISCCON:Misc Control Register->Byte Address:0xF8,bit Address:0xF8~0xFF */
sbit ISCEN         = 0xF8;
sbit DPRAMWP    = 0xF9;
sbit PLLLOCK    = 0xFA;
sbit PLLPWD        = 0xFB;
sbit CLKCPUTRIG    = 0xFC;
sbit CLKO0TRIG     = 0xFD;
sbit CLKO1TRIG     = 0xFE;
sbit CLKO2TRIG     = 0xFF;
#endif

mcu  的头文件:

 #include "M5.H"
 #include <intrins.h>
 #include <absacc.h>

 #define uchar unsigned char
 #define uint unsigned int
 #define ulong unsigned long

 sbit  GPIO_RST_N = P1^0;
 sbit  GPIO_wr_en = P1^1;
 sbit  GPIO_rd_en = P1^2;
 sbit  GPIO_SRAM_CS = P1^3;
 sbit  GPIO_dir   = P1^4;

 #define  GPIO_addr_L P0
 #define  GPIO_data_H P2
 #define  GPIO_data_L P3

  #define  RST_EN     GPIO_RST_N =0
 #define  RST_DISEN   GPIO_RST_N =1
 #define  WR_EN       GPIO_wr_en =0
 #define  WR_DISEN    GPIO_wr_en =1
 #define  RD_EN       GPIO_rd_en =0
 #define  RD_DISEN    GPIO_rd_en =1
 #define  CS_EN       GPIO_SRAM_CS =0
 #define  CS_DISEN    GPIO_SRAM_CS =1
 #define  DATA_OUT    GPIO_dir  = 1
 #define  DATA_IN     GPIO_dir  = 0
时间: 2024-07-31 09:22:25

Primace 5.0软件与KEIL单片机软件联合在线仿真步骤的相关文章

Surpac v6.0 1CD(矿山工程软件)+AUCOTEC.ELCAD.V7.8.0

I-DEAS 10.0 最新设计指南简体中文.rar Star-CD CD-adapco v4.08_x86.rar Ansoft Designer and Nexxim v4.0 -ISO 1CD(Nexxim是针对射频数模混合集成电路以及高性能信号完整 性\ PVTsim v18.0  1CD(多用途PVT模拟软件)\ RES2DINV v3.55.35(支持陆地,海底和钻孔测量 ,生成二维的数字测量数据)\ RES3DINV.v2.15f(地质学软件,利用地表的二维数字测量数据建立地表以下

基于Qt5.5.0的sql,C++备忘录软件的编写

我的第一个软件. 基于Qt5.5.0的 sql ,C++备忘录软件version1.0的编写 我用的Qt版本是5.5.0免配置编译器的版本,这里附上我使用的软件下载地址:http://download.qt.io/official_releases/qt/5.5/5.5.0/ 下载 qt-opensource-windows-x86-mingw492-5.5.0.exe即可. 话不多说,第一先是基于Qt5.5.0的sql的配置,这里详见我的另外一篇博客:http://www.cnblogs.co

Hydro Tec v5.1.0.2 Incl KeyGen(德语软件)

圆方家具设计系统6.8MagiCAD2010 2010.11中文版全功能支持32位64位+送3G教学Flotherm v9.1v9.3支持32位64位 送海量学习资料资料Geosoft.Oasis.Montaj.v7.5.1 Geosoft Oasis Montaj 7.5 Landmark EDT R5000.1.9.0 1DVDV-ELEQ v1.1.0 电气仿真系统 中文版Eudaptics Viscovery SOMine v5.0.1(数据挖掘系统)韩国电气仿真软件V-ELEQWeat

Transoft Solutions AutoTURN Pro 3D v9.0.1机动车转弯设计软件

Transoft Solutions AutoTURN Pro 3D v9.0.1机动车转弯设计软件Transoft.AutoTURN.v9.0.1.256 1CD(车辆转弯模拟软件)AutoTURN已经发展成为一个强大的和全面的车辆转弯模拟软件,AutoTURN 9.0预装了令人兴奋的新的增强功能,如进行视线的能力,分析了横向路线和垂直廓线,先进的垂直间隙检查功能,并研究复杂的负载形状的能力. 而且,新的高速资料报告,让工程师来研究沿着路径产生的车速变化,车辆档次模板分析的最大上升和下降的斜率

创媒Prezi.Pro.v6.16.2.0 PPT演示文稿制作软件

创媒Prezi.Pro.v6.16.2.0 PPT演示文稿制作软件 Prezi Pro桌面版是一款类似于PowerPoint的报告制作工具,可代替ppt软件,能够制作出具有动画和缩 放等各种交互效果的报告文件.除了平移和缩放,Prezi还支持图片.视频.PDF等各种媒体素材的嵌入, 可以多人在线编辑,生成的报告既可以在本地观看,也可以上传到服务器或嵌入网页在线查看. Prezi Pro可以让你通过你的故事缩放功能创造迷人的演示文稿.即使离线,没有Wi-Fi. Prezi也能让 您在Mac没有连接

Materialise.Mimics.Innovation.Suite.v17.0.Medical.&amp;.Research.Win32_64 4CD比利时医学软件+Mimics 10.01 (著名医学有限元仿真)

Materialise.Mimics.Innovation.Suite.v17.0.Medical.&.Research.Win32_64 4CD比利时医学软件Mimics 10.01 (著名医学有限元仿真)Delcam Dental v2010 SP2-ISO 1CD(专业牙科软件)Delcam DentCAD 8112 SP2 牙科设计软件DElcam DentMill 5070 牙科加工解决方案MiPACS Dental Enterprise Solution v3.1 (医学牙科软件)D

让你提前认识软件开发---学长的软件开发经验总结(19)

第1部分 重新认识C语言 C语言中的协议及单元测试示例 [文章摘要] 在实际的软件开发项目中,经常要实现多个模块之间的通信,这就需要大家约定好相互之间的通信协议,各自按照协议来收发和解析消息. 本文以实际的程序代码为例,详细介绍了如何用C语言来实现通信协议,并基于对协议字段的判断,说明了程序单元测试的过程,为相关的开发工作提供了有益的参考. [关键词] 软件开发  协议  单元测试  C语言  字段 一.软件模块之间的协议 什么是软件模块之间的协议?不同的软件模块之间要实现相互通信,就必须遵循共

让你提前认识软件开发---学长的软件开发经验总结(18)

第1部分 重新认识C语言 C语言中常用的文件操作函数总结及使用方法演示代码 在C语言中,有关文件操作的函数多达数十种,但并非每个函数都经常会被用到.        本文对实际软件开发项目中常用的C文件操作函数的用法进行了总结,并用实际的C代码来演示了它们的用法. 1. C语言中常用的文件操作函数总结 (1) fopen 作用:打开文件. 表头文件:#include <stdio.h> 定义函数:FILE *fopen(const char *path, const char *mode); 函

让你提前认识软件开发---学长的软件开发经验总结(17)

第1部分 重新认识C语言 makefile文件的书写及应用 [文章摘要] makefile用于Linux下整个工程的编译,对于Linux下的C/C++语言的编译是至关重要的. 本文以实际的C源程序为例子,介绍如何使用makefile来编译Linux下的C语言工程,为相关开发工作的开展提供了参考. [关键词] makefile  C语言  Linux  编译  开发 一.什么是makefile? makefile是什么?如果你写的程序只是在Windows下运行,那么很有可能不知道有这个玩意儿.而如