mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
examples/pio_blink: Add PIO blink example
This commit is contained in:
parent
dd13df2943
commit
20069c2305
18
examples/pio_blink/Makefile
Normal file
18
examples/pio_blink/Makefile
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
APPLICATION = pio_blink
|
||||||
|
BOARD ?= rpi-pico
|
||||||
|
RIOTBASE ?= $(CURDIR)/../..
|
||||||
|
# The board rpi-pico-w has no LED pin so you have to select the pin by hand with:
|
||||||
|
# PIO_BLINK_PIN=GPIO_PIN\(x,y\) make ...
|
||||||
|
PIO_BLINK_PIN ?= GPIO_UNDEF
|
||||||
|
|
||||||
|
CFLAGS += -DPIO_BLINK_PIN=$(PIO_BLINK_PIN)
|
||||||
|
|
||||||
|
FEATURES_REQUIRED += periph_pio
|
||||||
|
|
||||||
|
DEVELHELP ?= 1
|
||||||
|
QUIET ?= 1
|
||||||
|
|
||||||
|
include $(RIOTBASE)/Makefile.include
|
||||||
|
|
||||||
|
DIRS += $(CPU)_pio_blink
|
||||||
|
USEMODULE += $(CPU)_pio_blink
|
47
examples/pio_blink/main.c
Normal file
47
examples/pio_blink/main.c
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2023 Otto-von-Guericke-Universität Magdeburg
|
||||||
|
*
|
||||||
|
* This file is subject to the terms and conditions of the GNU Lesser
|
||||||
|
* General Public License v2.1. See the file LICENSE in the top level
|
||||||
|
* directory for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "board.h"
|
||||||
|
#include "periph/pio.h"
|
||||||
|
|
||||||
|
/* see blink.c */
|
||||||
|
pio_program_t pio_blink_export_program(void);
|
||||||
|
|
||||||
|
/* see blink.c */
|
||||||
|
int pio_blink_write_program(pio_t pio, pio_program_t *pro);
|
||||||
|
|
||||||
|
/* see blink.c */
|
||||||
|
int pio_blink_init(pio_t pio, pio_sm_t sm, const pio_program_t *pro,
|
||||||
|
gpio_t pin);
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
pio_program_t blink = pio_blink_export_program();
|
||||||
|
pio_t pio;
|
||||||
|
pio_sm_t sm;
|
||||||
|
if (pio_alloc_program_sm_lock_any(&pio, &sm, &blink)) {
|
||||||
|
puts("No PIO resources available.");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
if (pio_blink_write_program(pio, &blink)) {
|
||||||
|
puts("Program could not be written.");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
gpio_t blink_gpio = PIO_BLINK_PIN; /* see Makefile */
|
||||||
|
if (blink_gpio == GPIO_UNDEF) {
|
||||||
|
#ifdef LED0_PIN
|
||||||
|
blink_gpio = LED0_PIN;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
if (pio_blink_init(pio, sm, &blink, blink_gpio)) {
|
||||||
|
puts("PIO blink initialization failed");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
pio_sm_start(pio, sm);
|
||||||
|
return 0;
|
||||||
|
}
|
5
examples/pio_blink/rpx0xx_pio_blink/Makefile
Normal file
5
examples/pio_blink/rpx0xx_pio_blink/Makefile
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
include $(RIOTBASE)/Makefile.base
|
||||||
|
include $(RIOTMAKE)/pio.inc.mk
|
||||||
|
|
||||||
|
# Force generation of not existing pio header file
|
||||||
|
blink.c: blink.pio.h
|
98
examples/pio_blink/rpx0xx_pio_blink/blink.c
Normal file
98
examples/pio_blink/rpx0xx_pio_blink/blink.c
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2023 Fabian Hüßler
|
||||||
|
*
|
||||||
|
* This file is subject to the terms and conditions of the GNU Lesser
|
||||||
|
* General Public License v2.1. See the file LICENSE in the top level
|
||||||
|
* directory for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include "pio/pio.h" /* this is the internal PIO header of the rpx0xx */
|
||||||
|
#include "blink.pio.h" /* this is the auto generated header from blink.pio */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Initialize the GPIO, which will be controlled by PIO
|
||||||
|
*
|
||||||
|
* Every PIO program should have a custom function to initialize GPIOs
|
||||||
|
* as required for the use case. The first (0) mapped set-pin (GPIO @p pin)
|
||||||
|
* is initially configured as low output pin.
|
||||||
|
*
|
||||||
|
* @param[in] pio PIO index of the PIO to use
|
||||||
|
* @param[in] sm PIO state machine index of the SM to use
|
||||||
|
* @param[in] pin GPIO pin to be mapped as first set-pin (base)
|
||||||
|
*/
|
||||||
|
static void pio_blink_init_pins(pio_t pio, pio_sm_t sm, gpio_t pin)
|
||||||
|
{
|
||||||
|
pio_gpio_init_t init = {
|
||||||
|
.gpio_direction = PIO_GPIO_INIT_OUT(0),
|
||||||
|
.gpio_state = PIO_GPIO_INIT_LOW(0),
|
||||||
|
.gpio_base = pin,
|
||||||
|
.gpio_count = 1
|
||||||
|
};
|
||||||
|
pio_sm_set_set_pins_init(pio, sm, &init);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Create an unmapped blinky PIO program
|
||||||
|
*
|
||||||
|
* A PIO program needs a kind of constructor (in OOP).
|
||||||
|
*
|
||||||
|
* @return Blinky program
|
||||||
|
*/
|
||||||
|
pio_program_t pio_blink_export_program(void)
|
||||||
|
{
|
||||||
|
/* Call auto-generated function to retrieve a PIO program handle.
|
||||||
|
The program is not loaded yet. */
|
||||||
|
return pio_blink_create_program();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Write blink program to instruction memory
|
||||||
|
*
|
||||||
|
* A PIO program needs a function to write the instructions
|
||||||
|
* to the allocated program memory.
|
||||||
|
*
|
||||||
|
* @param[in] pio PIO index
|
||||||
|
* @param[in] pro Allocated program
|
||||||
|
*
|
||||||
|
* @return 0 on success or negative number on error
|
||||||
|
*/
|
||||||
|
int pio_blink_write_program(pio_t pio, pio_program_t *pro)
|
||||||
|
{
|
||||||
|
pio_instr_t instr[] = PIO_BLINK_PROGRAM;
|
||||||
|
int ret;
|
||||||
|
if ((ret = pio_write_program(pio, pro, instr))) {
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Initialize and start running a blinky PIO program from an
|
||||||
|
* allocated program @p pro and PIO @p pio and locked state machine @p sm
|
||||||
|
*
|
||||||
|
* A PIO program needs a function to initialize a PIO state machine to run a program.
|
||||||
|
*
|
||||||
|
* @param[in] pio PIO index
|
||||||
|
* @param[in] sm PIO state machine index
|
||||||
|
* @param[in] pro Allocated program
|
||||||
|
* @param[in] pin GPIO pin to use for blinking
|
||||||
|
*
|
||||||
|
* @return 0 on successful program start or negative number on error
|
||||||
|
*/
|
||||||
|
int pio_blink_init(pio_t pio, pio_sm_t sm, const pio_program_t *pro,
|
||||||
|
gpio_t pin)
|
||||||
|
{
|
||||||
|
pio_program_conf_t conf = PIO_BLINK_PROGRAM_CONF;
|
||||||
|
int ret;
|
||||||
|
if (pin >= 32) {
|
||||||
|
return -ENOTSUP;
|
||||||
|
}
|
||||||
|
if ((ret = pio_sm_init_common(pio, sm, pro, &conf))) {
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
pio_sm_set_clkdiv(pio, sm, pio_sm_clkdiv(2000));
|
||||||
|
pio_blink_init_pins(pio, sm, pin);
|
||||||
|
pio_sm_restart(pio, sm);
|
||||||
|
return 0;
|
||||||
|
}
|
22
examples/pio_blink/rpx0xx_pio_blink/blink.pio
Normal file
22
examples/pio_blink/rpx0xx_pio_blink/blink.pio
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
;
|
||||||
|
; Copyright (c) 2020 Raspberry Pi (Trading) Ltd.
|
||||||
|
;
|
||||||
|
; SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
;
|
||||||
|
|
||||||
|
.program blink
|
||||||
|
|
||||||
|
.wrap_target
|
||||||
|
begin:
|
||||||
|
set pins, 0 [31]
|
||||||
|
nop [31]
|
||||||
|
nop [31]
|
||||||
|
nop [31]
|
||||||
|
nop [31]
|
||||||
|
set pins, 1 [31]
|
||||||
|
nop [31]
|
||||||
|
nop [31]
|
||||||
|
nop [31]
|
||||||
|
nop [31]
|
||||||
|
jmp begin
|
||||||
|
.wrap
|
Loading…
Reference in New Issue
Block a user