Flowcode RPi Getting Started Guide
Flowcode RPi Getting Started Guide
Raspberry Pi is an inexpensive board level target with digital I/O but also internet
functionality built in. As such it provides an ideal base for diverse applications including IoT
(the Internet of Things). For the first time, Flowcode 8 enables users to target this hugely
popular Raspberry Pi family of boards. Flowcode is an intuitive way to program, either at
home, in the classroom or for industrial uses.
Alongside this, our E-blocks2 hardware platform also supports the Raspberry Pi and the
Raspberry Pi Shield is perfect for those who wish to integrate their Pi into the E-blocks
system.
Flowcode is chip independent and the Raspberry Pi is just one target of 33 different families
of microcontroller that we support. Hence most projects can easily be ported from one
target device to any other.
There are many advantages to creating Flowcode applications on Raspberry Pi, here are just
a few:
Flowcode uses secure shell, SSH, to transfer user applications to the Raspberry Pi.
SSH is easily enabled on the Raspberry Pi from the desktop.
Alternatively, this can be done by using raspi-config from the terminal.
From the Raspberry Pi menu, in the top left corner of the desktop, select “Raspberry Pi
Configuration” from the “Preferences” menu. In the “Interfaces” tab, select “Enabled” for
SSH and click OK. With SSH remote access enabled it is recommended that you to consider
changing the default pi user password (initial default is raspberry).
For this example project we will use a Raspberry Pi 3B+ with simply a LED and resistor
attached to GPIO 4 to demonstrate digital output.
Run Flowcode 9 and select New project.
Under Choose a Target right-select on any target device & select Search.
Within the search box, enter rpi then what version you have e.g rpi3b or rpi3b+ etc.
Press the Enter key or select Find Next.
Select New<RBI3B> Embedded Project:
Below Configure, enter the IP address for the Raspberry Pi together with the user name and
password (usually pi and raspberry).
Note: The “sudo” checkbox only needs to be enabled if PWM is used in the project.
Select Modify
Add a LED component, from the Components Libraries ribbon, Outputs menu, onto the
system panel. In the component properties window set the Connection property to
PORTG,4 (this represents GPIO 4).
Enable the Project Explorer by selecting it from the View ribbon.
Icons for example Loop, calculation box & Delay etc can be selected by clicking on the four
+ on the far left of the project explorer.
Component icons can be selected by clicking on Component’s icon of the project explorer.
Together with component icons to turn on and off the LED with 500mS delays as shown:
Save the project without any spaces (underscores are OK), and the flowchart can be
simulated on screen by clicking the Run button.
To run the project on the Raspberry Pi click the Build ribbon, Compile to Target… icon.
The project compilation window will display followed by a console (Putty) window whilst the
program runs on the Raspberry Pi and flashes the LED 10 times.
For this example we will use an E-blocks 2 Raspberry Pi upstream board (BL0036), with
Raspberry Pi 3B+ installed, and a Combo board (BL0114).
As with the previous example, Run Flowcode 9 and select New project.
Under Choose a Target right-select on any target device & select Search.
Within the search box, enter BL0036.
Press the Enter key or select Find Next.
Select New< BL0036> Embedded Project
Select Build - ribbon, Project Options.
Below Configure, enter the IP address for the Raspberry Pi together with the user name and
password (usually pi and raspberry).
Note: The “sudo” checkbox only needs to be enabled if PWM is used in the project.
Select Modify.
Select Components Libraries ribbon then select Search.
Enter bl0114 & left or right-click, Add to 2D panel
Combo BL0114 component will be added onto the dashboard.
From the Project Explorer window drag and drop a Start icon followed by a PrintString icon,
set the text field to “Hello World”.
Save the project (no spaces) and click the “Compile to chip” button in the task bar.
The project compilation window will run followed by a console (Putty) window whilst the
program runs on the Raspberry Pi target, and “Hello World” should appear on the display.
(Note: Ensure that the BL0114 “LCD” switch is set to ON)
Flowcode uses secure shell to transfer and run user applications, so whilst running you will
see the shell console window on the host PC. Note that in the case of programs with a
continuous loop this window will remain continuously present on the host PC.
Pressing CTRL and C in the window will abort the running program on the Raspberry Pi and
exit the console window.
The Flowcode DebugPrint component can be used to output text to the console window for
debugging or other purposes.
The shell console window runs concurrently with Flowcode such that ICD (In Circuit
Debugging) can be done with the use of the Flowcode Ghost features of the Matrix E-blocks
2 Raspberry Pi upstream board or Flowkit v2.
Running your programs independently of Flowcode
Once you have used Flowcode to create, compile and transfer your program to the
Raspberry PI, it will exist in the home directory of the selected user e.g. /home/pi
From there the application can be run via a serial console such as Putty or virtual desktop
such as VNC or RDP. VNC and SSH for Putty are enabled via the Raspberry Pi “Interface
Configuration” dialog.
Your application can also be configured to run from start-up of the Raspberry Pi by adding a
line to the /etc/rc.local file, but before the exit 0.
Editing this file must be done with root privileges, e.g. sudo nano /etc/rc.local
/home/pi/MyFlowcodeProject &
exit 0
Notes: It is vital that you do not use any spaces within the project name.
If you do, the code will not autorun on start up.
Underscores are allowed.
It is always best to add a space then & after the project name.
If you don’t then the Pi will not complete the
boot process.
Hardware peripherals on the Raspberry Pi are limited to UART, SPI, I 2C and PWM. To use
these peripherals with Flowcode they must be first be enabled via the Raspberry Pi
“Interface Configuration” dialog. There is no direct support for analogue or interrupts.
Analogue inputs and outputs would be implemented via external devices.
Also note that (at the date of this document) PWM requires programs to be run with root
privileges, for which Flowcode provides the option to run programs as sudo.
Flowcode provides software versions of SPI and I2C such that devices using these protocols
can be connected to any free GPIO pins. Due to the RTOS operation of Raspberry Pi, the bit
rate of these can depend upon other running processes. The same is the case for delays,
these can vary, the relative deviation being greater for shorter delays.