arch/arm/src/samdl: In sam_spibus_initialize(), the pinmux configuration was smashing the previous CTRLA register configuration. There are also some typos in samd_spi.h
This commit is contained in:
parent
0eca2c6fef
commit
537c9a27d1
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* arch/arm/src/samdl/sam_spi.c
|
* arch/arm/src/samdl/sam_spi.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2014-2017 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2014-2018 Gregory Nutt. All rights reserved.
|
||||||
* Authors: Gregory Nutt <gnutt@nuttx.org>
|
* Authors: Gregory Nutt <gnutt@nuttx.org>
|
||||||
*
|
*
|
||||||
* References:
|
* References:
|
||||||
@ -1421,7 +1421,7 @@ struct spi_dev_s *sam_spibus_initialize(int port)
|
|||||||
/* Set the SERCOM in SPI master mode (no address) */
|
/* Set the SERCOM in SPI master mode (no address) */
|
||||||
|
|
||||||
regval = spi_getreg32(priv, SAM_SPI_CTRLA_OFFSET);
|
regval = spi_getreg32(priv, SAM_SPI_CTRLA_OFFSET);
|
||||||
regval &= ~SPI_CTRLA_MODE_MASK;
|
regval &= ~(SPI_CTRLA_MODE_MASK | SPI_CTRLA_FORM_MASK);
|
||||||
regval |= (SPI_CTRLA_MODE_MASTER | SPI_CTRLA_FORM_SPI);
|
regval |= (SPI_CTRLA_MODE_MASTER | SPI_CTRLA_FORM_SPI);
|
||||||
spi_putreg32(priv, regval, SAM_SPI_CTRLA_OFFSET);
|
spi_putreg32(priv, regval, SAM_SPI_CTRLA_OFFSET);
|
||||||
|
|
||||||
@ -1435,11 +1435,13 @@ struct spi_dev_s *sam_spibus_initialize(int port)
|
|||||||
|
|
||||||
(void)spi_setfrequency((struct spi_dev_s *)priv, 400000);
|
(void)spi_setfrequency((struct spi_dev_s *)priv, 400000);
|
||||||
|
|
||||||
/* Set MSB first data order and the configured pad mux setting,
|
/* Set MSB first data order and the configured pad mux setting.
|
||||||
* Note that SPI mode 0 is assumed initially (CPOL=0 and CPHA=0).
|
* SPI mode 0 is assumed initially (CPOL=0 and CPHA=0).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
regval = (SPI_CTRLA_MSBFIRST | priv->muxconfig);
|
regval &= ~(SPI_CTRLA_DOPO_MASK | SPI_CTRLA_DIPO_MASK);
|
||||||
|
regval &= ~(SPI_CTRLA_CPHA | SPI_CTRLA_CPOL);
|
||||||
|
regval |= (SPI_CTRLA_MSBFIRST | priv->muxconfig);
|
||||||
spi_putreg32(priv, regval, SAM_SPI_CTRLA_OFFSET);
|
spi_putreg32(priv, regval, SAM_SPI_CTRLA_OFFSET);
|
||||||
|
|
||||||
/* Enable the receiver. Note that 8-bit data width is assumed initially */
|
/* Enable the receiver. Note that 8-bit data width is assumed initially */
|
||||||
|
Loading…
Reference in New Issue
Block a user