Skip to content

PICsimLab - PIC Simulator Laboratory

License

Notifications You must be signed in to change notification settings

iqapps/picsimlab

 
 

Repository files navigation

PICSimLab - PIC Simulator Laboratory

PICSimLab is a realtime emulator of development boards with integrated MPLABX/avr-gdb debugger. PICSimLab supports some picsim microcontrollers and some simavr microcontrollers. PICSimLab have integration with MPLABX/Arduino IDE for programming the boards microcontrollers.

The experimental version supports uCsim, gpsim and qemu-stm32 simulators in addition to the stable ones.

PICsimLab

PICsimLab

Requirements for compiling:

wxwidget - For graphic suport http://www.wxwidgets.org

picsim - PIC simulator https://github.com/lcgamboa/picsim

lxrad - Graphic library https://github.com/lcgamboa/lxrad

simavr - AVR simulator https://github.com/buserror/simavr

Utils:

picsimlab_md - for debug with MPLABX https://github.com/lcgamboa/picsimlab_md

com0com - For serial emulation in windows http://com0com.sourceforge.net/

tty0tty - For serial emulation in linux https://github.com/lcgamboa/tty0tty

Stable version executables download

https://github.com/lcgamboa/picsimlab/releases

If you are on macOS you can run picsimlab using Wine:

  • Download and install xquartz
  • Download and install Wine
  • Download the executable and double-click it to run the installer

Install from source

In Debian Linux and derivatives Linux native:

In first time build:

git clone https://github.com/lcgamboa/picsimlab.git
cd picsimlab
./picsimlab_build_all_and_deps.sh

To recompile use:

make -j4

Cross-compiling for Windows (from Linux or WSL on win10)

In first time build in Debian Linux and derivatives target Windows 64 bits:

git clone https://github.com/lcgamboa/picsimlab.git
cd picsimlab
./picsimlab_build_w64.sh

To recompile use:

make FILE=Makefile.cross -j4 

For target Windows 32 bits:

git clone https://github.com/lcgamboa/picsimlab.git
cd picsimlab
./picsimlab_build_w32.sh

To recompile use:

make FILE=Makefile.cross_32 -j4 

Experimental version

Experimental version can be built using the parameter "exp" on scripts:

./picsimlab_build_all_and_deps.sh exp
./picsimlab_build_w64.sh exp
./picsimlab_build_w32.sh exp

And recompiled using the parameter "exp" on Makefiles:

make -j4 exp
make FILE=Makefile.cross -j4  exp
make FILE=Makefile.cross_32 -j4 exp

Troubleshooting:

The simulation in PICSimLab consists of 3 parts:

  • The microcontroller program
  • Microcontroller simulation (made by picsim and simavr)
  • Simulation of boards and parts

When a problem occurs it is important to detect where it is occurring.

One of the most common problems is the error in the microcontroller program. Before creating an issue, test your code on a real circuit (even partially) to make sure the problem is not there.

Errors in the microcontroller simulation can be detected using code debugging. Any instruction execution or peripheral behavior outside the expected should be reported in the project of simulator used (picsim or simavr).

If the problem is not in either of the previous two options, the problem is probably in PICSimLab. A good practice is to send a source code together with a PICSimLab workspace (.pzw file) to open the issue about the problem.

Info

Online Documentation

Development Documentation

Examples

Changelog

TODO list

Online version of PICSimLab

Download analytics

Credit to Shields IO for the badges and to Somsubhra/github-release-stats for the individual file counters.

About

PICsimLab - PIC Simulator Laboratory

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 94.5%
  • C 3.2%
  • Other 2.3%