mirror of
https://github.com/firewalkwithm3/Sensor-Watch.git
synced 2024-11-22 11:10:29 +08:00
steps toward SPI support in watch library
This commit is contained in:
parent
22c072ac3f
commit
f98bc9bb4e
71
apps/Sensor Watch SPI Test/app.c
Normal file
71
apps/Sensor Watch SPI Test/app.c
Normal file
|
@ -0,0 +1,71 @@
|
|||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <peripheral_clk_config.h>
|
||||
#include "watch.h"
|
||||
|
||||
// NOTE: as of this writing (10/25/21) there is no SPI controller functionality in the watch library.
|
||||
// this is a very basic app to confirm that SPI is working, tested with board OSO-MISC-21-001 and a GD25Q16C Flash chip.
|
||||
// The updated SPI Flash sensor board design is OSO-MISC-21-017 (it's easier to build, 0603 passives instead of 0402's).
|
||||
|
||||
struct io_descriptor *io;
|
||||
struct spi_m_sync_descriptor SPI_0;
|
||||
|
||||
void app_init() {
|
||||
// SPI_0_CLOCK_init
|
||||
hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM3_GCLK_ID_CORE, CONF_GCLK_SERCOM3_CORE_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos));
|
||||
hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM3_GCLK_ID_SLOW, CONF_GCLK_SERCOM3_SLOW_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos));
|
||||
hri_mclk_set_APBCMASK_SERCOM3_bit(MCLK);
|
||||
|
||||
spi_m_sync_init(&SPI_0, SERCOM3);
|
||||
|
||||
// SPI_0_PORT_init
|
||||
gpio_set_pin_level(A3, true);
|
||||
gpio_set_pin_direction(A3, GPIO_DIRECTION_OUT);
|
||||
gpio_set_pin_function(A3, GPIO_PIN_FUNCTION_OFF);
|
||||
|
||||
gpio_set_pin_level(A2, false);
|
||||
gpio_set_pin_direction(A2, GPIO_DIRECTION_OUT);
|
||||
gpio_set_pin_function(A2, PINMUX_PB02C_SERCOM3_PAD0);
|
||||
|
||||
gpio_set_pin_direction(A4, GPIO_DIRECTION_IN);
|
||||
gpio_set_pin_pull_mode(A4, GPIO_PULL_OFF);
|
||||
gpio_set_pin_function(A4, PINMUX_PB00C_SERCOM3_PAD2);
|
||||
|
||||
gpio_set_pin_level(A1, false);
|
||||
gpio_set_pin_direction(A1, GPIO_DIRECTION_OUT);
|
||||
gpio_set_pin_function(A1, PINMUX_PB01C_SERCOM3_PAD3);
|
||||
|
||||
spi_m_sync_get_io_descriptor(&SPI_0, &io);
|
||||
spi_m_sync_enable(&SPI_0);
|
||||
}
|
||||
|
||||
void app_wake_from_backup() {
|
||||
}
|
||||
|
||||
void app_setup() {
|
||||
}
|
||||
|
||||
void app_prepare_for_standby() {
|
||||
}
|
||||
|
||||
void app_wake_from_standby() {
|
||||
}
|
||||
|
||||
static uint8_t get_id_command[4] = {0x9F};
|
||||
|
||||
bool app_loop() {
|
||||
watch_set_pin_level(A3, false);
|
||||
io_write(io, get_id_command, 1);
|
||||
uint8_t buf[3] = {0};
|
||||
|
||||
// should print 0, 0, 0
|
||||
printf("blank: %x, %x, %x\n", buf[0], buf[1], buf[2]);
|
||||
io_read(io, buf, 3);
|
||||
watch_set_pin_level(A3, true);
|
||||
// should print c8, 40, 15
|
||||
printf("ident: %x, %x, %x\n", buf[0], buf[1], buf[2]);
|
||||
|
||||
delay_ms(100);
|
||||
|
||||
return false;
|
||||
}
|
1
apps/Sensor Watch SPI Test/make/.gitignore
vendored
Executable file
1
apps/Sensor Watch SPI Test/make/.gitignore
vendored
Executable file
|
@ -0,0 +1 @@
|
|||
build/
|
10
apps/Sensor Watch SPI Test/make/Makefile
Executable file
10
apps/Sensor Watch SPI Test/make/Makefile
Executable file
|
@ -0,0 +1,10 @@
|
|||
TOP = ../../..
|
||||
include $(TOP)/make.mk
|
||||
|
||||
INCLUDES += \
|
||||
-I../
|
||||
|
||||
SRCS += \
|
||||
../app.c
|
||||
|
||||
include $(TOP)/rules.mk
|
1
make.mk
1
make.mk
|
@ -89,6 +89,7 @@ SRCS += \
|
|||
$(TOP)/watch-library/hal/src/hal_ext_irq.c \
|
||||
$(TOP)/watch-library/hal/src/hal_gpio.c \
|
||||
$(TOP)/watch-library/hal/src/hal_i2c_m_sync.c \
|
||||
$(TOP)/watch-library/hal/src/hal_spi_m_sync.c \
|
||||
$(TOP)/watch-library/hal/src/hal_init.c \
|
||||
$(TOP)/watch-library/hal/src/hal_io.c \
|
||||
$(TOP)/watch-library/hal/src/hal_slcd_sync.c \
|
||||
|
|
|
@ -143,7 +143,7 @@
|
|||
|
||||
// Enable configuration of module
|
||||
#ifndef CONF_SERCOM_3_SPI_ENABLE
|
||||
#define CONF_SERCOM_3_SPI_ENABLE 0
|
||||
#define CONF_SERCOM_3_SPI_ENABLE 1
|
||||
#endif
|
||||
|
||||
// Set module in SPI Master mode
|
||||
|
@ -180,7 +180,7 @@
|
|||
// <e> Advanced Configuration
|
||||
// <id> spi_master_advanced
|
||||
#ifndef CONF_SERCOM_3_SPI_ADVANCED
|
||||
#define CONF_SERCOM_3_SPI_ADVANCED 0
|
||||
#define CONF_SERCOM_3_SPI_ADVANCED 1
|
||||
#endif
|
||||
|
||||
// <o> Dummy byte <0x00-0x1ff>
|
||||
|
|
|
@ -32,6 +32,7 @@ extern "C" {
|
|||
#include <hal_sleep.h>
|
||||
#include <hal_ext_irq.h>
|
||||
#include <hal_i2c_m_sync.h>
|
||||
#include <hal_spi_m_sync.h>
|
||||
#include <hal_delay.h>
|
||||
#include <hal_slcd_sync.h>
|
||||
|
||||
|
|
Loading…
Reference in a new issue