X P L A N AT I O N : F P G A 1 0 1
Getting the Most
out of Your PicoBlaze
Microcontroller
by Adam P. Taylor
Head of Engineering Systems
e2v
aptaylor@theiet.org
Many FPGA
applications can
benefit from using a
simple soft-core processor
to ease the generation of
sequential control structure.
54 Xcell Journal Fourth Quarter 2014
XPLANANTION: FPGA 101
T
he PicoBlaze is a com- ple 8-bit microcontroller that is based WHY USE PICOBLAZE?
pact 8-bit soft-core mi- around a RISC architecture (see Figure FPGA applications usually require a
crocontroller that FPGA 1). The controller has a 12-bit address combination of parallel and sequential
engineers instantiate with- port, which means it can address as operations, with data flow being pre-
in their selected Xilinx many as 4,096 memory locations. Each dominantly parallel and control struc-
FPGA. Once implemented, this core is address location contains an 18-bit in- tures predominantly implemented as
completely contained within the FPGA struction that defines the operation the sequential structures, for example state
fabric using only logic slices and Block core must perform. Inputs and outputs machines (see Xcell Journal issue 81,
RAMs; it requires no external volatile or to and from the core are possible via two How to Implement State Machines in
nonvolatile memory. 8-bit ports (one input, one output). The Your FPGA). However, complex con-
Thanks to its small implementation controller also provides an 8-bit identi- trol structures if implemented as a state
footprint, it is possible for an FPGA to fication port, allowing for up to 256 pe- machine can become unwieldy, increas-
contain multiple PicoBlaze instantia- ripherals to be read from or written to. ing the verification time and making
tions, with each instantiation used to There is also a size-selectable scratch- modifications later in the development
implement control structures typically pad that can be 64, 128 or 256 bytes. As cycle more difficult. Complicated state
created by state machines. The result with all micros, PicoBlaze contains an machines also take more time to devel-
is a reduction in the development time arithmetic logic unit and support for op and if several are required, this time
along with a standardized approach to one interrupt. These capabilities mean can be considerable.
control structure generation. Thanks to the controller offers many advantages You can also use PicoBlaze for seri-
the underlying high performance of the to the FPGA design engineer. al communication control over RS232,
Xilinx FPGA fabric, PicoBlaze instantia- One of the most important aspects I2C and SPI. In fact, anything that you
tions are often capable of outperforming of PicoBlaze is its highly determinis- would use a typical 8-bit micro for can
many discrete 8-bit microcontrollers. tic nature, which means all instruc- be implemented within a PicoBlaze,
Lets take a look at how we can best uti- tions require two clock cycles for ex- with the upside of higher performance.
lize this handy device within our designs. ecution and interrupts are serviced Engineers have used PicoBlaze to im-
with four clock cycles maximum. plement PID controllers in control sys-
PICOBLAZE ARCHITECTURE (You can find more detailed infor- tems. They have used it with I2C, SPI or
Before we can use the core, it is first a mation on the PicoBlaze architec- parallel DACs to create reference wave-
good idea to understand a little about ture within the Xilinx user guide that forms that range from simple square,
its architecture. PicoBlaze is a very sim- comes with your download.) sawtooth and triangular to more com-
In Port[8] Out Port[8]
Port ID[8]
Strobes
Scratchpad 64, 128, 256 I/O Ports
Program Counter Stack
Bytes
Register Bank Enable
Bank A 16 Registers Program Counter Address[12]
Bank B 16 Registers
Program
Memory
Instruction[18]
ALU Flags Decode and Control
Generated by KCPSM6.exe
Contained within KCPSM6.Vhd
<Your Program>.Vhd
Figure 1 PicoBlaze architecture, with processor in left box and memory at right
Fourth Quarter 2014 Xcell Journal 55
XPLANANTION: FPGA 101
plicated sine/cosine waveforms (using NAMEREG s0,led ;rename S0 register to led
the shift-and-add CORDIC algorithm). ;As 8 bit processor we need four delay loops 256 * 256 * 256 *
Instantiating a PicoBlaze microcon- 256 = 4294967296
CONSTANT max1, 80 ;set delay
troller within your FPGA to implement
CONSTANT max2, 84 ;set delay
these sequential functions can result CONSTANT max3, 1e ;set delay
in a faster development time and al- CONSTANT max4, 00 ;set delay
low for simplified modifications later main: LOAD led, 00; load the led output register with 00
flash: XOR led, FF; xor the value in led register with FF i.e.
in the development life cycle. And of toggle
course, being a soft core, PicoBlaze OUTPUT led,01; output led register with port ID of 1
also helps address obsolescence is- CALL delay_init; start delay
JUMP flash; loop back to beginning
sues and it encourages design reuse as delay_init: LOAD s4, max4;
ASM modules are developed. LOAD s3, max3;
LOAD s2, max2;
LOAD s1, max1;
FIRST PICOBLAZE INSTANTIATION
delay_loop: SUB s1, 1d; subtract 1 decimal from s1
You can quickly implement a PicoBlaze SUBCY s2, 0d; carry subtraction
within your design by following a few SUBCY s3, 0d; carry subtraction
initial steps. First, make sure you have SUBCY s4, 0d; carry subtraction
JUMP NZ, delay_loop;
the latest version of the microcontroller RETURN
for the device you are targeting. Xilinx
makes these available from the Pico-
Figure 2 Snippet of assembler code for a program to flash LEDs
Blaze Lounge, offering versions that
support the latest 7 series devices to
those that work with older Spartan-3
and Virtex-4 devices.
Having downloaded the correct
version of the processor, extract
those files into your working directo-
ry and ensure that you read the read-
me file, paying close attention to the
setting of the PATH and Xilinx envi-
ronment variables as required. Within
your working directory, you will now
notice the following files or applica-
tions, along with the usual readme
and license files and user guides.
KCPSM6.Vhd: This is the actual
source code for the PicoBlaze.
KCPSM6.exe. This is the assembler
program that you will use to gener-
ate the machine code and memory
files required.
ROM_Form.vhd. The assembler
executable uses this file to gen-
erate the VHDL file your created
program will reside in.
KCPSM6_design_template vhd.
This is a template instantiation of a
PicoBlaze processor.
All_kcpsm6_syntax.psm. This file
is a definition of all assembler com- Figure 3 Using the KCPSM6 assembler to generate your memory files
mands and syntax.
56 Xcell Journal Fourth Quarter 2014
XPLANANTION: FPGA 101
At the very simplest level, you need declare
only two components within your design.
For our example design, the final DEVELOPMENT FLOW memory file (VHDL for use within
step is to create a new project in the Creating your first PicoBlaze instan- your FPGA), a log file and a hex file
ISE Design Suite within which we tiation is simple. The first step is to whose use we will look at later. Figure
can instantiate the PicoBlaze and its create a blank text file using an editor 3 shows the assembler process having
program memory if you are not adding like Notepad++. This file should have been run for the code snippet above.
them to an existing project. the file extension .PSMfor instance, Having run the assembler, you are now
Once we have completed the above test.psm. You program the microcon- in a position to instantiate the Pico-
steps, we are ready to start creating a troller using the PicoBlaze assembler. Blaze within your FPGA.
PicoBlaze processor within our appli- Xilinx provides detailed information You are now in possession of the
cation. At the very simplest level, you on this syntax in the file All_kcpsm6_ two VHDL files required: KCPSM6.
need declare only two components syntax.psm, which comes with your vhd and the VHDL file created by the
within your design: the processor itself download. However, it is easy to un- assembler program containing your
and the program memory as shown in derstand and learn this syntax. Figure application (in this case, test.vhd).
Figure 1 (processor is within the left 2 is an example of an assembler code The second stage is to declare the
box and memory the right box, to pro- snippet, which is a simple program to two components (KCPSM6 and Mem-
vide context). Of course, if you have flash LEDs at 2-Hz frequency with a ory) within your VHDL design and
more than one instantiation you will 40-MHz clock. instantiate them as shown in Figure
have a number of memory components, Once you are happy with your as- 4. This simple VHDL example can be
each containing a different program. sembler program, the next stage is to seen in the code snippet in Figure 5,
However, the first thing we need to do run this program through the assem- which implements a PicoBlaze that
is understand the development flow of bler executable that came with your will flash LEDs on an LX9 Spartan
a typical project. download. Doing so will generate a development board.
Enable Enable
Instruction Address Address Data
Rdl
Input Output
FPGA Fabric IP Port
Port
FPGA Fabric OP
Port ID
From FPGA
CLK Tree CLK
RS
Interrupt Interrupt Ack
Sleep
Figure 4 PicoBlaze context diagram
Fourth Quarter 2014 Xcell Journal 57
XPLANANTION: FPGA 101
SIMULATION AND VERIFICATION
Once you have instantiated the design library IEEE;
files within your application, you will of use IEEE.STD_LOGIC_1164.ALL;
course want to verify the performance -- Uncomment the following library declaration if instantiating
of the system or module within a simu- -- any Xilinx primitives in this code.
lation environment before you progress --library UNISIM;
--use UNISIM.VComponents.all;
to synthesis and implementation. As
PicoBlaze uses logic slices and Block entity pico_wave_top is
RAMs, it can be simulated very simply Port ( clk : in STD_LOGIC;
led : out STD_LOGIC_VECTOR (3 downto 0));
in programs like Mentor Graphics Mod- end pico_wave_top;
elSim or Xilinxs ISim in ISE (or Xsim in
the Vivado Design Suite if that is where architecture Behavioral of pico_wave_top is
you are implementing your PicoBlaze).
component kcpsm6 is
Since the Block RAM contains the in- generic( hwbuild : std_logic_vector(7 downto 0) := X00;
structions for your program, simulation is interrupt_vector : std_logic_vector(11 downto 0) := X3FF;
simple. Essentially, all you need to provide scratch_pad_memory_size : integer := 64);
is a clock and other inputs and outputs port ( address : out std_logic_vector(11 downto 0);
instruction : in std_logic_vector(17 downto 0);
as required by the instantiation, Figure 6
bram_enable : out std_logic;
shows ISim results for a PicoBlaze simu- in_port : in std_logic_vector(7 downto 0);
lation and shows the two clock cycles be- out_port : out std_logic_vector(7 downto 0);
tween the loading of instructions. port_id : out std_logic_vector(7 downto 0);
write_strobe : out std_logic;
UPDATING YOUR PROGRAM k_write_strobe : out std_logic;
read_strobe : out std_logic;
One of the great benefits of having the interrupt : in std_logic;
PicoBlaze contained within the FPGA interrupt_ack : out std_logic;
(and bit file) and is that following config- sleep : in std_logic;
uration of the FPGA the core will start reset : in std_logic;
executing the program within its RAM. clk : in std_logic);
end component kcpsm6;
However, in some cases you may need to
modify the program the core is executing. component test is
While you could rerun the implementation generic( C_FAMILY : string := S6;
stage including an updated memory file, C_RAM_SIZE_KWORDS : integer := 1;
depending upon the complexity of the re- C_JTAG_LOADER_ENABLE : integer := 1);
maining design this may take considerable Port ( address : in std_logic_vector(11 downto 0);
instruction : out std_logic_vector(17 downto 0);
time, especially if you are only trying out
enable : in std_logic;
possibilities in the lab. It is therefore pos- rdl : out std_logic;
sible to update the program memory the clk : in std_logic);
core uses to modify the program and try it end component test;
out before you rerun the implementation
stage using the JTAG loader program also SIGNAL instruction : std_logic_vector(17 DOWNTO 0);
provided with your download. SIGNAL address : std_logic_vector(11 DOWNTO 0);
The initial step in using the JTAG SIGNAL enable : std_logic;
loader is to enable it within your design SIGNAL rd1 : std_logic;
setting. Use the generic C_JTAG_LOAD- SIGNAL kcpsm6_output : std_logic_vector(7 downto 0);
SIGNAL port_id : std_logic_vector(7 downto 0);
ER_ENABLE : integer := 1 within your SIGNAL write_strobe:std_logic;
instantiation of one program memory. begin
Note that you can set this parameter for
only one memory instantiation within ram_inst : test PORT MAP (
address => address,
your design at a time. instruction => instruction,
Having enabled this facility within enable => enable,
your design, you must first select the rdl => rd1,
clk => clk);
correct version for the operating system
you are using from the JTAG_loader di-
58 Xcell Journal Fourth Quarter 2014
XPLANANTION: FPGA 101
rectory and copy it to your working di-
pico_inst : kcpsm6 PORT MAP (
address => address, rectory (where you hex file is located).
instruction => instruction, Now you can open a command window
bram_enable => enable, and navigate to your working directory
in_port => (OTHERS =>0),
out_port => kcpsm6_output, and use the command below.
port_id => port_id,
write_strobe => write_strobe, jtagloader l <Your Project Name>.hex
k_write_strobe => open,
read_strobe => open, Note: I have renamed the version of the
interrupt => 0, executable for my OS jtagloader.exe.
interrupt_ack => open,
sleep => 0, This action will download the hex
reset => rd1, file created when you ran the assembler
clk => clk);
on your latest PSM file, with results as
output_ports: process(clk) shown in Figure 7. As this file downloads,
begin you will notice that the JTAG loader halts
if rising_edge(clk) then
if write_strobe = 1 then the core execution and downloads the
-- 4 LEDs at port address 01 hex Spartan LX9 new program to memory before releasing
Development board the core reset, at which point it starts run-
if port_id(0) = 1 then
led <= kcpsm6_output(3 DOWNTO 0); ning your new program.
end if; Once you are happy with the updated
end if; behavior of the PSM file, you can rerun
end if;
end process; the implementation and bit file gener-
end Behavioral; ation, ensuring that the next time the
device is configured it will execute the
Figure 5 Code snippet for a PicoBlaze that will flash LEDs on updated program.
an LX9 Spartan development board
Figure 6 ISim simulation results
Figure 7 JTAG loader in action
Fourth Quarter 2014 Xcell Journal 59