diff --git a/libraries/SPI/src/SPI.cpp b/cores/arduino/SPI.cpp similarity index 99% rename from libraries/SPI/src/SPI.cpp rename to cores/arduino/SPI.cpp index 361bc96..d0eb6e4 100644 --- a/libraries/SPI/src/SPI.cpp +++ b/cores/arduino/SPI.cpp @@ -6,7 +6,7 @@ #include "fpioa.h" #include "stdint.h" #include "stdbool.h" -#include "spi.h" +#include "./kendryte-standalone-sdk/lib/drivers/include/spi.h" #include "SPI_hal.h" #include "sysctl.h" diff --git a/libraries/SPI/src/SPI.h b/cores/arduino/SPI.h similarity index 100% rename from libraries/SPI/src/SPI.h rename to cores/arduino/SPI.h diff --git a/libraries/Sipeed_ST7789/src/st7789.c b/cores/arduino/st7789.c similarity index 100% rename from libraries/Sipeed_ST7789/src/st7789.c rename to cores/arduino/st7789.c diff --git a/libraries/Sipeed_ST7789/src/st7789.h b/cores/arduino/st7789.h similarity index 98% rename from libraries/Sipeed_ST7789/src/st7789.h rename to cores/arduino/st7789.h index 31f0556..df1aede 100644 --- a/libraries/Sipeed_ST7789/src/st7789.h +++ b/cores/arduino/st7789.h @@ -4,7 +4,7 @@ #include #include "gpio.h" #include "fpioa.h" -#include "spi.h" +#include "./kendryte-standalone-sdk/lib/drivers/include/spi.h" #ifdef __cplusplus extern "C" { diff --git a/libraries/SPI/examples/basic/basic.ino b/libraries/SPI/examples/basic/basic.ino index 6070bfa..1debb86 100644 --- a/libraries/SPI/examples/basic/basic.ino +++ b/libraries/SPI/examples/basic/basic.ino @@ -1,20 +1,17 @@ #include "SPI.h" -SPIClass spi0(SPI0); void setup() { - spi0.setFrequency(10000000); - spi0.begin(27, 26, 28, 29); - spi0.transfer(1); - spi0.transfer(2); - spi0.transfer(3); - spi0.transfer(0xEE); + SPI.setFrequency(10000000); + SPI.begin(27, 26, 28, 29); + SPI.transfer(1); + SPI.transfer(2); + SPI.transfer(3); + SPI.transfer(0xEE); } void loop() { } - - diff --git a/libraries/SPI/examples/ssd1306/ssd1306.ino b/libraries/SPI/examples/ssd1306/ssd1306.ino deleted file mode 100644 index c1947f6..0000000 --- a/libraries/SPI/examples/ssd1306/ssd1306.ino +++ /dev/null @@ -1,429 +0,0 @@ -/************************************************************************** - This is an example for our Monochrome OLEDs based on SSD1306 drivers - - Pick one up today in the adafruit shop! - ------> http://www.adafruit.com/category/63_98 - - This example is for a 128x64 pixel display using SPI to communicate - 4 or 5 pins are required to interface. - - Adafruit invests time and resources providing this open - source code, please support Adafruit and open-source - hardware by purchasing products from Adafruit! - - Written by Limor Fried/Ladyada for Adafruit Industries, - with contributions from the open source community. - BSD license, check license.txt for more information - All text above, and the splash screen below must be - included in any redistribution. - **************************************************************************/ - -#include -// #include -#include -#include - -#define SCREEN_WIDTH 128 // OLED display width, in pixels -#define SCREEN_HEIGHT 64 // OLED display height, in pixels - -// Declaration for SSD1306 display connected using software SPI (default case): -#define OLED_MOSI 28 -#define OLED_CLK 27 -#define OLED_DC 21 -#define OLED_CS 19 -#define OLED_RESET 22 -#define OLED_FREQ 10000000 //10MHz - -// SPIClass spi0(SPI0); // equal to object SPI -SPIClass spi0(SPI0, OLED_CLK, -1, OLED_MOSI, -1, OLED_FREQ); // just for k210 - -Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &spi0, - OLED_DC, OLED_RESET, OLED_CS); - -/* Comment out above, uncomment this block to use hardware SPI -#define OLED_DC 6 -#define OLED_CS 7 -#define OLED_RESET 8 -Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, - &SPI, OLED_DC, OLED_RESET, OLED_CS); -*/ - -#define NUMFLAKES 10 // Number of snowflakes in the animation example - -#define LOGO_HEIGHT 16 -#define LOGO_WIDTH 16 -static const unsigned char PROGMEM logo_bmp[] = -{ B00000000, B11000000, - B00000001, B11000000, - B00000001, B11000000, - B00000011, B11100000, - B11110011, B11100000, - B11111110, B11111000, - B01111110, B11111111, - B00110011, B10011111, - B00011111, B11111100, - B00001101, B01110000, - B00011011, B10100000, - B00111111, B11100000, - B00111111, B11110000, - B01111100, B11110000, - B01110000, B01110000, - B00000000, B00110000 }; - -void setup() { - Serial.begin(9600); - spi0.setFrequency(10000000); - // SSD1306_SWITCHCAPVCC = generate display voltage from 3.3V internally - if(!display.begin(SSD1306_SWITCHCAPVCC)) { - Serial.println(F("SSD1306 allocation failed")); - for(;;); // Don't proceed, loop forever - } - - - // Show initial display buffer contents on the screen -- - // the library initializes this with an Adafruit splash screen. - display.display(); - delay(2000); // Pause for 2 seconds - - // Clear the buffer - display.clearDisplay(); - - // Draw a single pixel in white - display.drawPixel(10, 10, WHITE); - - // Show the display buffer on the screen. You MUST call display() after - // drawing commands to make them visible on screen! - display.display(); - delay(2000); - // display.display() is NOT necessary after every single drawing command, - // unless that's what you want...rather, you can batch up a bunch of - // drawing operations and then update the screen all at once by calling - // display.display(). These examples demonstrate both approaches... - - testdrawline(); // Draw many lines - - testdrawrect(); // Draw rectangles (outlines) - - testfillrect(); // Draw rectangles (filled) - - testdrawcircle(); // Draw circles (outlines) - - testfillcircle(); // Draw circles (filled) - - testdrawroundrect(); // Draw rounded rectangles (outlines) - - testfillroundrect(); // Draw rounded rectangles (filled) - - testdrawtriangle(); // Draw triangles (outlines) - - testfilltriangle(); // Draw triangles (filled) - - testdrawchar(); // Draw characters of the default font - - testdrawstyles(); // Draw 'stylized' characters - - testscrolltext(); // Draw scrolling text - - testdrawbitmap(); // Draw a small bitmap image - - // Invert and restore display, pausing in-between - display.invertDisplay(true); - delay(1000); - display.invertDisplay(false); - delay(1000); - - testanimate(logo_bmp, LOGO_WIDTH, LOGO_HEIGHT); // Animate bitmaps -} - -void loop() { -} - -void testdrawline() { - int16_t i; - - display.clearDisplay(); // Clear display buffer - - for(i=0; i=0; i-=4) { - display.drawLine(0, display.height()-1, display.width()-1, i, WHITE); - display.display(); - delay(1); - } - delay(250); - - display.clearDisplay(); - - for(i=display.width()-1; i>=0; i-=4) { - display.drawLine(display.width()-1, display.height()-1, i, 0, WHITE); - display.display(); - delay(1); - } - for(i=display.height()-1; i>=0; i-=4) { - display.drawLine(display.width()-1, display.height()-1, 0, i, WHITE); - display.display(); - delay(1); - } - delay(250); - - display.clearDisplay(); - - for(i=0; i0; i-=3) { - // The INVERSE color is used so circles alternate white/black - display.fillCircle(display.width() / 2, display.height() / 2, i, INVERSE); - display.display(); // Update screen with each newly-drawn circle - delay(1); - } - - delay(2000); -} - -void testdrawroundrect(void) { - display.clearDisplay(); - - for(int16_t i=0; i0; i-=5) { - // The INVERSE color is used so triangles alternate white/black - display.fillTriangle( - display.width()/2 , display.height()/2-i, - display.width()/2-i, display.height()/2+i, - display.width()/2+i, display.height()/2+i, INVERSE); - display.display(); - delay(1); - } - - delay(2000); -} - -void testdrawchar(void) { - display.clearDisplay(); - - display.setTextSize(1); // Normal 1:1 pixel scale - display.setTextColor(WHITE); // Draw white text - display.setCursor(0, 0); // Start at top-left corner - display.cp437(true); // Use full 256 char 'Code Page 437' font - - // Not all the characters will fit on the display. This is normal. - // Library will draw what it can and the rest will be clipped. - for(int16_t i=0; i<256; i++) { - if(i == '\n') display.write(' '); - else display.write(i); - } - - display.display(); - delay(2000); -} - -void testdrawstyles(void) { - display.clearDisplay(); - - display.setTextSize(1); // Normal 1:1 pixel scale - display.setTextColor(WHITE); // Draw white text - display.setCursor(0,0); // Start at top-left corner - display.println(F("Hello, world!")); - - display.setTextColor(BLACK, WHITE); // Draw 'inverse' text - display.println(3.141592); - - display.setTextSize(2); // Draw 2X-scale text - display.setTextColor(WHITE); - display.print(F("0x")); display.println(0xDEADBEEF, HEX); - - display.display(); - delay(2000); -} - -void testscrolltext(void) { - display.clearDisplay(); - - display.setTextSize(2); // Draw 2X-scale text - display.setTextColor(WHITE); - display.setCursor(10, 0); - display.println(F("scroll")); - display.display(); // Show initial text - delay(100); - - // Scroll in various directions, pausing in-between: - display.startscrollright(0x00, 0x0F); - delay(2000); - display.stopscroll(); - delay(1000); - display.startscrollleft(0x00, 0x0F); - delay(2000); - display.stopscroll(); - delay(1000); - display.startscrolldiagright(0x00, 0x07); - delay(2000); - display.startscrolldiagleft(0x00, 0x07); - delay(2000); - display.stopscroll(); - delay(1000); -} - -void testdrawbitmap(void) { - display.clearDisplay(); - - display.drawBitmap( - (display.width() - LOGO_WIDTH ) / 2, - (display.height() - LOGO_HEIGHT) / 2, - logo_bmp, LOGO_WIDTH, LOGO_HEIGHT, 1); - display.display(); - delay(1000); -} - -#define XPOS 0 // Indexes into the 'icons' array in function below -#define YPOS 1 -#define DELTAY 2 - -void testanimate(const uint8_t *bitmap, uint8_t w, uint8_t h) { - int8_t f, icons[NUMFLAKES][3]; - - // Initialize 'snowflake' positions - for(f=0; f< NUMFLAKES; f++) { - icons[f][XPOS] = random(1 - LOGO_WIDTH, display.width()); - icons[f][YPOS] = -LOGO_HEIGHT; - icons[f][DELTAY] = random(1, 6); - // Serial.print(F("x: ")); - // Serial.print(icons[f][XPOS], DEC); - // Serial.print(F(" y: ")); - // Serial.print(icons[f][YPOS], DEC); - // Serial.print(F(" dy: ")); - // Serial.println(icons[f][DELTAY], DEC); - } - - for(;;) { // Loop forever... - display.clearDisplay(); // Clear the display buffer - - // Draw each snowflake: - for(f=0; f< NUMFLAKES; f++) { - display.drawBitmap(icons[f][XPOS], icons[f][YPOS], bitmap, w, h, WHITE); - } - - display.display(); // Show the display buffer on the screen - delay(200); // Pause for 1/10 second - - // Then update coordinates of each flake... - for(f=0; f< NUMFLAKES; f++) { - icons[f][YPOS] += icons[f][DELTAY]; - // If snowflake is off the bottom of the screen... - if (icons[f][YPOS] >= display.height()) { - // Reinitialize to a random position, just off the top - icons[f][XPOS] = random(1 - LOGO_WIDTH, display.width()); - icons[f][YPOS] = -LOGO_HEIGHT; - icons[f][DELTAY] = random(1, 6); - } - } - } -} diff --git a/libraries/SPI/keywords.txt b/libraries/SPI/keywords.txt deleted file mode 100644 index 51ca29f..0000000 --- a/libraries/SPI/keywords.txt +++ /dev/null @@ -1,35 +0,0 @@ -####################################### -# Syntax Coloring Map SPI -####################################### - -####################################### -# Datatypes (KEYWORD1) -####################################### - -SPI KEYWORD1 - -####################################### -# Methods and Functions (KEYWORD2) -####################################### -begin KEYWORD2 -end KEYWORD2 -transfer KEYWORD2 -transferBytes KEYWORD2 -setBitOrder KEYWORD2 -setDataMode KEYWORD2 -setFrequency KEYWORD2 -beginTransaction KEYWORD2 -endTransaction KEYWORD2 -bus KEYWORD2 - - -####################################### -# Constants (LITERAL1) -####################################### -SPI_MODE0 LITERAL1 -SPI_MODE1 LITERAL1 -SPI_MODE2 LITERAL1 -SPI_MODE3 LITERAL1 -SPI_MSBFIRST LITERAL1 -SPI0 LITERAL1 -SPI1 LITERAL1 diff --git a/libraries/SPI/library.properties b/libraries/SPI/library.properties deleted file mode 100644 index 735fe2e..0000000 --- a/libraries/SPI/library.properties +++ /dev/null @@ -1,9 +0,0 @@ -name=SPI -version=1.0 -author=Neucrack -maintainer=Neucrack -sentence=Enables the communication with devices that use the Serial Peripheral Interface (SPI) Bus. -paragraph=SPI is a synchronous serial data protocol used by microcontrollers for communicating with one or more peripheral devices quickly over short distances. It uses three lines common to all devices (MISO, MOSI and SCK) and one specific for each device. -category=Communication -url=http://arduino.cc/en/Reference/SPI -architectures=k210 diff --git a/platform.txt b/platform.txt index dba822c..4b29615 100644 --- a/platform.txt +++ b/platform.txt @@ -18,7 +18,8 @@ compiler.size.cmd=riscv64-unknown-elf-size compiler.clib.path={runtime.tools.riscv64-unknown-elf-gcc.path}/include compiler.sdk.path={runtime.platform.path}/cores/arduino/kendryte-standalone-sdk/lib compiler.lib_hal_inc.path={runtime.platform.path}/cores/arduino/hal/include -compiler.preproc.flags=-I{build.system.path}/include -I{compiler.lib_hal_inc.path} -I{compiler.sdk.path}/bsp/include -I{compiler.sdk.path}/drivers/include -I{compiler.sdk.path}/utils/include -I{compiler.sdk.path}/freertos/conf -I{compiler.sdk.path}/freertos/include -I{compiler.sdk.path}/freertos/portable -I{compiler.clib.path} +compiler.cores.path={runtime.platform.path}/cores/arduino/ +compiler.preproc.flags=-I{build.system.path}/include -I{compiler.cores.path} -I{compiler.lib_hal_inc.path} -I{compiler.sdk.path}/bsp/include -I{compiler.sdk.path}/drivers/include -I{compiler.sdk.path}/utils/include -I{compiler.sdk.path}/freertos/conf -I{compiler.sdk.path}/freertos/include -I{compiler.sdk.path}/freertos/portable -I{compiler.clib.path} compiler.both.flags=-mcmodel=medany -mabi=lp64f -march=rv64imafc -fno-common -ffunction-sections -fdata-sections -fstrict-volatile-bitfields -fno-zero-initialized-in-bss -Os -ggdb -Wall -Werror=all -Wno-error=unused-function -Wno-error=unused-but-set-variable -Wno-error=unused-variable -Wno-error=deprecated-declarations -Wextra -Werror=frame-larger-than=65536 -Wno-unused-parameter -Wno-sign-compare -Wno-error=missing-braces -Wno-error=return-type -Wno-error=pointer-sign -Wno-missing-braces -Wno-strict-aliasing -Wno-implicit-fallthrough -Wno-missing-field-initializers -Wno-int-to-pointer-cast -Wno-error=comment -Wno-error=logical-not-parentheses -Wno-error=duplicate-decl-specifier -Wno-error=parentheses -lpthread