Skip to content

Commit 9555d25

Browse files
author
rogerclarkmelbourne
committed
Merge branch 'fix_spi_ss'
2 parents efd8ecb + 657d6da commit 9555d25

4 files changed

Lines changed: 20 additions & 6 deletions

File tree

STM32F1/cores/maple/libmaple/gpio_f1.c

Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -138,6 +138,23 @@ void gpio_set_mode(gpio_dev *dev, uint8 pin, gpio_pin_mode mode) {
138138
}
139139
}
140140

141+
gpio_pin_mode gpio_get_mode(gpio_dev *dev, uint8 pin) {
142+
gpio_reg_map *regs = dev->regs;
143+
__io uint32 *cr = &regs->CRL + (pin >> 3);
144+
uint32 shift = (pin & 0x7) * 4;
145+
uint32 tmp = *cr;
146+
147+
uint32 crMode = (*cr>>shift) & 0x0F;
148+
149+
// could be pull up or pull down. Nee to check the ODR
150+
if (crMode==GPIO_INPUT_PD && ((regs->ODR >> pin) & 0x01) !=0 )
151+
{
152+
crMode = GPIO_INPUT_PU;
153+
}
154+
155+
return(crMode);
156+
}
157+
141158
/*
142159
* AFIO
143160
*/

STM32F1/cores/maple/libmaple/spi_f1.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -63,7 +63,7 @@ void spi_config_gpios(spi_dev *ignored,
6363
uint8 miso_bit,
6464
uint8 mosi_bit) {
6565
if (as_master) {
66-
gpio_set_mode(nss_dev, nss_bit, GPIO_AF_OUTPUT_PP);
66+
// gpio_set_mode(nss_dev, nss_bit, GPIO_AF_OUTPUT_PP);// Roger Clark. Commented out, so that NSS can be driven as a normal GPIO pin during SPI use
6767
gpio_set_mode(comm_dev, sck_bit, GPIO_AF_OUTPUT_PP);
6868
gpio_set_mode(comm_dev, miso_bit, GPIO_INPUT_FLOATING);
6969
gpio_set_mode(comm_dev, mosi_bit, GPIO_AF_OUTPUT_PP);

STM32F1/libraries/SPI/src/SPI.cpp

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -119,10 +119,7 @@ SPIClass::SPIClass(uint32 spi_num) {
119119
*/
120120

121121
void SPIClass::begin(void) {
122-
if (dataMode >= 4) {
123-
ASSERT(0);
124-
return;
125-
}
122+
126123
uint32 flags = ((bitOrder == MSBFIRST ? SPI_FRAME_MSB : SPI_FRAME_LSB) | SPI_DFF_8_BIT | SPI_SW_SLAVE | SPI_SOFT_SS);
127124
spi_init(spi_d);
128125
configure_gpios(spi_d, 1);

STM32F1/system/libmaple/include/libmaple/gpio.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -71,7 +71,7 @@ void gpio_init(gpio_dev *dev);
7171
void gpio_init_all(void);
7272
/* TODO flags argument version? */
7373
void gpio_set_mode(gpio_dev *dev, uint8 pin, gpio_pin_mode mode);
74-
74+
gpio_pin_mode gpio_get_mode(gpio_dev *dev, uint8 pin);
7575
/**
7676
* @brief Get a GPIO port's corresponding EXTI port configuration.
7777
* @param dev GPIO port whose exti_cfg to return.

0 commit comments

Comments
 (0)