Start of trail Clocks Analog Inputs Analog Outputs Digital Inputs Digital Outputs Encoder Inputs PWM Outputs Other Inputs Other Outputs Interrupts Watchdog Board-Specific Options Properties Targets See Also navigation bar

Raspberry Pi Zero W

Raspberry Pi Zero W

The Raspberry Pi Zero W is an embedded system built and sold by the Raspberry Pi Foundation, Inc. The Raspberry Pi Zero W driver provides access to the hardware I/O available on the Raspberry Pi Zero W board. The Raspberry Pi Zero W includes a BCM2835 ARMv6 processor (1 GHz, single core, 2M cache, 512 MB RAM). The I/O available with the Raspberry Pi Zero W include:

* Communications channels are accessed through the Stream API blocks, see Serial protocol, SPI protocol and I2C protocol.

The QUARC driver name for this card is raspberry_pi_0 .

To select the Raspberry Pi Zero W HIL board, pass raspberry_pi_0 as the card type to the hil_open function. Please note that only one raspberry_pi_0 "card" can be used on a Raspberry Pi Zero W at a time. The QUARC controller runs on the Raspberry Pi Zero W board and communicates with the hardware I/O directly.

Warning

Note that the Linux Raspbian target must be selected to use the Raspberry Pi Zero W board.

Communications

The communications ports provided on the Raspberry Pi Zero W board can be utilized through the QUARC Communications blockset and the Quanser Stream API (see QUARC Communications Protocols).

For SPI communications, a sample URI for communications would be:

spi://localhost:0?baud='1000000',phase='off',lsb='off',frame='0'

where the frame option selects the SPI CE line to frame the SPI bus transaction (0 or 1). Note that the SPI port must be enabled using the raspi-config utility for SPI communications to be used. Once the SPI port is enabled, the corresponding digital I/O (pins 19, 21, 23, 24 and 26) will no longer be available as digital I/O.

SPI can also be enabled via the /boot/config.txt file by setting spi=on in the Device Tree Overlay parameters. For example:

dtparam=spi=on

After changing /boot/config.txt, reboot the Raspberry Pi for the changes to take effect.

For I2C communications, a sample URI for communications would be:

i2c://localhost:0?baud='400000',address=0x69

where the address option specifies the I2C slave address. Note that the I2C port must be enabled using the raspi-config utility for I2C communications to be used. Once the I2C port is enabled, the corresponding digital I/O (pins 3 and 5) will no longer be available as digital I/O.

To set the baud rate for the I2C, the /boot/config.txt file must be edited and the Raspbery Pi rebooted. For example, to enable I2C and set the I2C baud rate to 400000 baud, change the Device Tree Overlay parameters to:

dtparam=i2c_arm=on,i2c_arm_baudrate=400000

After changing /boot/config.txt, reboot the Raspberry Pi for the changes to take effect.

For serial communications, a sample URI for communications would be:

serial://localhost:1?baud='115200',word='8',parity='none',stop='1'

Configuring the Raspberry Pi Zero W to support serial communications is a bit more involved. First, use the raspi-config utility to disable the serial port use by the kernel console. Then edit the /boot/config.txt file so that:

enable_uart=1

Also add the line:

dtoverlay=pi3-disable-bt

in order to disable bluetooth, which makes use of the UART otherwise (see Pi Zero W WiFi interference with TTY). Alternatively, to maintain bluetooth and use the UART, use the lines:

dtoverlay=pi3-miniuart.txt

core_freq=250

Refer to this Raspberry Pi forum topic for details.

After changing /boot/config.txt, reboot the Raspberry Pi for the changes to take effect. Use the gpio readall command to confirm that the TxD and RxD pins for the UART are in ALT0 mode. The serial port is /dev/ttyAMA0.

Clocks

The Raspberry Pi Zero W card does not support hardware clocks.

Analog Inputs

The Raspberry Pi Zero W card does not support analog inputs.

Analog Outputs

The Raspberry Pi Zero W card does not support analog outputs.

Digital Inputs

The Raspberry Pi Zero W supports 28 bidirectional digital I/O lines. Digital input channel numbers range from 0 to 27. Channels 0 and 1, however, are reserved for a HAT EEPROM I2C interface. A digital I/O line cannot be used as an input and output at the same time. Nor can it be used for communications (SPI, I2C or UART) or PWM at the same time.

Since the digital I/O lines may be individually programmed as inputs or outputs on the Raspberry Pi Zero W, all channels which will be used for digital inputs should be configured using the hil_set_digital_directions function.

Digital Outputs

The Raspberry Pi Zero W supports 28 bidirectional digital I/O lines. Digital output channel numbers range from 0 to 27. Channels 0 and 1, however, are reserved for a HAT EEPROM I2C interface. A digital I/O line cannot be used as an input and output at the same time. Nor can it be used for communications (SPI, I2C or UART) or PWM at the same time.

Since the digital I/O lines may be individually programmed as inputs or outputs on the Raspberry Pi Zero W, all the channels which will be used for digital outputs should be configured using the hil_set_digital_directions function.

Encoder Inputs

The Raspberry Pi Zero W card does not support encoder inputs.

PWM Outputs

The Raspberry Pi Zero W driver supports up to 2 PWM output channels. Hence, PWM output channels range from 0 to 1. Each PWM channel is completely independent and can have its own duty cycle and frequency.

Before the PWM channels may be used, they must be configured in the /boot/config.txt file and in the board-specific options. The /boot/config.txt file must be edited with root privileges. For example, to use the vi editor, enter the command:

sudo vi /boot/config.txt

in a terminal window.

The lines which must be added to the /boot/config.txt file depend on the number of PWM channels desired, and the pins to which they are assigned. The following table documents the lines that must be added to the /boot/config.txt file for each combination of options:

PWM 0

PWM 1

Line to Add

disabled

disabled

Do not add any lines

GPIO 12

disabled

dtoverlay=pwm,pin=12,func=4

GPIO 18

disabled

dtoverlay=pwm,pin=18,func=2

disabled

GPIO 13

dtoverlay=pwm,pin=13,func=4

disabled

GPIO 19

dtoverlay=pwm,pin=19,func=2

GPIO 12

GPIO 13

dtoverlay=pwm-2chan,pin=12,func=4,pin2=13,func2=4

GPIO 12

GPIO 19

dtoverlay=pwm-2chan,pin=12,func=4,pin2=19,func2=2

GPIO 18

GPIO 13

dtoverlay=pwm-2chan,pin=18,func=2,pin2=13,func2=4

GPIO 18

GPIO 19

dtoverlay=pwm-2chan,pin=18,func=2,pin2=19,func2=2

Warning

Note that once a GPIO is configured as a PWM channel then it will no longer be recognized as a digital I/O line.

In order to configure the PWM mode or frequency, use the hil_set_pwm_mode and hil_set_pwm_frequency functions respectively.

The PWM outputs are generic PWM outputs that are capable of producing the standard analog ESC protocols, namely standard PWM (1000us to 2000us), Oneshot125 (125us to 250us), Oneshot42 (42us to 84us) and Multishot (5us to 25us). They may also be used to drive R/C servos.

The PWM parameters for each of these protocols are tabulated below:

Protocol

PWM Frequency

Pulse Time Range

Duty Cycle Range

Standard PWM

50 Hz (20ms)

0.001 to 0.002 seconds (1ms to 2ms)

0.05 to 0.1 (5% to 10%)

Oneshot125

2000 Hz (500us)

125e-6 to 250e-6 seconds (125us to 250us)

0.25 to 0.5 (25% to 50%)

Oneshot42

11905 Hz (84us)

42e-6 to 84e-6 seconds (42us to 84us)

0.25 to 0.5 (25% to 50%)

Multishot

20000 Hz (50us)

5e-6 to 25e-6 seconds (5us to 25us)

0.1 to 0.5 (10% to 50%)

The PWM outputs are not restricted to these parameter values as they are generic PWM outputs. The maximum output frequency is 50 MHz. The number of bits of resolution decreases with increasing PWM output frequency.

The PWM mode is set using the hil_set_pwm_mode_c function. The duty cycle mode (PWM_DUTY_CYCLE_MODE) or time mode (PWM_TIME_MODE) is typically used when driving ESCs or R/C servos. The PWM output frequency (a.k.a., pulse rate) is set using the hil_set_pwm_frequency function.

Other Inputs

The Raspberry Pi Zero W card does not support other inputs.

Other Outputs

The Raspberry Pi Zero W card does not support other outputs.

Interrupts

The Raspberry Pi Zero W card, or its driver, does not support any interrupt sources.

Watchdog

The Raspberry Pi Zero W card does not support a watchdog timer.

Board-Specific Options

The Raspberry Pi Zero W has a number of board-specific options to control specialized functionality of the board. These options configure the PWM.

pwm0_en

This option is a boolean value that enable or disables PWM 0. If PWM 0 is disabled then the PWM pin may be used as a regular digital I/O. Valid values are 0, 1, false, true, off, on, no or yes.

pwm1_en

This option is a boolean value that enable or disables PWM 1. If PWM 1 is disabled then the PWM pin may be used as a regular digital I/O. Valid values are 0, 1, false, true, off, on, no or yes.

pwm0_pin

This option determines which pin will be used for PWM 0. Valid values are 12 or 18 corresponding to GPIO 12 or GPIO 18 respectively.

Warning

Note that once a GPIO is configured as a PWM channel then it will no longer be recognized as a digital I/O line.

pwm1_pin

This option determines which pin will be used for PWM 1. Valid values are 13 or 19 corresponding to GPIO 13 or GPIO 19 respectively.

Warning

Note that once a GPIO is configured as a PWM channel then it will no longer be recognized as a digital I/O line.

Properties

The Raspberry Pi Zero W card does not support any properties.

Connectors

The Raspberry Pi Zero W board has one connector for expansion I/O. The pinouts for this connector are listed below. Note that all pins are 3.3V and are not 5V tolerant unless marked otherwise. Exceeding these voltages may damage the board!

Raspberry Pi GPIO Connector

GPIO 21

4039

Ground

GPIO 20

3837

GPIO 26

GPIO 16

3635

GPIO 19 / → PWM 1

Ground

3433

GPIO 13 / → PWM 1

PWM 0 ← / GPIO 12

3231

GPIO 6

Ground

3029

GPIO 5

ID SC / GPIO 1

2827

GPIO 0 / ID SD

SPI CE1 ← / GPIO 7

2625

Ground

SPI CE0 ← / GPIO 8

2423

GPIO 11 / → SPI SCLK

GPIO 25

2221

GPIO 9 / ← SPI MISO

Ground

2019

GPIO 10 / → SPI MOSI

GPIO 24

1817

3.3V

GPIO 23

1615

GPIO 22

Ground

1413

GPIO 27

PWM 0 ← / GPIO 18

1211

GPIO 17

UART RXD → / GPIO 15

109

Ground

UART TXD ← / GPIO 14

87

GPIO 4

Ground

65

GPIO 3 / I2C SCL

5V

43

GPIO 2 / I2C SDA

5V

21

3.3V

Legend

→▯←

=

input

←▯→

=

output

↔▯↔

=

bidirectional I/O

=

3.3V signal

=

power

=

ground

Targets

Target

Supported

Comments

QUARC Win32 Target

No

Not supported.

QUARC Win64 Target

No

Not supported.

QUARC Linux Nvidia Target

No

Not supported.

QUARC Linux Raspberry Pi 3 Target

No

Not supported.

QUARC Linux Raspberry Pi 4 Target

No

Not supported.

QUARC Linux RT ARMv7 Target

No

Not supported.

QUARC Linux x64 Target

No

Not supported.

QUARC Linux DuoVero Target

No

Not supported.

QUARC Linux DuoVero 2016 Target

No

Not supported.

QUARC Linux Verdex Target

No

Not supported.

QUARC QNX x86 Target

No

Not supported.

Rapid Simulation (RSIM) Target

Yes

Supported with no communication to the hardware.

Normal simulation

Yes

Supported with no communication to the hardware.

See Also

 

navigation bar