Fix SPI, SD for BIGTREETECH SKR Mini (#14287)
This commit is contained in:
parent
903863dcb6
commit
66d51272af
3 changed files with 51 additions and 48 deletions
|
@ -36,20 +36,14 @@
|
||||||
// Includes
|
// Includes
|
||||||
// --------------------------------------------------------------------------
|
// --------------------------------------------------------------------------
|
||||||
|
|
||||||
#include "HAL.h"
|
#include "../../inc/MarlinConfig.h"
|
||||||
#include "../shared/HAL_SPI.h"
|
|
||||||
#include "pins_arduino.h"
|
|
||||||
#include "spi_pins.h"
|
|
||||||
#include <SPI.h>
|
#include <SPI.h>
|
||||||
|
|
||||||
#include "../../inc/MarlinConfigPre.h"
|
|
||||||
|
|
||||||
// --------------------------------------------------------------------------
|
// --------------------------------------------------------------------------
|
||||||
// Public Variables
|
// Public Variables
|
||||||
// --------------------------------------------------------------------------
|
// --------------------------------------------------------------------------
|
||||||
|
|
||||||
static SPISettings spiConfig;
|
|
||||||
|
|
||||||
// --------------------------------------------------------------------------
|
// --------------------------------------------------------------------------
|
||||||
// Public functions
|
// Public functions
|
||||||
// --------------------------------------------------------------------------
|
// --------------------------------------------------------------------------
|
||||||
|
@ -82,8 +76,7 @@ void spiBegin() {
|
||||||
#if !PIN_EXISTS(SS)
|
#if !PIN_EXISTS(SS)
|
||||||
#error "SS_PIN not defined!"
|
#error "SS_PIN not defined!"
|
||||||
#endif
|
#endif
|
||||||
SET_OUTPUT(SS_PIN);
|
OUT_WRITE(SS_PIN, HIGH);
|
||||||
WRITE(SS_PIN, HIGH);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -105,8 +98,11 @@ void spiInit(uint8_t spiRate) {
|
||||||
case SPI_SPEED_6: clock = SPI_CLOCK_DIV64; break;
|
case SPI_SPEED_6: clock = SPI_CLOCK_DIV64; break;
|
||||||
default: clock = SPI_CLOCK_DIV2; // Default from the SPI library
|
default: clock = SPI_CLOCK_DIV2; // Default from the SPI library
|
||||||
}
|
}
|
||||||
spiConfig = SPISettings(clock, MSBFIRST, SPI_MODE0);
|
SPI.setModule(SPI_DEVICE);
|
||||||
SPI.begin();
|
SPI.begin();
|
||||||
|
SPI.setClockDivider(clock);
|
||||||
|
SPI.setBitOrder(MSBFIRST);
|
||||||
|
SPI.setDataMode(SPI_MODE0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -117,9 +113,9 @@ void spiInit(uint8_t spiRate) {
|
||||||
* @details
|
* @details
|
||||||
*/
|
*/
|
||||||
uint8_t spiRec(void) {
|
uint8_t spiRec(void) {
|
||||||
SPI.beginTransaction(spiConfig);
|
WRITE(SS_PIN, LOW);
|
||||||
uint8_t returnByte = SPI.transfer(0xFF);
|
uint8_t returnByte = SPI.transfer(0xFF);
|
||||||
SPI.endTransaction();
|
WRITE(SS_PIN, HIGH);
|
||||||
return returnByte;
|
return returnByte;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -133,9 +129,9 @@ uint8_t spiRec(void) {
|
||||||
* @details Uses DMA
|
* @details Uses DMA
|
||||||
*/
|
*/
|
||||||
void spiRead(uint8_t* buf, uint16_t nbyte) {
|
void spiRead(uint8_t* buf, uint16_t nbyte) {
|
||||||
SPI.beginTransaction(spiConfig);
|
WRITE(SS_PIN, LOW);
|
||||||
SPI.dmaTransfer(0, const_cast<uint8_t*>(buf), nbyte);
|
SPI.dmaTransfer(0, const_cast<uint8_t*>(buf), nbyte);
|
||||||
SPI.endTransaction();
|
WRITE(SS_PIN, HIGH);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -146,9 +142,9 @@ void spiRead(uint8_t* buf, uint16_t nbyte) {
|
||||||
* @details
|
* @details
|
||||||
*/
|
*/
|
||||||
void spiSend(uint8_t b) {
|
void spiSend(uint8_t b) {
|
||||||
SPI.beginTransaction(spiConfig);
|
WRITE(SS_PIN, LOW);
|
||||||
SPI.send(b);
|
SPI.send(b);
|
||||||
SPI.endTransaction();
|
WRITE(SS_PIN, HIGH);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -160,25 +156,10 @@ void spiSend(uint8_t b) {
|
||||||
* @details Use DMA
|
* @details Use DMA
|
||||||
*/
|
*/
|
||||||
void spiSendBlock(uint8_t token, const uint8_t* buf) {
|
void spiSendBlock(uint8_t token, const uint8_t* buf) {
|
||||||
SPI.beginTransaction(spiConfig);
|
WRITE(SS_PIN, LOW);
|
||||||
SPI.send(token);
|
SPI.send(token);
|
||||||
SPI.dmaSend(const_cast<uint8_t*>(buf), 512);
|
SPI.dmaSend(const_cast<uint8_t*>(buf), 512);
|
||||||
SPI.endTransaction();
|
WRITE(SS_PIN, HIGH);
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Begin SPI transaction, set clock, bit order, data mode
|
|
||||||
*
|
|
||||||
* @param spiClock Clock setting
|
|
||||||
* @param bitOrder Bit Order setting
|
|
||||||
* @param dataMode Data Mode setting
|
|
||||||
* @return Nothing
|
|
||||||
*
|
|
||||||
* @details Uses an SPI Config via SPISettings
|
|
||||||
*/
|
|
||||||
void spiBeginTransaction(uint32_t spiClock, uint8_t bitOrder, uint8_t dataMode) {
|
|
||||||
spiConfig = SPISettings(spiClock, (BitOrder)bitOrder, dataMode);
|
|
||||||
SPI.beginTransaction(spiConfig);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#if ENABLED(SPI_EEPROM)
|
#if ENABLED(SPI_EEPROM)
|
||||||
|
|
|
@ -21,13 +21,29 @@
|
||||||
/**
|
/**
|
||||||
* HAL for stm32duino.com based on Libmaple and compatible (STM32F1)
|
* HAL for stm32duino.com based on Libmaple and compatible (STM32F1)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Define SPI Pins: SCK, MISO, MOSI, SS
|
* Define SPI Pins: SCK, MISO, MOSI, SS
|
||||||
*
|
*
|
||||||
* Any PIN can be used for Chip Select (SS)
|
* Any PIN can be used for Chip Select (SS)
|
||||||
|
*
|
||||||
|
* SPI1 is enabled by default
|
||||||
*/
|
*/
|
||||||
#define SCK_PIN PA5
|
#if ENABLED(ENABLE_SPI3)
|
||||||
#define MISO_PIN PA6
|
#define SPI_DEVICE 3
|
||||||
#define MOSI_PIN PA7
|
#define SCK_PIN BOARD_SPI3_SCK_PIN
|
||||||
#define SS_PIN PA4
|
#define MISO_PIN BOARD_SPI3_MISO_PIN
|
||||||
|
#define MOSI_PIN BOARD_SPI3_MOSI_PIN
|
||||||
|
#define SS_PIN BOARD_SPI3_NSS_PIN
|
||||||
|
#elif ENABLED(ENABLE_SPI2)
|
||||||
|
#define SPI_DEVICE 2
|
||||||
|
#define SCK_PIN BOARD_SPI2_SCK_PIN
|
||||||
|
#define MISO_PIN BOARD_SPI2_MISO_PIN
|
||||||
|
#define MOSI_PIN BOARD_SPI2_MOSI_PIN
|
||||||
|
#define SS_PIN BOARD_SPI2_NSS_PIN
|
||||||
|
#else
|
||||||
|
#define SPI_DEVICE 1
|
||||||
|
#define SCK_PIN BOARD_SPI1_SCK_PIN
|
||||||
|
#define MISO_PIN BOARD_SPI1_MISO_PIN
|
||||||
|
#define MOSI_PIN BOARD_SPI1_MOSI_PIN
|
||||||
|
#define SS_PIN BOARD_SPI1_NSS_PIN
|
||||||
|
#endif
|
|
@ -28,6 +28,9 @@
|
||||||
#define BOARD_NAME "BIGTREE SKR mini V1.1"
|
#define BOARD_NAME "BIGTREE SKR mini V1.1"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
//#define DISABLE_DEBUG
|
||||||
|
#define DISABLE_JTAG
|
||||||
|
|
||||||
// Ignore temp readings during develpment.
|
// Ignore temp readings during develpment.
|
||||||
//#define BOGUS_TEMPERATURE_FAILSAFE_OVERRIDE
|
//#define BOGUS_TEMPERATURE_FAILSAFE_OVERRIDE
|
||||||
|
|
||||||
|
@ -91,11 +94,11 @@
|
||||||
/**
|
/**
|
||||||
* _____ _____
|
* _____ _____
|
||||||
* NC | · · | GND 5V | · · | GND
|
* NC | · · | GND 5V | · · | GND
|
||||||
* RESET | · · | 1.31(SD_DETECT) (LCD_D7) 1.23 | · · | 1.22 (LCD_D6)
|
* RESET | · · | PB9 (SD_DETECT) (LCD_D7) PC14 | · · | PC15 (LCD_D6)
|
||||||
* (MOSI)0.18 | · · | 3.25(BTN_EN2) (LCD_D5) 1.21 | · · | 1.20 (LCD_D4)
|
* (MOSI) PB5 | · · | PB8 (BTN_EN2) (LCD_D5) PB7 | · · | PC13 (LCD_D4)
|
||||||
* (SD_SS)0.16 | · · | 3.26(BTN_EN1) (LCD_RS) 1.19 | · · | 1.18 (LCD_EN)
|
* (SD_SS) PA15 | · · | PD2 (BTN_EN1) (LCD_RS) PC12 | · · | PB6 (LCD_EN)
|
||||||
* (SCK)0.15 | · · | 0.17(MISO) (BTN_ENC) 0.28 | · · | 1.30 (BEEPER)
|
* (SCK) PB3 | · · | PB4 (MISO) (BTN_ENC) PC11 | · · | PC10 (BEEPER)
|
||||||
*  ̄ ̄  ̄ ̄
|
*  ̄ ̄ ̄  ̄ ̄ ̄
|
||||||
* EXP2 EXP1
|
* EXP2 EXP1
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -123,10 +126,13 @@
|
||||||
// SD Card
|
// SD Card
|
||||||
//
|
//
|
||||||
|
|
||||||
// Marlin uses the SD drive attached to the LCD
|
// By default the onboard SD is enabled.
|
||||||
|
// To disable it and use an external SD (connected to LCD)
|
||||||
|
// enable STM32_SD_LCD.
|
||||||
|
|
||||||
//#define STM32_SD_LCD
|
//#define STM32_SD_LCD
|
||||||
|
|
||||||
#ifdef STM32_SD_LCD
|
#if ENABLED(STM32_SD_LCD)
|
||||||
#define SD_DETECT_PIN PB9
|
#define SD_DETECT_PIN PB9
|
||||||
#define ENABLE_SPI3
|
#define ENABLE_SPI3
|
||||||
#else
|
#else
|
||||||
|
|
Reference in a new issue