资料介绍
软件简介
simavr - a lean and mean Atmel AVR simulator for linux
simavr is a new AVR simulator for linux, or any platform that uses avr-gcc. It uses avr-gcc's own register definition to simplify creating new targets for supported AVR devices. The core was made to be small and compact, and hackable so allow quick prototyping of an AVR project. The AVR core is now stable for use with parts with <= 128KB flash, and with preliminary support for the bigger parts. The simulator loads ELF files directly, and there is even a way to specify simulation parameters directly in the emulated code using an .elf section. You can also load multipart HEX files.
Installation
On OSX, we recommend using homebrew:
On Ubuntu, SimAVR is available in the Bionic package source:
apt-get install simavr
(Note that the command is made available under the name simavr
not run_avr
.)
Otherwise, make
is enough to just start using bin/simavr. To install the simavr command system-wide, make install RELEASE=1
.
Supported IOs
- eeprom
- watchdog
- IO ports (including pin interrupts)
- Timers, 8 &16 (Normal, CTC and Fast PWM, the overflow interrupt too)
- The UART, including tx & rx interrupts (there is a loopback/local echo test mode too)
- SPI, master/slave including the interrupt
- i2c Master & Slave
- External Interrupts, INT0 and so on.
- ADC
- Self-programming (ie bootloaders!)
Emulated Cores (very easy to add new ones!)
- ATMega2560
- AT90USB162 (with USB!)
- ATMega1281
- ATMega1280
- ATMega128
- ATMega128rf1
- ATMega16M1
- ATMega169
- ATMega162
- ATMega164/324/644
- ATMega48/88/168/328
- ATMega8/16/32
- ATTiny25/45/85
- ATTIny44/84
- ATTiny2313/2313v
- ATTiny13/13a
Extras:
- fully working gdb support including some pretty cool “passive modes”.
- There is also very easy support for “VCD” (Value Change Dump) that can be visualized graphically as “waveforms” with tools like gtkwave (see below).
- There are a few examples of real life firmwares running on simavr, including OpenGL rendering of the display…
- There is support for Arduino, but no IDE integration
Documentation And Further Information
- Manual / Developer Guide: https://github.com/buserror-uk/simavr/blob/master/doc/manual/manual.pdf?raw=true
- Examples: https://github.com/buserror-uk/simavr/tree/master/examples
- Mailing List: http://groups.google.com/group/simavr
- IRC: #simavr on Freenode
Contributing
Patches are always welcome! Please submit your changes via Github pull requests.
VCD Support -- built in logic analyzer
simavr can output most of its pins, firmware variables, interrupts and a few other things as signals to be dumped into a file that can be plotted using gtkwave for further, precise analysis. A firmware can contain instructions for simavr to know what to trace, and the file is automatically generated. Example:
const struct avr_mmcu_vcd_trace_t _mytrace[] _MMCU_ = {
{ AVR_MCU_VCD_SYMBOL("UDR0"), .what = (void*)&UDR0, },
{ AVR_MCU_VCD_SYMBOL("UDRE0"), .mask = (1 << UDRE0), .what = (void*)&UCSR0A, },
};
Will tell simavr to generate a trace everytime the UDR0 register changes and everytime the interrupt is raised (in UCSR0A). The MMCU tag tells gcc that it needs compiling, but it won't be linked in your program, so it takes literally zero bytes, this is a code section that is private to simavr, it's free! A program running with these instructions and writing to the serial port will generate a file that will display:
$ ./simavr/run_avr tests/atmega88_example.axf
AVR_MMCU_TAG_VCD_TRACE 00c6:00 - UDR0
AVR_MMCU_TAG_VCD_TRACE 00c0:20 - UDRE0
Loaded 1780 .text
Loaded 114 .data
Loaded 4 .eeprom
Starting atmega88 - flashend 1fff ramend 04ff e2end 01ff
atmega88 init
avr_eeprom_ioctl: AVR_IOCTL_EEPROM_SET Loaded 4 at offset 0
Creating VCD trace file 'gtkwave_trace.vcd'
Read from eeprom 0xdeadbeef -- should be 0xdeadbeef..
Read from eeprom 0xcafef00d -- should be 0xcafef00d..
simavr: sleeping with interrupts off, quitting gracefully
And when the file is loaded in gtkwave, you see:
You get a very precise timing breakdown of any change that you add to the trace, down to the AVR cycle.
Example:
simavr is really made to be the center for emulating your own AVR projects, not just a debugger, but also the emulating the peripherals you will use in your firmware, so you can test and develop offline, and now and then try it on the hardware.
You can also use simavr to do test units on your shipping firmware to validate it before you ship a new version, to prevent regressions or mistakes.
simavr has a few 'complete projects/ that demonstrate this, most of them were made using real hardware at some point, and the firmware binary is exactly the one that ran on the hardware. The key here is to emulate the parts or peripherals that are hooked to the AVR. Of course, you don't have to emulate the full hardware, you just need to generate the proper stimulus so that the AVR is fooled.
HD44780 LCD Board Demo
This example board hooks up an Atmega48 to an emulated HD44780 LCD and display a running counter in the 'lcd'. Everything is emulated, the firmware runs exactly like this on a real hardware.
And this is a gtkwave trace of what the firmware is doing. You can zoom in, measure, etc in gtkwave, select trades to see etc.
Quite a few other examples are available!
- Atmel发布AVR XMEGA评测工具套件
- labview轴心轨迹模拟器轴心轨迹分析 33次下载
- AVR教程---模拟比较器和ADC接口
- 基于DSP的电磁脉冲模拟器控制系统设计方案 13次下载
- ADSIM模拟器
- 如何使用MATLAB RTW和Vxworks实现飞行模拟器的实时仿真 6次下载
- Atmel studio 6.2软件下载 289次下载
- Atmel AVR1923用户指南 5次下载
- Atmel AVR1935入门指南 3次下载
- Atmel AVR 单片机上网方案 6次下载
- AVR精简学习板 0次下载
- Atmel爱特梅尔AVR微控制器简介
- Atmel 90系列AVR单片机烧录器
- Atmel AVR 单片机上网方案
- 汽车驾驶模拟器新一代实时场景系统的开发
- DC/DC模拟器的特征和使用方法 381次阅读
- 使用Netropy广域网模拟器测试简化SD-WAN测试 396次阅读
- 华为eNSP模拟器安装教程 2717次阅读
- 华为新版模拟器eNSP Lite 5692次阅读
- 华为新版模拟器eNSP Lite安装攻略 6675次阅读
- 如何对PNET 模拟器进行初始化安装 1755次阅读
- HarmonyOS本地模拟器的版本演进与使用方法 6017次阅读
- 微雪电子USB AVR JTAG ICE XPII下载器简介 4042次阅读
- 基于步进电机和单片机的航海罗经模拟器方案设计浅析 1010次阅读
- 基于QEMU系统模拟器Xilinx/QEMU的运行与调试 8886次阅读
- 基于TL431的电动汽车多节串联锂电池模拟器 7262次阅读
- 一种基于FPGA嵌入式系统的雷达信号模拟器的实现 2601次阅读
- AVR单片机的主要特性 895次阅读
- AVR单片机有什么优点_为什么要选择AVR单片机 2420次阅读
- 基于FPGA的飞行模拟器通信接口设计 2598次阅读
下载排行
本周
- 1山景DSP芯片AP8248A2数据手册
- 1.06 MB | 532次下载 | 免费
- 2RK3399完整板原理图(支持平板,盒子VR)
- 3.28 MB | 339次下载 | 免费
- 3TC358743XBG评估板参考手册
- 1.36 MB | 330次下载 | 免费
- 4DFM软件使用教程
- 0.84 MB | 295次下载 | 免费
- 5元宇宙深度解析—未来的未来-风口还是泡沫
- 6.40 MB | 227次下载 | 免费
- 6迪文DGUS开发指南
- 31.67 MB | 194次下载 | 免费
- 7元宇宙底层硬件系列报告
- 13.42 MB | 182次下载 | 免费
- 8FP5207XR-G1中文应用手册
- 1.09 MB | 178次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234315次下载 | 免费
- 2555集成电路应用800例(新编版)
- 0.00 MB | 33566次下载 | 免费
- 3接口电路图大全
- 未知 | 30323次下载 | 免费
- 4开关电源设计实例指南
- 未知 | 21549次下载 | 免费
- 5电气工程师手册免费下载(新编第二版pdf电子书)
- 0.00 MB | 15349次下载 | 免费
- 6数字电路基础pdf(下载)
- 未知 | 13750次下载 | 免费
- 7电子制作实例集锦 下载
- 未知 | 8113次下载 | 免费
- 8《LED驱动电路设计》 温德尔著
- 0.00 MB | 6656次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935054次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 78.1 MB | 537798次下载 | 免费
- 3MATLAB 7.1 下载 (含软件介绍)
- 未知 | 420027次下载 | 免费
- 4OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234315次下载 | 免费
- 5Altium DXP2002下载入口
- 未知 | 233046次下载 | 免费
- 6电路仿真软件multisim 10.0免费下载
- 340992 | 191187次下载 | 免费
- 7十天学会AVR单片机与C语言视频教程 下载
- 158M | 183279次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138040次下载 | 免费
评论
查看更多