Apug

Download as pdf or txt
Download as pdf or txt
You are on page 1of 11

DLI Atomic Pi user guide

20190206T074743Z
CONTENTS 1

Contents

1 Overview 2

2 GPIO pin reference 3

3 BNO055 sensor reference 6

4 Custom bus configuration reference 7

5 Technical support 8

6 Open source code 9

DLI Atomic Pi user guide: 20190206T074743Z


2 CONTENTS

1 Overview

Congratulations on selecting Atomic Pi, an performant embedded controller with peripherals.

Atomic Pi has the following interfaces:

• HDMI for video and sound output;

• Additional XMOS Mayfield audio output;

• 3 user-accessible UART ports;

• USB 3.0 for connecting peripherals;

• microSD for storage (in addition to on-board eMMC);

• Ethernet, WiFi and Bluetooth connectivity options;

• 6 user-configurable GPIOs, with built-in support for running I2C or SPI bus masters over them.

The unit ships with a Bosch BNO055 absolute orientation sensor, connected via an internal I2C bus.

The firmware is based on open-source code which is provided to give you the option to build totally custom firmware.

Please contact technical support in case of any problems.

DLI Atomic Pi user guide: 20190206T074743Z


2 GPIO pin reference 3

2 GPIO pin reference

The Atomic Pi has 6 GPIO pins available to users, and additional lines connected to the BNO055 sensor. Here's a
overview of them.

2.1 Addressing

In order to use GPIO pins from Linux, it's important to understand how they are addressed in various situations.

Each GPIO has a global number in the integer GPIO namespace used with the legacy GPIO interface (e.g. through
sysfs). This is considered a legacy interface but there are currently no plans to remove it. However, in addition
to that, recent Linux kernels expose GPIO chips, which are basically named sets of GPIOs of the same hardware
origin with a single base number; GPIOs are numbered sequentially within a chip, but the global GPIO namespace
itself needn't be contiguous.

2.2 Pin description

Generally available pins:

Schematic name GPIO chip id Chip pin number Global pin number Connected devices
ISH_GPIO_0 gpiochip3 21 335
ISH_GPIO_1 gpiochip3 18 332 LED Green (active low)
ISH_GPIO_2 gpiochip3 24 338 LED Yellow (active low)
ISH_GPIO_3 gpiochip3 15 329
ISH_GPIO_4 gpiochip3 22 336
ISH_GPIO_7 gpiochip3 16 330

These signals are available on the Atomic Pi's 26-pin connector. If you have the Enchilada breakout board, the
signals are available as on it as well. Connector pin numbers are as follows:

Schematic name 26-pin connector number Enchilada connector number


ISH_GPIO_0 24 9
ISH_GPIO_1 25 10
ISH_GPIO_2 26 11
ISH_GPIO_3 18 3
ISH_GPIO_4 19 4
ISH_GPIO_7 20 5

Other pins (not on the 26-pin connector or the Enchilada connector):

Schematic name GPIO chip id Chip pin number Global pin number Connected devices
I2C2_3P3_SDA gpiochip0 62 476 BNO055 I2C SDA
I2C2_3P3_SCL gpiochip0 66 480 BNO055 I2C SCL
AU_MIC_SEL gpiochip1 0 341 XMOS Audio mi-
crophone loopback
selector
XMOS_RESET gpiochip1 8 349 XMOS Audio reset (ac-
tive low)

DLI Atomic Pi user guide: 20190206T074743Z


4 CONTENTS

Schematic name GPIO chip id Chip pin number Global pin number Connected devices
BN_INT gpiochip1 17 358 BNO055-generated in-
terrupt (active low)
BN_RESET gpiochip1 25 366 BNO055 reset (active
low)

The XMOS_RESET line is controlled by a system service, atomicpi-hold-xmos, to bring up the XMOS Audio
device.

The AU_MIC_SEL line must be configured to logical 0 to record audio from microphone, or to logical 1 for loopback
(recording audio being played back).

Using the interrupt and reset lines is not strictly required for BNO055 operation. Additional devices may be con-
nected to its I2C bus but that would require soldering.

Note that the system core contains other GPIO pins, some connected to internal circuits. Reading the datasheet is
strongly recommended before attempting to configure them!

2.3 Using GPIOs from the shell

GPIO pin constants can be pulled in by including /usr/lib/atomicpi.sh:


. /usr/lib/atomicpi.sh

The traditional sysfs way of manipulating GPIOs from the command line is documented at:

https://www.kernel.org/doc/Documentation/gpio/sysfs.txt

It is listed as deprecated but there are no plans to remove it.


. /usr/lib/atomicpi.sh
echo $ATOMICPI_ISH_GPIO_1 >/sys/class/gpio/export
echo $ATOMICPI_ISH_GPIO_2 >/sys/class/gpio/export
echo low >/sys/class/gpio/$ATOMICPI_ISH_GPIO_1/direction
while true; do
echo low > /sys/class/gpio/$ATOMICPI_ISH_GPIO_2/direction
sleep 1
echo high > /sys/class/gpio/$ATOMICPI_ISH_GPIO_2/direction
sleep 1
done
echo $ATOMICPI_ISH_GPIO_2 >/sys/class/gpio/unexport
echo $ATOMICPI_ISH_GPIO_1 >/sys/class/gpio/unexport

Constants storing global GPIO indices are prefixed by ATOMICPI_.

Additionally, several utilities allow GPIO control using the more modern interface (and chip id + pin index
addressing):

Constants storing "<chip id> <pin index>" are prefixed by ATOMICPICHIP_. Due to shell expansion rules,
${ATOMICPICHIP_ISH_GPIO_0} (without quotes) will expand to two arguments, the chip id and the pin index,
which is what most of the following utilities expect.

List all GPIO chips, print their labels and number of GPIO lines:
gpiodetect

Find a GPIO line by name (the output of this command can be used as input for gpioget/gpioset):

DLI Atomic Pi user guide: 20190206T074743Z


2 GPIO pin reference 5

gpiofind <name>

Print information about all lines of the specified GPIO chip(s) (or all chips if none are specified):
gpioinfo <gpiochip1> ...

Read line value(s) from a GPIO chip:


gpioget [-l] <chip name/number> <offset 1> <offset 2> ...

Options:
-l, --active-low: set the line active state to low

Set GPIO line values of a GPIO chip:


gpioset [OPTIONS] <chip name/number> <offset1>=<value1> <offset2>=<value2> ...

Options:
-l, --active-low: set the line active state to low
-m, --mode=[exit|wait|time|signal] (defaults to 'exit'):
tell the program what to do after setting values
-s, --sec=SEC: specify the number of seconds to wait (only valid for --mode= ←-
,→ time)
-u, --usec=USEC: specify the number of microseconds to wait (only valid for -- ←-
,→ mode=time)
-b, --background: after setting values: detach from the controlling terminal

Modes:
exit: set values and exit immediately
wait: set values and wait for user to press ENTER
time: set values and sleep for a specified amount of time
signal: set values and wait for SIGINT or SIGTERM

Wait for events on GPIO lines:


gpiomon [OPTIONS] <chip name/number> <offset 1> <offset 2> ...

Options:
-l, --active-low: set the line active state to low
-n, --num-events=NUM: exit after processing NUM events
-s, --silent: don't print event info
-r, --rising-edge: only process rising edge events
-f, --falling-edge: only process falling edge events
-F, --format=FMT specify custom output format

Format specifiers:
%o: GPIO line offset
%e: event type (0 - falling edge, 1 rising edge)
%s: seconds part of the event timestamp
%n: nanoseconds part of the event timestamp

See /usr/lib/atomicpi.sh for details.

2.4 Using GPIOs from Node.JS

var atomicpi = require("atomicpi");


var GPIO = require("sysfs-gpio");

DLI Atomic Pi user guide: 20190206T074743Z


6 CONTENTS

Control by signal ID GPIO.export(atomicpi.signals.ISH_GPIO_0.global_idx, (pin) => { pin.out(); pin.high(); });


Control with signal ID lookup on Enchilada connector first GPIO.export(atomicpi.signals[atomicpi.connectors.←-
enchilada.leds.green].global_idx, (pin) => { pin.out(); pin.low(); }); process.stdin.resume();

atomicpi.signals contains a mapping from the signal name (e.g. "ISH_GPIO_0") to {chip,chip_←-
idx,global_idx}. You will need global_idx most of the time as sysfs-gpio uses the legacy sysfs
interface.

See /usr/lib/node/atomicpi.js and sysfs-gpio documentation for details.

2.5 Using GPIOs from Python

import atomicpi
import gpio as GPIO
# Control by signal ID
GPIO_0=atomicpi.signals.ISH_GPIO_0.global_idx
GPIO.setup(GPIO_0, GPIO.OUT)
GPIO.output(GPIO_0, True)
# Control with signal ID lookup on Enchilada connector first
GREEN_LED=atomicpi.signals[atomicpi.connectors.enchilada.leds.green].global_idx
GPIO.setup(GREEN_LED, GPIO.OUT)
GPIO.output(GREEN_LED, False)
GPIO.cleanup(GPIO_0)
GPIO.cleanup(GREEN_LED)

atomicpi.signals contains a mapping from the signal name (e.g. "ISH_GPIO_0") to {chip,chip_←-
idx,global_idx}. You will need global_idx most of the time as gpio uses the legacy sysfs interface.

The gpio library largely mimics the Raspberry Pi RPIO library.

See /usr/lib/python/dist-packages/atomicpi.py and gpio documentation for details.

3 BNO055 sensor reference

The Atomic Pi has a BNO055 absolute orientation sensor attached to a custom GPIO I2C bus (configured as I2C
bus 50 by default). It combines an accelerometer, a gyroscope and a magnetometer.

You may need to calibrate the sensor to obtain desired accuracy. Consult the Bosch Sensortec reference
for details.

3.1 Using BNO055 from Node.JS

var BNO055 = require('bno055');


var async = require('async');

BNO055 is configured on I2C bus 50 in /etc/i2c-gpio-custom.d/bno055-bus by default var imu = new BN←-
O055({device:"/dev/i2c-50"}); imu.beginNDOF(function() { console.info('imu running'); setInterval(function() {
async.series({ calibrationStatus: imu.getCalibrationStatus.bind(imu), quaternion: imu.getQuaternion.bind(imu),
euler: imu.getEuler.bind(imu), linearAcceleration: imu.getLinearAcceleration.bind(imu) }, function(err, results) {
console.info( 'imu: ', JSON.stringify(results) ); }); }, 1000); });

See bno055 package documentation for details.

3.2 Using BNO055 from Python

DLI Atomic Pi user guide: 20190206T074743Z


4 Custom bus configuration reference 7

from Adafruit_BNO055.BNO055 import BNO055


from time import sleep
# BNO055 is configured on I2C bus 50 in /etc/i2c-gpio-custom.d/bno055-bus by ←-
,→ default
sensor = BNO055(busnum=50)
assert(sensor.begin())
while True:
print('Euler=%0.2f:%0.2f:%0.2f Quaternion=%0.2f:%0.2f:%0.2f:%0.2f Temp=%0.2fC ←-
,→ Mag=%0.2f:%0.2f:%0.2f Gyr=%0.2f:%0.2f:%0.2f Accel=%0.2f:%0.2f:%0.2f ←-
,→ LAccel=%0.2f:%0.2f:%0.2f Gravity=%0.2f:%0.2f:%0.2f'%(
sensor.read_euler() +
sensor.read_quaternion() +
(sensor.read_temp(),) +
sensor.read_magnetometer() +
sensor.read_gyroscope() +
sensor.read_accelerometer() +
sensor.read_linear_acceleration() +
sensor.read_gravity()
))
sleep(1)

See Adafruit_BNO055 package documentation for details.

4 Custom bus configuration reference

The Atomic Pi can act as a I2C or SPI bus master on a custom set of GPIOs. This is implemented using kernel
modules i2c-gpio-custom and spi-gpio-custom (sources in /usr/src/, editable and buildable using D←-
KMS).

The kernel modules are by default configured using systemd services i2c-gpio-custom.service and
spi-gpio-custom.service. Modules are loaded on service start and unloaded on service stop.

Services collect bus configuration items from /etc/i2c-gpio-custom.d and /etc/spi-gpio-custom.d


and set up command lines for the modules, which have form 'bus0=<id0>,<args...> bus1=<id1>,<args...>...'.
Every bus needs to have a unique numeric ID (DLI default ids start with 50; it's recommended to start custom bus
numbering with 100). GPIO pins referenced in the arguments must be specified using their global GPIO indices.
See the README files in those directories for more information.

DLI Atomic Pi user guide: 20190206T074743Z


8 CONTENTS

5 Technical support

To save time, please have a look at the product FAQ page solutions. You may FAX questions to (408) 541-8459 or
email: support@digital-loggers.com.

For phone support, call (408) 330-5599 with the following so we can better serve you:

• the firmware version level installed;

• a description of the Ethernet devices connected to your unit, for example, a 10/100 PC and crossover cable,
if it's relevant;

• a description of the WiFi or Bluetooth devices connected to your unit, i.e. their manufacturers and model
numbers, if it's relevant.

DLI Atomic Pi user guide: 20190206T074743Z


6 Open source code 9

6 Open source code

Open-source components used in the Atomic Pi are mostly unmodified, as they are in the Ubuntu Bionic distribution
(see apt list --installed).

Most additional components developed specifically for the Atomic Pi are provided in source form in the
firmware already. For example, avrdude support for the ATMega328PB is provided in source form as part
of /etc/avrdude.conf (it is not original).

Sources for the binary I2C and SPI custom-GPIO bus master kernel modules are provided in /usr/src in (configured
to be used by DKMS). Updated source versions will be available from Git repositories located at:

https://github.com/digitalloggers/i2c-gpio-custom.git

https://github.com/digitalloggers/spi-gpio-custom.git

Updated versions of the BNO055 sensor library for Node.JS will be available at:

https://github.com/digitalloggers/node-BNO055.git

DLI cannot provide warranty or technical support for modified units; this includes units with custom firmware.

DLI Atomic Pi user guide: 20190206T074743Z

You might also like