Tips, Ideas, Discussion for SOC Virtual Prototypes

Three Tips for Using Linux Swap & Play with ARM Cortex-A Systems

Posted by Jason Andrews on Tue, Dec 30, 2014 @ 11:33 AM

Today, I have three tips for using Swap & Play with Linux systems.

Read More

Tags: ARM Cortex-A15, Swap & Play, Benchmarks, ARM Cortex-A53, Jason Andrews, Linux, ARM Performance Optimization, ARM Cortex-A57

Sometimes Hardware Details Matter in ARM Embedded Systems Programming

Posted by Jason Andrews on Fri, Jun 20, 2014 @ 04:34 AM

Last week, I received the call for papers for the Embedded World Conference for 2015. The list of topics is a good reminder of how broad the world of embedded systems is. It also reminded me how overloaded the term “embedded” has become. The term may invoke thoughts of a system made for a specific purpose to perform a dedicated function, or visions of invisible processors and software hidden in a product like a car. When I think of embedded, I tend think about the combination of hardware and software and learning how they work together, and the challenge of building and debugging a system running software that interacts with hardware. Some people call this hardware dependent software, firmware, or device drivers. Whatever it is called, it’s always a challenge to construct and debug both hardware and software and find out what the problems are. One of the great things about working at Carbon is the variety of the latest ARM IP combined with a spectrum of different types of software. We commonly work with software ranging from small bare-metal C programs to Linux running on multiple ARM cores. We also work with a mix of cycle accurate models and abstract models.

Read More

Tags: virtual prototype, ARM Cortex-A15, Jason Andrews, ARM Virtual Prototype, ARM GIC-400, Cycle Accurate Models

Understanding ARM Bare Metal Benchmark Application Startup Time

Posted by Jason Andrews on Wed, May 21, 2014 @ 10:16 AM

One of the benefits of simulation with virtual prototypes is the added control and visibility of memory. It’s easy to load data into memory models, dump data from memory to a file, and change memory values without running any simulation. After I gave up debugging hardware in a lab and decided I would rather spend my time simulating, some of my first lessons were related to assumptions software makes about memory at power on. When a computer powers on, software must assume the data in memories such as SRAM and DRAM is unknown. I recall being somewhat amazed to find out that initialization software would commonly clear large memory ranges before doing anything useful. I also recall learning that startup software would figure out how much memory was present in a system by writing the first byte or word to some value, reading it back, and if the written value was read back there must be memory present. The way to determine memory size was to continue incrementing the address until the read value did not match the expected value and conclude this was the size of the memory.

Read More

Tags: virtual prototype, ARM Cortex-A15, CPAK, Benchmarks, Jason Andrews

SMP Linux on a Minimal Dual-Core ARM Cortex-A15 System

Posted by Jason Andrews on Tue, Apr 29, 2014 @ 09:13 AM

Previously, I explained how to create a minimal, single-core ARM® Cortex™-A15 system running Linux®. In this article I will update the hardware design to use a dual-core ARM Cortex-A15 CPU and run SMP (Symmetric Multiprocessing) Linux. While the first system was interesting, I’m fairly certain no single-core A15 systems have ever been built, and most engineers will require multi-core systems for common design and verification tasks.

Read More

Tags: virtual prototype, ARM Cortex-A15, SoCDesigner Plus, Jason Andrews, Linux

Running the Latest Linux Kernel on a Minimal ARM Cortex-A15 System

Posted by Jason Andrews on Tue, Apr 15, 2014 @ 08:06 AM

Linux® has become a popular operating system in embedded products, and as a result is experiencing increased usage for system design and verification. This means that a new set of people, who are not traditional embedded software engineers, need to learn to work with Linux to accomplish daily tasks.

Read More

Tags: virtual prototype, ARM Cortex-A15, CPAK, SoCDesigner Plus, Jason Andrews, Linux

FREE Insights & Analysis

Get the world's leading discussions on virtual prototyping delivered to your inbox

FREE Virtual Prototype Resources


Virtual Prototype Resources for SoC Designers

Samsung Virtual Prototype Whitepaper

Virtual Prototype Success Story