From f185f281e79aaad15ee1f8000d6c80586e09a23b Mon Sep 17 00:00:00 2001 From: Kelvin Ly Date: Fri, 15 Apr 2022 07:20:40 -0400 Subject: [PATCH] Working USB CDC UART test! NOTE: W25QL128B works great, IS25LP128 does not! Maybe eventually figure out why... --- .gitignore | 1 + CMakeLists.txt | 25 +++++++++++++++++ boards/walkie_talkies.h | 13 +++++++++ pico_sdk_import.cmake | 62 +++++++++++++++++++++++++++++++++++++++++ src/blink_test.c | 11 ++++++++ src/uart_test.c | 11 ++++++++ 6 files changed, 123 insertions(+) create mode 100644 CMakeLists.txt create mode 100644 boards/walkie_talkies.h create mode 100644 pico_sdk_import.cmake create mode 100644 src/blink_test.c create mode 100644 src/uart_test.c diff --git a/.gitignore b/.gitignore index 8ad1028..9662e1f 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,2 @@ *-backups/ +build/ diff --git a/CMakeLists.txt b/CMakeLists.txt new file mode 100644 index 0000000..069beea --- /dev/null +++ b/CMakeLists.txt @@ -0,0 +1,25 @@ +cmake_minimum_required(VERSION 3.12) + +set(PICO_BOARD walkie_talkies) +set(PICO_BOARD_HEADER_DIRS ${CMAKE_SOURCE_DIR}/boards/) + +# Pull in SDK (must be before project) +include(pico_sdk_import.cmake) + +project(walkie_talkies) + +pico_sdk_init() + +set(CMAKE_C_STANDARD 11) +set(CMAKE_CXX_STANDARD 17) + +add_executable(uart_test + src/uart_test.c + ) + +target_link_libraries(uart_test pico_stdlib) + +pico_enable_stdio_usb(uart_test 1) +pico_enable_stdio_uart(uart_test 0) + +pico_add_extra_outputs(uart_test) diff --git a/boards/walkie_talkies.h b/boards/walkie_talkies.h new file mode 100644 index 0000000..cbc05a4 --- /dev/null +++ b/boards/walkie_talkies.h @@ -0,0 +1,13 @@ +#ifndef _BOARDS_WALKIE_TALKIES +#define _BOARDS_WALKIE_TALKIES + +#include "boards/pico.h" + +#undef PICO_BOOT_STAGE2_CHOOSE_W25Q080 +#define PICO_BOOT_STAGE2_CHOOSE_W25Q080 1 +//#define PICO_BOOT_STAGE2_CHOOSE_IS25LP080 1 +//#define PICO_BOOT_STAGE2_CHOOSE_GENERIC_03H 1 + +#undef PICO_SMPS_MODE_PIN + +#endif diff --git a/pico_sdk_import.cmake b/pico_sdk_import.cmake new file mode 100644 index 0000000..28efe9e --- /dev/null +++ b/pico_sdk_import.cmake @@ -0,0 +1,62 @@ +# This is a copy of /external/pico_sdk_import.cmake + +# This can be dropped into an external project to help locate this SDK +# It should be include()ed prior to project() + +if (DEFINED ENV{PICO_SDK_PATH} AND (NOT PICO_SDK_PATH)) + set(PICO_SDK_PATH $ENV{PICO_SDK_PATH}) + message("Using PICO_SDK_PATH from environment ('${PICO_SDK_PATH}')") +endif () + +if (DEFINED ENV{PICO_SDK_FETCH_FROM_GIT} AND (NOT PICO_SDK_FETCH_FROM_GIT)) + set(PICO_SDK_FETCH_FROM_GIT $ENV{PICO_SDK_FETCH_FROM_GIT}) + message("Using PICO_SDK_FETCH_FROM_GIT from environment ('${PICO_SDK_FETCH_FROM_GIT}')") +endif () + +if (DEFINED ENV{PICO_SDK_FETCH_FROM_GIT_PATH} AND (NOT PICO_SDK_FETCH_FROM_GIT_PATH)) + set(PICO_SDK_FETCH_FROM_GIT_PATH $ENV{PICO_SDK_FETCH_FROM_GIT_PATH}) + message("Using PICO_SDK_FETCH_FROM_GIT_PATH from environment ('${PICO_SDK_FETCH_FROM_GIT_PATH}')") +endif () + +set(PICO_SDK_PATH "${PICO_SDK_PATH}" CACHE PATH "Path to the Raspberry Pi Pico SDK") +set(PICO_SDK_FETCH_FROM_GIT "${PICO_SDK_FETCH_FROM_GIT}" CACHE BOOL "Set to ON to fetch copy of SDK from git if not otherwise locatable") +set(PICO_SDK_FETCH_FROM_GIT_PATH "${PICO_SDK_FETCH_FROM_GIT_PATH}" CACHE FILEPATH "location to download SDK") + +if (NOT PICO_SDK_PATH) + if (PICO_SDK_FETCH_FROM_GIT) + include(FetchContent) + set(FETCHCONTENT_BASE_DIR_SAVE ${FETCHCONTENT_BASE_DIR}) + if (PICO_SDK_FETCH_FROM_GIT_PATH) + get_filename_component(FETCHCONTENT_BASE_DIR "${PICO_SDK_FETCH_FROM_GIT_PATH}" REALPATH BASE_DIR "${CMAKE_SOURCE_DIR}") + endif () + FetchContent_Declare( + pico_sdk + GIT_REPOSITORY https://github.com/raspberrypi/pico-sdk + GIT_TAG master + ) + if (NOT pico_sdk) + message("Downloading Raspberry Pi Pico SDK") + FetchContent_Populate(pico_sdk) + set(PICO_SDK_PATH ${pico_sdk_SOURCE_DIR}) + endif () + set(FETCHCONTENT_BASE_DIR ${FETCHCONTENT_BASE_DIR_SAVE}) + else () + message(FATAL_ERROR + "SDK location was not specified. Please set PICO_SDK_PATH or set PICO_SDK_FETCH_FROM_GIT to on to fetch from git." + ) + endif () +endif () + +get_filename_component(PICO_SDK_PATH "${PICO_SDK_PATH}" REALPATH BASE_DIR "${CMAKE_BINARY_DIR}") +if (NOT EXISTS ${PICO_SDK_PATH}) + message(FATAL_ERROR "Directory '${PICO_SDK_PATH}' not found") +endif () + +set(PICO_SDK_INIT_CMAKE_FILE ${PICO_SDK_PATH}/pico_sdk_init.cmake) +if (NOT EXISTS ${PICO_SDK_INIT_CMAKE_FILE}) + message(FATAL_ERROR "Directory '${PICO_SDK_PATH}' does not appear to contain the Raspberry Pi Pico SDK") +endif () + +set(PICO_SDK_PATH ${PICO_SDK_PATH} CACHE PATH "Path to the Raspberry Pi Pico SDK" FORCE) + +include(${PICO_SDK_INIT_CMAKE_FILE}) diff --git a/src/blink_test.c b/src/blink_test.c new file mode 100644 index 0000000..61d36c7 --- /dev/null +++ b/src/blink_test.c @@ -0,0 +1,11 @@ +#include +#include "pico/stdlib.h" + +int main() { + stdio_init_all(); + while (true) { + printf("test!\n"); + sleep_ms(250); + } + return 0; +} diff --git a/src/uart_test.c b/src/uart_test.c new file mode 100644 index 0000000..61d36c7 --- /dev/null +++ b/src/uart_test.c @@ -0,0 +1,11 @@ +#include +#include "pico/stdlib.h" + +int main() { + stdio_init_all(); + while (true) { + printf("test!\n"); + sleep_ms(250); + } + return 0; +}