Skip to content

Commit 5015036

Browse files
authored
Merge pull request adafruit#1758 from pewpew-game/fourwire-frequency
Stop hard-coding SPI frequency in FourWire
2 parents 672a102 + 049b9ca commit 5015036

File tree

6 files changed

+36
-3
lines changed

6 files changed

+36
-3
lines changed

ports/atmel-samd/boards/hallowing_m0_express/board.c

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -29,6 +29,7 @@
2929
#include "shared-bindings/displayio/FourWire.h"
3030
#include "shared-module/displayio/__init__.h"
3131
#include "shared-module/displayio/mipi_constants.h"
32+
#include "shared-bindings/busio/SPI.h"
3233

3334
#include "tick.h"
3435

@@ -71,8 +72,10 @@ uint8_t display_init_sequence[] = {
7172
void board_init(void) {
7273
displayio_fourwire_obj_t* bus = &displays[0].fourwire_bus;
7374
bus->base.type = &displayio_fourwire_type;
75+
busio_spi_obj_t *spi = board_spi();
76+
common_hal_busio_spi_configure(spi, 12000000, 0, 0, 8);
7477
common_hal_displayio_fourwire_construct(bus,
75-
board_spi(),
78+
spi,
7679
&pin_PA28, // Command or data
7780
&pin_PA01, // Chip select
7881
&pin_PA27); // Reset

ports/atmel-samd/common-hal/busio/SPI.c

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -361,3 +361,13 @@ bool common_hal_busio_spi_transfer(busio_spi_obj_t *self, uint8_t *data_out, uin
361361
uint32_t common_hal_busio_spi_get_frequency(busio_spi_obj_t* self) {
362362
return samd_peripherals_spi_baud_reg_value_to_baudrate(hri_sercomspi_read_BAUD_reg(self->spi_desc.dev.prvt));
363363
}
364+
365+
uint8_t common_hal_busio_spi_get_phase(busio_spi_obj_t* self) {
366+
void * hw = self->spi_desc.dev.prvt;
367+
return hri_sercomspi_get_CTRLA_CPHA_bit(hw);
368+
}
369+
370+
uint8_t common_hal_busio_spi_get_polarity(busio_spi_obj_t* self) {
371+
void * hw = self->spi_desc.dev.prvt;
372+
return hri_sercomspi_get_CTRLA_CPOL_bit(hw);
373+
}

ports/nrf/common-hal/busio/SPI.c

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -327,3 +327,11 @@ uint32_t common_hal_busio_spi_get_frequency(busio_spi_obj_t* self) {
327327
return 0;
328328
}
329329
}
330+
331+
uint8_t common_hal_busio_spi_get_phase(busio_spi_obj_t* self) {
332+
return 0;
333+
}
334+
335+
uint8_t common_hal_busio_spi_get_polarity(busio_spi_obj_t* self) {
336+
return 0;
337+
}

shared-bindings/busio/SPI.h

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -61,6 +61,12 @@ extern bool common_hal_busio_spi_transfer(busio_spi_obj_t *self, uint8_t *data_o
6161
// Return actual SPI bus frequency.
6262
uint32_t common_hal_busio_spi_get_frequency(busio_spi_obj_t* self);
6363

64+
// Return SPI bus phase.
65+
uint8_t common_hal_busio_spi_get_phase(busio_spi_obj_t* self);
66+
67+
// Return SPI bus polarity.
68+
uint8_t common_hal_busio_spi_get_polarity(busio_spi_obj_t* self);
69+
6470
// This is used by the supervisor to claim SPI devices indefinitely.
6571
extern void common_hal_busio_spi_never_reset(busio_spi_obj_t *self);
6672

shared-module/displayio/FourWire.c

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -40,6 +40,9 @@ void common_hal_displayio_fourwire_construct(displayio_fourwire_obj_t* self,
4040

4141
self->bus = spi;
4242
common_hal_busio_spi_never_reset(self->bus);
43+
self->frequency = common_hal_busio_spi_get_frequency(spi);
44+
self->polarity = common_hal_busio_spi_get_polarity(spi);
45+
self->phase = common_hal_busio_spi_get_phase(spi);
4346

4447
common_hal_digitalio_digitalinout_construct(&self->command, command);
4548
common_hal_digitalio_digitalinout_switch_to_output(&self->command, true, DRIVE_MODE_PUSH_PULL);
@@ -71,8 +74,8 @@ bool common_hal_displayio_fourwire_begin_transaction(mp_obj_t obj) {
7174
if (!common_hal_busio_spi_try_lock(self->bus)) {
7275
return false;
7376
}
74-
// TODO(tannewt): Stop hardcoding SPI frequency, polarity and phase.
75-
common_hal_busio_spi_configure(self->bus, 12000000, 0, 0, 8);
77+
common_hal_busio_spi_configure(self->bus, self->frequency, self->polarity,
78+
self->phase, 8);
7679
common_hal_digitalio_digitalinout_set_value(&self->chip_select, false);
7780
return true;
7881
}

shared-module/displayio/FourWire.h

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -38,6 +38,9 @@ typedef struct {
3838
digitalio_digitalinout_obj_t command;
3939
digitalio_digitalinout_obj_t chip_select;
4040
digitalio_digitalinout_obj_t reset;
41+
uint32_t frequency;
42+
uint8_t polarity;
43+
uint8_t phase;
4144
} displayio_fourwire_obj_t;
4245

4346
#endif // MICROPY_INCLUDED_ATMEL_SAMD_COMMON_HAL_DISPLAYIO_FOURWIRE_H

0 commit comments

Comments
 (0)