Simics Explained

Simics
Author:SICS, Virtutech
Developer:Intel
Latest Release Version:6
Latest Release Date:2019
Programming Language:C, DML, Python, Simgen, Simics CLI scripts, C++, Rust, Javascript, Java
Genre:Full-system simulator
License:Proprietary

Simics is a full-system simulator or virtual platform used to run unchanged production binaries of the target hardware. Simics was originally developed by the Swedish Institute of Computer Science (SICS), and then spun off to Virtutech for commercial development in 1998. Virtutech was acquired by Intel in 2010. Currently, Simics is provided by Intel in a public release[1] and sold commercially by Wind River Systems, which was in the past a subsidiary of Intel.

Simics contains both instruction set simulators and hardware models, and is or has been used to simulate systems such as Alpha, ARM (32- and 64-bit), IA-64, MIPS (32- and 64-bit), MSP430, PowerPC (32- and 64-bit), RISC-V (32- and 64-bit), SPARC-V8 and V9, and x86 and x86-64 CPUs.

Many different operating systems have been run on various simulated virtual platforms, including Linux, MS-DOS, Windows, VxWorks, OSE, Solaris, FreeBSD, QNX, RTEMS, UEFI, and Zephyr.

The NetBSD AMD64 port was initially developed using Simics before the public release of the chip.[2] The purpose of simulation in Simics is often to develop software for a particular type of hardware without requiring access to that precise hardware, using Simics as a virtual platform. This can applied both to pre-release and pre-silicon software development for future hardware, as well as for existing hardware. Intel uses Simics to provide its ecosystem with access to future platform months or years ahead of the hardware launch.[3]

The current version of Simics is 6 which was released publicly in 2019.[4] [5] Simics runs on 64-bit x86-64 machines running Microsoft Windows and Linux (32-bit support was dropped with the release of Simics 5, since 64-bit provides significant performance advantages and is universally available on current hardware). The previous version, Simics 5, was released in 2015.[6]

Simics has the ability to execute a system in forward and reverse direction.[7] Reverse debugging can illuminate how an exceptional condition or bug occurred. When executing an OS such as Linux in reverse using Simics, previously deleted files reappear when the deletion point is passed in reverse and scrolling and other graphical display and console updates occur backwards as well.

Simics is built for high performance execution of full-system models, and uses both binary translation and hardware-assisted virtualization to increase simulation speed. It is natively multithreaded and can simulate multiple target (or guest) processors and boards using multiple host threads. It has been used to run simulations containing hundreds of target processors.

See also

External links

Notes and References

  1. Web site: Simics® Simulator . Intel . 2021-05-14 . 2022-02-02.
  2. Web site: Simics used to port an OS . NetBSD Wiki . NetBSD.
  3. Web site: Engblom. Jakob. Simics 6 at the Mountain Top. Intel Developer Zone. March 17, 2020 .
  4. Web site: Engblom. Jakob. Seeing the Early Snow on the Ridge. Intel Developer Zone Blog. September 10, 2019 .
  5. Web site: Evoy. Sean. Simics: Just when you thought it couldn't get any better. Wind River Blog. November 5, 2019 .
  6. Web site: Engblom. Jakob. Simics 5 is here - More Parallel than Ever . Wind River Blog . June 30, 2015 .
  7. Web site: Engblom . Jakob . Back to Reverse Execution - Tools, Testing, & Virtual Systems . 2017-10-01 . https://web.archive.org/web/20171001010539/http://blogs.windriver.com/tools/2013/06/back-to-reverse-execution.html . 2017-10-01 . dead . 2022-02-02.