Remove CONFIG_SPI_OWNBUS: Now it is not just a good idea, it is the law

This commit is contained in:
Gregory Nutt 2016-01-23 18:10:21 -06:00
parent 00aaceaf2f
commit b7cbbab761
23 changed files with 33 additions and 584 deletions

View File

@ -60,20 +60,15 @@ struct calypso_spidev_s
{ {
struct spi_dev_s spidev; /* External driver interface */ struct spi_dev_s spidev; /* External driver interface */
int nbits; /* Number of transfered bits */ int nbits; /* Number of transfered bits */
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Mutual exclusion of devices */ sem_t exclsem; /* Mutual exclusion of devices */
#endif
}; };
/* STUBS! */ /* STUBS! */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
return -ENOSYS; return -ENOSYS;
} }
#endif
static void spi_select(FAR struct spi_dev_s *dev, enum spi_dev_e devid, static void spi_select(FAR struct spi_dev_s *dev, enum spi_dev_e devid,
bool selected) bool selected)
@ -117,9 +112,7 @@ static uint16_t spi_send(FAR struct spi_dev_s *dev, uint16_t wd)
static const struct spi_ops_s g_spiops = static const struct spi_ops_s g_spiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = spi_select, .select = spi_select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -129,7 +122,7 @@ static const struct spi_ops_s g_spiops =
#endif #endif
.status = 0, .status = 0,
#ifdef CONFIG_SPI_CMDDATA #ifdef CONFIG_SPI_CMDDATA
.cmddata = , .cmddata = 0,
#endif #endif
.send = spi_send, .send = spi_send,
#ifdef CONFIG_SPI_EXCHANGE #ifdef CONFIG_SPI_EXCHANGE

View File

@ -152,13 +152,10 @@ struct efm32_spidev_s
sem_t txdmasem; /* Wait for TX DMA to complete */ sem_t txdmasem; /* Wait for TX DMA to complete */
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Supports mutually exclusive access */ sem_t exclsem; /* Supports mutually exclusive access */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
uint8_t nbits; /* Width of word in bits (4-16) */ uint8_t nbits; /* Width of word in bits (4-16) */
bool lsbfirst; /* True: Bit order is LSB first */ bool lsbfirst; /* True: Bit order is LSB first */
bool initialized; /* True: Already initialized */ bool initialized; /* True: Already initialized */
@ -200,9 +197,7 @@ static inline void spi_dmatxstart(FAR struct efm32_spidev_s *priv);
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(struct spi_dev_s *dev, bool lock); static int spi_lock(struct spi_dev_s *dev, bool lock);
#endif
static void spi_select(struct spi_dev_s *dev, enum spi_dev_e devid, static void spi_select(struct spi_dev_s *dev, enum spi_dev_e devid,
bool selected); bool selected);
static uint32_t spi_setfrequency(struct spi_dev_s *dev, static uint32_t spi_setfrequency(struct spi_dev_s *dev,
@ -236,9 +231,7 @@ static int spi_portinitialize(struct efm32_spidev_s *priv);
static const struct spi_ops_s g_spiops = static const struct spi_ops_s g_spiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = spi_select, .select = spi_select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -761,7 +754,6 @@ static inline void spi_dmatxstart(FAR struct efm32_spidev_s *priv)
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(struct spi_dev_s *dev, bool lock) static int spi_lock(struct spi_dev_s *dev, bool lock)
{ {
struct efm32_spidev_s *priv = (struct efm32_spidev_s *)dev; struct efm32_spidev_s *priv = (struct efm32_spidev_s *)dev;
@ -786,7 +778,6 @@ static int spi_lock(struct spi_dev_s *dev, bool lock)
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_select * Name: spi_select
@ -846,7 +837,6 @@ static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency)
/* Has the frequency changed? */ /* Has the frequency changed? */
#ifndef CONFIG_SPI_OWNBUS
if (frequency == priv->frequency) if (frequency == priv->frequency)
{ {
/* No... just return the actual frequency from the last calcualtion */ /* No... just return the actual frequency from the last calcualtion */
@ -854,7 +844,6 @@ static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency)
actual = priv->actual; actual = priv->actual;
} }
else else
#endif
{ {
/* We want to use integer division to avoid forcing in float division /* We want to use integer division to avoid forcing in float division
* utils, and yet keep rounding effect errors to a minimum. * utils, and yet keep rounding effect errors to a minimum.
@ -909,14 +898,12 @@ static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency)
actual = (BOARD_HFPERCLK_FREQUENCY << 7) / (256 + clkdiv); actual = (BOARD_HFPERCLK_FREQUENCY << 7) / (256 + clkdiv);
spivdbg("frequency=%u actual=%u\n", frequency, actual); spivdbg("frequency=%u actual=%u\n", frequency, actual);
#ifndef CONFIG_SPI_OWNBUS
/* Save the frequency selection so that subsequent reconfigurations /* Save the frequency selection so that subsequent reconfigurations
* will be faster. * will be faster.
*/ */
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
} }
return actual; return actual;
@ -951,10 +938,8 @@ static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
setting = 0; setting = 0;
switch (mode) switch (mode)
{ {
@ -983,12 +968,10 @@ static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode)
regval |= setting; regval |= setting;
spi_putreg(config, EFM32_USART_CTRL_OFFSET, regval); spi_putreg(config, EFM32_USART_CTRL_OFFSET, regval);
#ifndef CONFIG_SPI_OWNBUS
/* Save the mode so that subsequent re-configurations will be faster */ /* Save the mode so that subsequent re-configurations will be faster */
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -1585,10 +1568,8 @@ static int spi_portinitialize(struct efm32_spidev_s *priv)
regval |= USART_FRAME_DATABITS_EIGHT | USART_CTRL_MSBF; regval |= USART_FRAME_DATABITS_EIGHT | USART_CTRL_MSBF;
spi_putreg(config, EFM32_USART_CTRL_OFFSET, regval); spi_putreg(config, EFM32_USART_CTRL_OFFSET, regval);
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = 0; priv->frequency = 0;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
priv->nbits = 8; priv->nbits = 8;
priv->lsbfirst = false; priv->lsbfirst = false;
@ -1602,9 +1583,7 @@ static int spi_portinitialize(struct efm32_spidev_s *priv)
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
#ifdef CONFIG_EFM32_SPI_DMA #ifdef CONFIG_EFM32_SPI_DMA
/* Allocate two DMA channels... one for the RX and one for the TX side of /* Allocate two DMA channels... one for the RX and one for the TX side of

View File

@ -166,9 +166,7 @@ static int spi_interrupt(int irq, void *context);
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void spi_setbits(FAR struct spi_dev_s *dev, int nbits); static void spi_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -189,9 +187,7 @@ static void spi_recvblock(FAR struct spi_dev_s *dev, FAR void *buffer, size_t
static const struct spi_ops_s g_spiops = static const struct spi_ops_s g_spiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = imx_spiselect, /* Provided externally by board logic */ .select = imx_spiselect, /* Provided externally by board logic */
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -704,14 +700,12 @@ static int spi_interrupt(int irq, void *context)
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
/* Not implemented */ /* Not implemented */
return -ENOSYS; return -ENOSYS;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency

View File

@ -90,13 +90,11 @@ struct kl_spidev_s
{ {
struct spi_dev_s spidev; /* Externally visible part of the SPI interface */ struct spi_dev_s spidev; /* Externally visible part of the SPI interface */
uint32_t spibase; /* Base address of SPI registers */ uint32_t spibase; /* Base address of SPI registers */
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t nbits; /* Width of word in bits (8 to 16) */ uint8_t nbits; /* Width of word in bits (8 to 16) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
}; };
/************************************************************************************ /************************************************************************************
@ -111,9 +109,7 @@ static inline void spi_putreg(FAR struct kl_spidev_s *priv, uint8_t offset,
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void spi_setbits(FAR struct spi_dev_s *dev, int nbits); static void spi_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -134,9 +130,7 @@ static void spi_recvblock(FAR struct spi_dev_s *dev, FAR void *rxbuffer,
#ifdef CONFIG_KL_SPI0 #ifdef CONFIG_KL_SPI0
static const struct spi_ops_s g_spi0ops = static const struct spi_ops_s g_spi0ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = kl_spi0select, .select = kl_spi0select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -168,9 +162,7 @@ static struct kl_spidev_s g_spi0dev =
#ifdef CONFIG_KL_SPI1 #ifdef CONFIG_KL_SPI1
static const struct spi_ops_s g_spi1ops = static const struct spi_ops_s g_spi1ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = kl_spi1select, .select = kl_spi1select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -263,7 +255,6 @@ static inline void spi_putreg(FAR struct kl_spidev_s *priv, uint8_t offset,
* *
************************************************************************************/ ************************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct kl_spidev_s *priv = (FAR struct kl_spidev_s *)dev; FAR struct kl_spidev_s *priv = (FAR struct kl_spidev_s *)dev;
@ -287,7 +278,6 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
} }
return OK; return OK;
} }
#endif
/************************************************************************************ /************************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency
@ -314,14 +304,12 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Check if the requested frequence is the same as the frequency selection */ /* Check if the requested frequence is the same as the frequency selection */
#ifndef CONFIG_SPI_OWNBUS
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* The clock source for the SPI baud rate generator is the bus clock. We /* The clock source for the SPI baud rate generator is the bus clock. We
* need to pick a prescaler value 1, 2, 3, 4, 5, 6, 7, or 8 and then a * need to pick a prescaler value 1, 2, 3, 4, 5, 6, 7, or 8 and then a
@ -373,10 +361,8 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
spidbg("Frequency %d->%d\n", frequency, actual); spidbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -406,10 +392,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set C1 appropriately */ /* Yes... Set C1 appropriately */
regval = spi_getreg(priv, KL_SPI_C1_OFFSET); regval = spi_getreg(priv, KL_SPI_C1_OFFSET);
@ -441,10 +425,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configuratins will be faster */ /* Save the mode so that subsequent re-configuratins will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/************************************************************************************ /************************************************************************************
@ -721,10 +703,8 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
/* Set the initial SPI configuration */ /* Set the initial SPI configuration */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = 0; priv->frequency = 0;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Select a default frequency of approx. 400KHz */ /* Select a default frequency of approx. 400KHz */
@ -732,9 +712,7 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
return &priv->spidev; return &priv->spidev;
} }

View File

@ -115,13 +115,11 @@
struct lpc11_spidev_s struct lpc11_spidev_s
{ {
struct spi_dev_s spidev; /* Externally visible part of the SPI interface */ struct spi_dev_s spidev; /* Externally visible part of the SPI interface */
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t nbits; /* Width of word in bits (8 to 16) */ uint8_t nbits; /* Width of word in bits (8 to 16) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
}; };
/**************************************************************************** /****************************************************************************
@ -130,9 +128,7 @@ struct lpc11_spidev_s
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev,
uint32_t frequency); uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, static void spi_setmode(FAR struct spi_dev_s *dev,
@ -150,9 +146,7 @@ static void spi_recvblock(FAR struct spi_dev_s *dev, FAR void *buffer,
static const struct spi_ops_s g_spiops = static const struct spi_ops_s g_spiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = lpc11_spiselect, .select = lpc11_spiselect,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -208,7 +202,6 @@ static struct lpc11_spidev_s g_spidev =
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct lpc11_spidev_s *priv = (FAR struct lpc11_spidev_s *)dev; FAR struct lpc11_spidev_s *priv = (FAR struct lpc11_spidev_s *)dev;
@ -232,7 +225,6 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
} }
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency
@ -259,14 +251,13 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev,
/* Check if the requested frequence is the same as the frequency selection */ /* Check if the requested frequence is the same as the frequency selection */
DEBUGASSERT(priv && frequency <= SPI_CLOCK / 2); DEBUGASSERT(priv && frequency <= SPI_CLOCK / 2);
#ifndef CONFIG_SPI_OWNBUS
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* frequency = SPI_CLOCK / divisor, or divisor = SPI_CLOCK / frequency */ /* frequency = SPI_CLOCK / divisor, or divisor = SPI_CLOCK / frequency */
@ -297,10 +288,8 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev,
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
spidbg("Frequency %d->%d\n", frequency, actual); spidbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -328,10 +317,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set CR appropriately */ /* Yes... Set CR appropriately */
regval = getreg32(LPC11_SPI_CR); regval = getreg32(LPC11_SPI_CR);
@ -363,10 +350,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configurations will be faster */ /* Save the mode so that subsequent re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -392,10 +377,9 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Has the number of bits changed? */ /* Has the number of bits changed? */
DEBUGASSERT(priv && nbits > 7 && nbits < 17); DEBUGASSERT(priv && nbits > 7 && nbits < 17);
#ifndef CONFIG_SPI_OWNBUS
if (nbits != priv->nbits) if (nbits != priv->nbits)
{ {
#endif
/* Yes... Set CR appropriately */ /* Yes... Set CR appropriately */
regval = getreg32(LPC11_SPI_CR); regval = getreg32(LPC11_SPI_CR);
@ -406,10 +390,8 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Save the selection so the subsequence re-configurations will be faster */ /* Save the selection so the subsequence re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->nbits = nbits; priv->nbits = nbits;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -606,11 +588,9 @@ FAR struct spi_dev_s *lpc11_spiinitialize(int port)
/* Set the initial SPI configuration */ /* Set the initial SPI configuration */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = 0; priv->frequency = 0;
priv->nbits = 8; priv->nbits = 8;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Select a default frequency of approx. 400KHz */ /* Select a default frequency of approx. 400KHz */
@ -618,9 +598,7 @@ FAR struct spi_dev_s *lpc11_spiinitialize(int port)
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
return &priv->spidev; return &priv->spidev;
} }

View File

@ -134,13 +134,11 @@ struct lpc11_sspdev_s
#ifdef CONFIG_LPC11_SSP_INTERRUPTS #ifdef CONFIG_LPC11_SSP_INTERRUPTS
uint8_t sspirq; /* SPI IRQ number */ uint8_t sspirq; /* SPI IRQ number */
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t nbits; /* Width of word in bits (4 to 16) */ uint8_t nbits; /* Width of word in bits (4 to 16) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
}; };
/**************************************************************************** /****************************************************************************
@ -156,9 +154,7 @@ static inline void ssp_putreg(FAR struct lpc11_sspdev_s *priv,
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int ssp_lock(FAR struct spi_dev_s *dev, bool lock); static int ssp_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev, static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev,
uint32_t frequency); uint32_t frequency);
static void ssp_setmode(FAR struct spi_dev_s *dev, static void ssp_setmode(FAR struct spi_dev_s *dev,
@ -186,9 +182,7 @@ static inline FAR struct lpc11_sspdev_s *lpc11_ssp1initialize(void);
#ifdef CONFIG_LPC11_SSP0 #ifdef CONFIG_LPC11_SSP0
static const struct spi_ops_s g_spi0ops = static const struct spi_ops_s g_spi0ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = ssp_lock, .lock = ssp_lock,
#endif
.select = lpc11_ssp0select, /* Provided externally */ .select = lpc11_ssp0select, /* Provided externally */
.setfrequency = ssp_setfrequency, .setfrequency = ssp_setfrequency,
.setmode = ssp_setmode, .setmode = ssp_setmode,
@ -223,9 +217,7 @@ static struct lpc11_sspdev_s g_ssp0dev =
#ifdef CONFIG_LPC11_SSP1 #ifdef CONFIG_LPC11_SSP1
static const struct spi_ops_s g_spi1ops = static const struct spi_ops_s g_spi1ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = ssp_lock, .lock = ssp_lock,
#endif
.select = lpc11_ssp1select, /* Provided externally */ .select = lpc11_ssp1select, /* Provided externally */
.setfrequency = ssp_setfrequency, .setfrequency = ssp_setfrequency,
.setmode = ssp_setmode, .setmode = ssp_setmode,
@ -257,9 +249,7 @@ static struct lpc11_sspdev_s g_ssp1dev =
#ifdef CONFIG_LPC11_SSP2 #ifdef CONFIG_LPC11_SSP2
static const struct spi_ops_s g_spi2ops = static const struct spi_ops_s g_spi2ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = ssp_lock, .lock = ssp_lock,
#endif
.select = lpc11_ssp2select, /* Provided externally */ .select = lpc11_ssp2select, /* Provided externally */
.setfrequency = ssp_setfrequency, .setfrequency = ssp_setfrequency,
.setmode = ssp_setmode, .setmode = ssp_setmode,
@ -360,7 +350,6 @@ static inline void ssp_putreg(FAR struct lpc11_sspdev_s *priv,
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int ssp_lock(FAR struct spi_dev_s *dev, bool lock) static int ssp_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct lpc11_sspdev_s *priv = (FAR struct lpc11_sspdev_s *)dev; FAR struct lpc11_sspdev_s *priv = (FAR struct lpc11_sspdev_s *)dev;
@ -384,7 +373,6 @@ static int ssp_lock(FAR struct spi_dev_s *dev, bool lock)
} }
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: ssp_setfrequency * Name: ssp_setfrequency
@ -412,14 +400,13 @@ static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Check if the requested frequency is the same as the frequency selection */ /* Check if the requested frequency is the same as the frequency selection */
DEBUGASSERT(priv && frequency <= SSP_CLOCK / 2); DEBUGASSERT(priv && frequency <= SSP_CLOCK / 2);
#ifndef CONFIG_SPI_OWNBUS
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* The SSP bit frequency is given by: /* The SSP bit frequency is given by:
* *
@ -483,10 +470,8 @@ static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
sspdbg("Frequency %d->%d\n", frequency, actual); sspdbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -514,10 +499,8 @@ static void ssp_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set CR0 appropriately */ /* Yes... Set CR0 appropriately */
regval = ssp_getreg(priv, LPC11_SSP_CR0_OFFSET); regval = ssp_getreg(priv, LPC11_SSP_CR0_OFFSET);
@ -550,10 +533,8 @@ static void ssp_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configurations will be faster */ /* Save the mode so that subsequent re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -579,10 +560,9 @@ static void ssp_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Has the number of bits changed? */ /* Has the number of bits changed? */
DEBUGASSERT(priv && nbits > 3 && nbits < 17); DEBUGASSERT(priv && nbits > 3 && nbits < 17);
#ifndef CONFIG_SPI_OWNBUS
if (nbits != priv->nbits) if (nbits != priv->nbits)
{ {
#endif
/* Yes... Set CR1 appropriately */ /* Yes... Set CR1 appropriately */
regval = ssp_getreg(priv, LPC11_SSP_CR0_OFFSET); regval = ssp_getreg(priv, LPC11_SSP_CR0_OFFSET);
@ -592,10 +572,8 @@ static void ssp_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Save the selection so the subsequence re-configurations will be faster */ /* Save the selection so the subsequence re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->nbits = nbits; priv->nbits = nbits;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -1024,11 +1002,9 @@ FAR struct spi_dev_s *lpc11_sspinitialize(int port)
/* Set the initial SSP configuration */ /* Set the initial SSP configuration */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = 0; priv->frequency = 0;
priv->nbits = 8; priv->nbits = 8;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Select a default frequency of approx. 400KHz */ /* Select a default frequency of approx. 400KHz */
@ -1036,9 +1012,7 @@ FAR struct spi_dev_s *lpc11_sspinitialize(int port)
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
/* Enable the SPI */ /* Enable the SPI */

View File

@ -115,13 +115,11 @@
struct lpc17_spidev_s struct lpc17_spidev_s
{ {
struct spi_dev_s spidev; /* Externally visible part of the SPI interface */ struct spi_dev_s spidev; /* Externally visible part of the SPI interface */
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t nbits; /* Width of word in bits (8 to 16) */ uint8_t nbits; /* Width of word in bits (8 to 16) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
}; };
/**************************************************************************** /****************************************************************************
@ -130,9 +128,7 @@ struct lpc17_spidev_s
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void spi_setbits(FAR struct spi_dev_s *dev, int nbits); static void spi_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -146,9 +142,7 @@ static void spi_recvblock(FAR struct spi_dev_s *dev, FAR void *buffer, size_
static const struct spi_ops_s g_spiops = static const struct spi_ops_s g_spiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = lpc17_spiselect, .select = lpc17_spiselect,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -204,7 +198,6 @@ static struct lpc17_spidev_s g_spidev =
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct lpc17_spidev_s *priv = (FAR struct lpc17_spidev_s *)dev; FAR struct lpc17_spidev_s *priv = (FAR struct lpc17_spidev_s *)dev;
@ -228,7 +221,6 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
} }
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency
@ -254,14 +246,13 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Check if the requested frequence is the same as the frequency selection */ /* Check if the requested frequence is the same as the frequency selection */
DEBUGASSERT(priv && frequency <= SPI_CLOCK / 2); DEBUGASSERT(priv && frequency <= SPI_CLOCK / 2);
#ifndef CONFIG_SPI_OWNBUS
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* frequency = SPI_CLOCK / divisor, or divisor = SPI_CLOCK / frequency */ /* frequency = SPI_CLOCK / divisor, or divisor = SPI_CLOCK / frequency */
@ -292,10 +283,8 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
spidbg("Frequency %d->%d\n", frequency, actual); spidbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -323,10 +312,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set CR appropriately */ /* Yes... Set CR appropriately */
regval = getreg32(LPC17_SPI_CR); regval = getreg32(LPC17_SPI_CR);
@ -358,10 +345,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configuratins will be faster */ /* Save the mode so that subsequent re-configuratins will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -387,10 +372,9 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Has the number of bits changed? */ /* Has the number of bits changed? */
DEBUGASSERT(priv && nbits > 7 && nbits < 17); DEBUGASSERT(priv && nbits > 7 && nbits < 17);
#ifndef CONFIG_SPI_OWNBUS
if (nbits != priv->nbits) if (nbits != priv->nbits)
{ {
#endif
/* Yes... Set CR appropriately */ /* Yes... Set CR appropriately */
regval = getreg32(LPC17_SPI_CR); regval = getreg32(LPC17_SPI_CR);
@ -401,10 +385,8 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Save the selection so the subsequence re-configurations will be faster */ /* Save the selection so the subsequence re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->nbits = nbits; priv->nbits = nbits;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -597,11 +579,9 @@ FAR struct spi_dev_s *lpc17_spiinitialize(int port)
/* Set the initial SPI configuration */ /* Set the initial SPI configuration */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = 0; priv->frequency = 0;
priv->nbits = 8; priv->nbits = 8;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Select a default frequency of approx. 400KHz */ /* Select a default frequency of approx. 400KHz */
@ -609,9 +589,7 @@ FAR struct spi_dev_s *lpc17_spiinitialize(int port)
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
return &priv->spidev; return &priv->spidev;
} }

View File

@ -134,13 +134,11 @@ struct lpc17_sspdev_s
#ifdef CONFIG_LPC17_SSP_INTERRUPTS #ifdef CONFIG_LPC17_SSP_INTERRUPTS
uint8_t sspirq; /* SPI IRQ number */ uint8_t sspirq; /* SPI IRQ number */
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t nbits; /* Width of word in bits (4 to 16) */ uint8_t nbits; /* Width of word in bits (4 to 16) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
}; };
/**************************************************************************** /****************************************************************************
@ -155,9 +153,7 @@ static inline void ssp_putreg(FAR struct lpc17_sspdev_s *priv, uint8_t offset,
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int ssp_lock(FAR struct spi_dev_s *dev, bool lock); static int ssp_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void ssp_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void ssp_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void ssp_setbits(FAR struct spi_dev_s *dev, int nbits); static void ssp_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -184,9 +180,7 @@ static inline FAR struct lpc17_sspdev_s *lpc17_ssp2initialize(void);
#ifdef CONFIG_LPC17_SSP0 #ifdef CONFIG_LPC17_SSP0
static const struct spi_ops_s g_spi0ops = static const struct spi_ops_s g_spi0ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = ssp_lock, .lock = ssp_lock,
#endif
.select = lpc17_ssp0select, /* Provided externally */ .select = lpc17_ssp0select, /* Provided externally */
.setfrequency = ssp_setfrequency, .setfrequency = ssp_setfrequency,
.setmode = ssp_setmode, .setmode = ssp_setmode,
@ -221,9 +215,7 @@ static struct lpc17_sspdev_s g_ssp0dev =
#ifdef CONFIG_LPC17_SSP1 #ifdef CONFIG_LPC17_SSP1
static const struct spi_ops_s g_spi1ops = static const struct spi_ops_s g_spi1ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = ssp_lock, .lock = ssp_lock,
#endif
.select = lpc17_ssp1select, /* Provided externally */ .select = lpc17_ssp1select, /* Provided externally */
.setfrequency = ssp_setfrequency, .setfrequency = ssp_setfrequency,
.setmode = ssp_setmode, .setmode = ssp_setmode,
@ -255,9 +247,7 @@ static struct lpc17_sspdev_s g_ssp1dev =
#ifdef CONFIG_LPC17_SSP2 #ifdef CONFIG_LPC17_SSP2
static const struct spi_ops_s g_spi2ops = static const struct spi_ops_s g_spi2ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = ssp_lock, .lock = ssp_lock,
#endif
.select = lpc17_ssp2select, /* Provided externally */ .select = lpc17_ssp2select, /* Provided externally */
.setfrequency = ssp_setfrequency, .setfrequency = ssp_setfrequency,
.setmode = ssp_setmode, .setmode = ssp_setmode,
@ -356,7 +346,6 @@ static inline void ssp_putreg(FAR struct lpc17_sspdev_s *priv, uint8_t offset, u
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int ssp_lock(FAR struct spi_dev_s *dev, bool lock) static int ssp_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct lpc17_sspdev_s *priv = (FAR struct lpc17_sspdev_s *)dev; FAR struct lpc17_sspdev_s *priv = (FAR struct lpc17_sspdev_s *)dev;
@ -380,7 +369,6 @@ static int ssp_lock(FAR struct spi_dev_s *dev, bool lock)
} }
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: ssp_setfrequency * Name: ssp_setfrequency
@ -408,14 +396,13 @@ static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Check if the requested frequency is the same as the frequency selection */ /* Check if the requested frequency is the same as the frequency selection */
DEBUGASSERT(priv && frequency <= SSP_CLOCK / 2); DEBUGASSERT(priv && frequency <= SSP_CLOCK / 2);
#ifndef CONFIG_SPI_OWNBUS
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* The SSP bit frequency is given by: /* The SSP bit frequency is given by:
* *
@ -479,10 +466,8 @@ static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
sspdbg("Frequency %d->%d\n", frequency, actual); sspdbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -510,10 +495,8 @@ static void ssp_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set CR0 appropriately */ /* Yes... Set CR0 appropriately */
regval = ssp_getreg(priv, LPC17_SSP_CR0_OFFSET); regval = ssp_getreg(priv, LPC17_SSP_CR0_OFFSET);
@ -546,10 +529,8 @@ static void ssp_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configurations will be faster */ /* Save the mode so that subsequent re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -575,10 +556,9 @@ static void ssp_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Has the number of bits changed? */ /* Has the number of bits changed? */
DEBUGASSERT(priv && nbits > 3 && nbits < 17); DEBUGASSERT(priv && nbits > 3 && nbits < 17);
#ifndef CONFIG_SPI_OWNBUS
if (nbits != priv->nbits) if (nbits != priv->nbits)
{ {
#endif
/* Yes... Set CR1 appropriately */ /* Yes... Set CR1 appropriately */
regval = ssp_getreg(priv, LPC17_SSP_CR0_OFFSET); regval = ssp_getreg(priv, LPC17_SSP_CR0_OFFSET);
@ -588,10 +568,8 @@ static void ssp_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Save the selection so the subsequence re-configurations will be faster */ /* Save the selection so the subsequence re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->nbits = nbits; priv->nbits = nbits;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -1013,11 +991,9 @@ FAR struct spi_dev_s *lpc17_sspinitialize(int port)
/* Set the initial SSP configuration */ /* Set the initial SSP configuration */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = 0; priv->frequency = 0;
priv->nbits = 8; priv->nbits = 8;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Select a default frequency of approx. 400KHz */ /* Select a default frequency of approx. 400KHz */
@ -1025,9 +1001,7 @@ FAR struct spi_dev_s *lpc17_sspinitialize(int port)
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
/* Enable the SPI */ /* Enable the SPI */

View File

@ -117,13 +117,11 @@
struct lpc23xx_spidev_s struct lpc23xx_spidev_s
{ {
struct spi_dev_s spidev; /* Externally visible part of the SPI interface */ struct spi_dev_s spidev; /* Externally visible part of the SPI interface */
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t nbits; /* Width of word in bits (8 to 16) */ uint8_t nbits; /* Width of word in bits (8 to 16) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
}; };
/**************************************************************************** /****************************************************************************
@ -132,9 +130,7 @@ struct lpc23xx_spidev_s
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void spi_setbits(FAR struct spi_dev_s *dev, int nbits); static void spi_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -148,9 +144,7 @@ static void spi_recvblock(FAR struct spi_dev_s *dev, FAR void *buffer, size_
static const struct spi_ops_s g_spiops = static const struct spi_ops_s g_spiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = lpc23xx_spiselect, /* Provided externally */ .select = lpc23xx_spiselect, /* Provided externally */
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -206,7 +200,6 @@ static struct lpc23xx_spidev_s g_spidev =
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct lpc23xx_spidev_s *priv = (FAR struct lpc23xx_spidev_s *)dev; FAR struct lpc23xx_spidev_s *priv = (FAR struct lpc23xx_spidev_s *)dev;
@ -231,7 +224,6 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency
@ -250,25 +242,21 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency) static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
{ {
#ifndef CONFIG_SPI_OWNBUS
FAR struct lpc23xx_spidev_s *priv = (FAR struct lpc23xx_spidev_s *)dev; FAR struct lpc23xx_spidev_s *priv = (FAR struct lpc23xx_spidev_s *)dev;
#endif
uint32_t divisor; uint32_t divisor;
uint32_t actual; uint32_t actual;
DEBUGASSERT(frequency <= SPI_CLOCK / 2); DEBUGASSERT(frequency <= SPI_CLOCK / 2);
#ifndef CONFIG_SPI_OWNBUS
/* Check if the requested frequency is the same as the frequency selection */ /* Check if the requested frequency is the same as the frequency selection */
DEBUGASSERT(priv); DEBUGASSERT(priv != NULL);
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* frequency = SPI_CLOCK / divisor, or divisor = SPI_CLOCK / frequency */ /* frequency = SPI_CLOCK / divisor, or divisor = SPI_CLOCK / frequency */
@ -297,10 +285,8 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
spidbg("Frequency %d->%d\n", frequency, actual); spidbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -323,18 +309,14 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode) static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
{ {
#ifndef CONFIG_SPI_OWNBUS
FAR struct lpc23xx_spidev_s *priv = (FAR struct lpc23xx_spidev_s *)dev; FAR struct lpc23xx_spidev_s *priv = (FAR struct lpc23xx_spidev_s *)dev;
#endif
uint32_t regval; uint32_t regval;
#ifndef CONFIG_SPI_OWNBUS
/* Has the mode changed? */ /* Has the mode changed? */
DEBUGASSERT(priv); DEBUGASSERT(priv != NULL);
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set CR appropriately */ /* Yes... Set CR appropriately */
regval = getreg32(SPI_CR); regval = getreg32(SPI_CR);
@ -366,10 +348,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configuratins will be faster */ /* Save the mode so that subsequent re-configuratins will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -389,20 +369,16 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
static void spi_setbits(FAR struct spi_dev_s *dev, int nbits) static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
{ {
#ifndef CONFIG_SPI_OWNBUS
FAR struct lpc23xx_spidev_s *priv = (FAR struct lpc23xx_spidev_s *)dev; FAR struct lpc23xx_spidev_s *priv = (FAR struct lpc23xx_spidev_s *)dev;
#endif
uint32_t regval; uint32_t regval;
DEBUGASSERT(nbits > 7 && nbits < 17); DEBUGASSERT(nbits > 7 && nbits < 17);
#ifndef CONFIG_SPI_OWNBUS
/* Has the number of bits changed? */ /* Has the number of bits changed? */
DEBUGASSERT(priv); DEBUGASSERT(priv != NULL);
if (nbits != priv->nbits) if (nbits != priv->nbits)
{ {
#endif
/* Yes... Set CR appropriately */ /* Yes... Set CR appropriately */
regval = getreg32(SPI_CR); regval = getreg32(SPI_CR);
@ -413,10 +389,8 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Save the selection so the subsequence re-configurations will be faster */ /* Save the selection so the subsequence re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->nbits = nbits; priv->nbits = nbits;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -612,11 +586,9 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
/* Set the initial SPI configuration */ /* Set the initial SPI configuration */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = 0; priv->frequency = 0;
priv->nbits = 8; priv->nbits = 8;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Select a default frequency of approx. 400KHz */ /* Select a default frequency of approx. 400KHz */
@ -624,9 +596,7 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
return &priv->spidev; return &priv->spidev;
} }

View File

@ -104,13 +104,11 @@
struct lpc43_spidev_s struct lpc43_spidev_s
{ {
struct spi_dev_s spidev; /* Externally visible part of the SPI interface */ struct spi_dev_s spidev; /* Externally visible part of the SPI interface */
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t nbits; /* Width of word in bits (8 to 16) */ uint8_t nbits; /* Width of word in bits (8 to 16) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
}; };
/**************************************************************************** /****************************************************************************
@ -119,9 +117,7 @@ struct lpc43_spidev_s
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static void spi_select(FAR struct spi_dev_s *dev, enum spi_dev_e devid, bool selected); static void spi_select(FAR struct spi_dev_s *dev, enum spi_dev_e devid, bool selected);
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
@ -136,9 +132,7 @@ static void spi_recvblock(FAR struct spi_dev_s *dev, FAR void *buffer, size_
static const struct spi_ops_s g_spiops = static const struct spi_ops_s g_spiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = lpc43_spiselect, .select = lpc43_spiselect,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -194,7 +188,6 @@ static struct lpc43_spidev_s g_spidev =
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct lpc43_spidev_s *priv = (FAR struct lpc43_spidev_s *)dev; FAR struct lpc43_spidev_s *priv = (FAR struct lpc43_spidev_s *)dev;
@ -218,7 +211,6 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
} }
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency
@ -244,14 +236,13 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Check if the requested frequence is the same as the frequency selection */ /* Check if the requested frequence is the same as the frequency selection */
DEBUGASSERT(priv && frequency <= SPI_CLOCK / 2); DEBUGASSERT(priv && frequency <= SPI_CLOCK / 2);
#ifndef CONFIG_SPI_OWNBUS
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* frequency = SPI_CLOCK / divisor, or divisor = SPI_CLOCK / frequency */ /* frequency = SPI_CLOCK / divisor, or divisor = SPI_CLOCK / frequency */
@ -280,10 +271,8 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
spidbg("Frequency %d->%d\n", frequency, actual); spidbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -311,10 +300,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set CR appropriately */ /* Yes... Set CR appropriately */
regval = getreg32(LPC43_SPI_CR); regval = getreg32(LPC43_SPI_CR);
@ -346,10 +333,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configuratins will be faster */ /* Save the mode so that subsequent re-configuratins will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -375,10 +360,9 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Has the number of bits changed? */ /* Has the number of bits changed? */
DEBUGASSERT(priv && nbits > 7 && nbits < 17); DEBUGASSERT(priv && nbits > 7 && nbits < 17);
#ifndef CONFIG_SPI_OWNBUS
if (nbits != priv->nbits) if (nbits != priv->nbits)
{ {
#endif
/* Yes... Set CR appropriately */ /* Yes... Set CR appropriately */
regval = getreg32(LPC43_SPI_CR); regval = getreg32(LPC43_SPI_CR);
@ -389,10 +373,8 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Save the selection so the subsequence re-configurations will be faster */ /* Save the selection so the subsequence re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->nbits = nbits; priv->nbits = nbits;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -567,11 +549,9 @@ FAR struct spi_dev_s *lpc43_spiinitialize(int port)
/* Set the initial SPI configuration */ /* Set the initial SPI configuration */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = 0; priv->frequency = 0;
priv->nbits = 8; priv->nbits = 8;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Select a default frequency of approx. 400KHz */ /* Select a default frequency of approx. 400KHz */
@ -579,12 +559,9 @@ FAR struct spi_dev_s *lpc43_spiinitialize(int port)
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
return &priv->spidev; return &priv->spidev;
} }
#endif /* CONFIG_LPC43_SPI */ #endif /* CONFIG_LPC43_SPI */
/**************************************************************************** /****************************************************************************

View File

@ -103,13 +103,11 @@ struct lpc43_sspdev_s
#ifdef CONFIG_LPC43_SSP_INTERRUPTS #ifdef CONFIG_LPC43_SSP_INTERRUPTS
uint8_t sspirq; /* SPI IRQ number */ uint8_t sspirq; /* SPI IRQ number */
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t nbits; /* Width of word in bits (4 to 16) */ uint8_t nbits; /* Width of word in bits (4 to 16) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
}; };
/**************************************************************************** /****************************************************************************
@ -124,9 +122,7 @@ static inline void ssp_putreg(FAR struct lpc43_sspdev_s *priv, uint8_t offset,
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int ssp_lock(FAR struct spi_dev_s *dev, bool lock); static int ssp_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void ssp_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void ssp_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void ssp_setbits(FAR struct spi_dev_s *dev, int nbits); static void ssp_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -154,9 +150,7 @@ static inline FAR struct lpc43_sspdev_s *lpc43_ssp1initialize(void);
#ifdef CONFIG_LPC43_SSP0 #ifdef CONFIG_LPC43_SSP0
static const struct spi_ops_s g_spi0ops = static const struct spi_ops_s g_spi0ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = ssp_lock, .lock = ssp_lock,
#endif
.select = lpc43_ssp0select, /* Provided externally */ .select = lpc43_ssp0select, /* Provided externally */
.setfrequency = ssp_setfrequency, .setfrequency = ssp_setfrequency,
.setmode = ssp_setmode, .setmode = ssp_setmode,
@ -196,9 +190,7 @@ static struct lpc43_sspdev_s g_ssp0dev =
#ifdef CONFIG_LPC43_SSP1 #ifdef CONFIG_LPC43_SSP1
static const struct spi_ops_s g_spi1ops = static const struct spi_ops_s g_spi1ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = ssp_lock, .lock = ssp_lock,
#endif
.select = lpc43_ssp1select, /* Provided externally */ .select = lpc43_ssp1select, /* Provided externally */
.setfrequency = ssp_setfrequency, .setfrequency = ssp_setfrequency,
.setmode = ssp_setmode, .setmode = ssp_setmode,
@ -302,7 +294,6 @@ static inline void ssp_putreg(FAR struct lpc43_sspdev_s *priv, uint8_t offset, u
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int ssp_lock(FAR struct spi_dev_s *dev, bool lock) static int ssp_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct lpc43_sspdev_s *priv = (FAR struct lpc43_sspdev_s *)dev; FAR struct lpc43_sspdev_s *priv = (FAR struct lpc43_sspdev_s *)dev;
@ -327,7 +318,6 @@ static int ssp_lock(FAR struct spi_dev_s *dev, bool lock)
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: ssp_setfrequency * Name: ssp_setfrequency
@ -350,14 +340,12 @@ static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
uint32_t divisor; uint32_t divisor;
uint32_t actual; uint32_t actual;
#ifndef CONFIG_SPI_OWNBUS
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* frequency = SSP_CLOCK / divisor, or divisor = SSP_CLOCK / frequency */ /* frequency = SSP_CLOCK / divisor, or divisor = SSP_CLOCK / frequency */
@ -386,10 +374,8 @@ static uint32_t ssp_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
sspdbg("Frequency %d->%d\n", frequency, actual); sspdbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -417,10 +403,8 @@ static void ssp_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set CR0 appropriately */ /* Yes... Set CR0 appropriately */
regval = ssp_getreg(priv, LPC43_SSP_CR0_OFFSET); regval = ssp_getreg(priv, LPC43_SSP_CR0_OFFSET);
@ -453,10 +437,8 @@ static void ssp_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configurations will be faster */ /* Save the mode so that subsequent re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -482,10 +464,9 @@ static void ssp_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Has the number of bits changed? */ /* Has the number of bits changed? */
DEBUGASSERT(priv && nbits > 3 && nbits < 17); DEBUGASSERT(priv && nbits > 3 && nbits < 17);
#ifndef CONFIG_SPI_OWNBUS
if (nbits != priv->nbits) if (nbits != priv->nbits)
{ {
#endif
/* Yes... Set CR1 appropriately */ /* Yes... Set CR1 appropriately */
regval = ssp_getreg(priv, LPC43_SSP_CR0_OFFSET); regval = ssp_getreg(priv, LPC43_SSP_CR0_OFFSET);
@ -495,10 +476,8 @@ static void ssp_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Save the selection so the subsequence re-configurations will be faster */ /* Save the selection so the subsequence re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->nbits = nbits; priv->nbits = nbits;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -855,11 +834,9 @@ FAR struct spi_dev_s *lpc43_sspinitialize(int port)
/* Set the initial SSP configuration */ /* Set the initial SSP configuration */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = 0; priv->frequency = 0;
priv->nbits = 8; priv->nbits = 8;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Select a default frequency of approx. 400KHz */ /* Select a default frequency of approx. 400KHz */
@ -867,9 +844,7 @@ FAR struct spi_dev_s *lpc43_sspinitialize(int port)
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
/* Enable the SPI */ /* Enable the SPI */

View File

@ -176,11 +176,9 @@ struct sam_spics_s
{ {
struct spi_dev_s spidev; /* Externally visible part of the SPI interface */ struct spi_dev_s spidev; /* Externally visible part of the SPI interface */
#ifndef CONFIG_SPI_OWNBUS
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
uint8_t nbits; /* Width of word in bits (8 to 16) */ uint8_t nbits; /* Width of word in bits (8 to 16) */
#if defined(CONFIG_SAM34_SPI0) || defined(CONFIG_SAM34_SPI1) #if defined(CONFIG_SAM34_SPI0) || defined(CONFIG_SAM34_SPI1)
@ -288,9 +286,7 @@ static inline uintptr_t spi_regaddr(struct sam_spics_s *spics,
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(struct spi_dev_s *dev, bool lock); static int spi_lock(struct spi_dev_s *dev, bool lock);
#endif
static void spi_select(struct spi_dev_s *dev, enum spi_dev_e devid, static void spi_select(struct spi_dev_s *dev, enum spi_dev_e devid,
bool selected); bool selected);
static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency);
@ -327,9 +323,7 @@ static const uint8_t g_csroffset[4] =
static const struct spi_ops_s g_spi0ops = static const struct spi_ops_s g_spi0ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = spi_select, .select = spi_select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -369,9 +363,7 @@ static struct sam_spidev_s g_spi0dev =
static const struct spi_ops_s g_spi1ops = static const struct spi_ops_s g_spi1ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = spi_select, .select = spi_select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -895,7 +887,6 @@ static inline uintptr_t spi_regaddr(struct sam_spics_s *spics,
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(struct spi_dev_s *dev, bool lock) static int spi_lock(struct spi_dev_s *dev, bool lock)
{ {
struct sam_spics_s *spics = (struct sam_spics_s *)dev; struct sam_spics_s *spics = (struct sam_spics_s *)dev;
@ -922,7 +913,6 @@ static int spi_lock(struct spi_dev_s *dev, bool lock)
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_select * Name: spi_select
@ -1012,14 +1002,12 @@ static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency)
/* Check if the requested frequency is the same as the frequency selection */ /* Check if the requested frequency is the same as the frequency selection */
#ifndef CONFIG_SPI_OWNBUS
if (spics->frequency == frequency) if (spics->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return spics->actual; return spics->actual;
} }
#endif
/* Configure SPI to a frequency as close as possible to the requested frequency. /* Configure SPI to a frequency as close as possible to the requested frequency.
* *
@ -1084,10 +1072,8 @@ static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
spics->frequency = frequency; spics->frequency = frequency;
spics->actual = actual; spics->actual = actual;
#endif
spidbg("Frequency %d->%d\n", frequency, actual); spidbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -1119,10 +1105,8 @@ static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != spics->mode) if (mode != spics->mode)
{ {
#endif
/* Yes... Set the mode appropriately: /* Yes... Set the mode appropriately:
* *
* SPI CPOL NCPHA * SPI CPOL NCPHA
@ -1164,10 +1148,8 @@ static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configurations will be faster */ /* Save the mode so that subsequent re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
spics->mode = mode; spics->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -1197,9 +1179,7 @@ static void spi_setbits(struct spi_dev_s *dev, int nbits)
/* Has the number of bits changed? */ /* Has the number of bits changed? */
#ifndef CONFIG_SPI_OWNBUS
if (nbits != spics->nbits) if (nbits != spics->nbits)
#endif
{ {
/* Yes... Set number of bits appropriately */ /* Yes... Set number of bits appropriately */
@ -1759,10 +1739,8 @@ struct spi_dev_s *up_spiinitialize(int port)
int csno = (port & __SPI_CS_MASK) >> __SPI_CS_SHIFT; int csno = (port & __SPI_CS_MASK) >> __SPI_CS_SHIFT;
int spino = (port & __SPI_SPI_MASK) >> __SPI_SPI_SHIFT; int spino = (port & __SPI_SPI_MASK) >> __SPI_SPI_SHIFT;
irqstate_t flags; irqstate_t flags;
#ifndef CONFIG_SPI_OWNBUS
uint32_t regval; uint32_t regval;
unsigned int offset; unsigned int offset;
#endif
/* The support SAM parts have only a single SPI port */ /* The support SAM parts have only a single SPI port */
@ -1911,14 +1889,12 @@ struct spi_dev_s *up_spiinitialize(int port)
(void)spi_getreg(spi, SAM_SPI_SR_OFFSET); (void)spi_getreg(spi, SAM_SPI_SR_OFFSET);
(void)spi_getreg(spi, SAM_SPI_RDR_OFFSET); (void)spi_getreg(spi, SAM_SPI_RDR_OFFSET);
#ifndef CONFIG_SPI_OWNBUS
/* Initialize the SPI semaphore that enforces mutually exclusive /* Initialize the SPI semaphore that enforces mutually exclusive
* access to the SPI registers. * access to the SPI registers.
*/ */
sem_init(&spi->spisem, 0, 1); sem_init(&spi->spisem, 0, 1);
spi->initialized = true; spi->initialized = true;
#endif
#ifdef CONFIG_SAM34_SPI_DMA #ifdef CONFIG_SAM34_SPI_DMA
/* Initialize the SPI semaphore that is used to wake up the waiting /* Initialize the SPI semaphore that is used to wake up the waiting
@ -1936,10 +1912,8 @@ struct spi_dev_s *up_spiinitialize(int port)
spi_dumpregs(spi, "After initialization"); spi_dumpregs(spi, "After initialization");
} }
#ifndef CONFIG_SPI_OWNBUS /* Set to mode=0 and nbits=8 and impossible frequency. The SPI will only
/* Set to mode=0 and nbits=8 and impossible frequency. It is only * be reconfigured if there is a change.
* critical to do this if CONFIG_SPI_OWNBUS is not defined because in
* that case, the SPI will only be reconfigured if there is a change.
*/ */
offset = (unsigned int)g_csroffset[csno]; offset = (unsigned int)g_csroffset[csno];
@ -1950,7 +1924,6 @@ struct spi_dev_s *up_spiinitialize(int port)
spics->nbits = 8; spics->nbits = 8;
spivdbg("csr[offset=%02x]=%08x\n", offset, regval); spivdbg("csr[offset=%02x]=%08x\n", offset, regval);
#endif
return &spics->spidev; return &spics->spidev;
} }

View File

@ -168,13 +168,10 @@
struct sam_spics_s struct sam_spics_s
{ {
struct spi_dev_s spidev; /* Externally visible part of the SPI interface */ struct spi_dev_s spidev; /* Externally visible part of the SPI interface */
#ifndef CONFIG_SPI_OWNBUS
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t nbits; /* Width of word in bits (8 to 16) */ uint8_t nbits; /* Width of word in bits (8 to 16) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
#if defined(CONFIG_SAMA5_SPI0) || defined(CONFIG_SAMA5_SPI1) #if defined(CONFIG_SAMA5_SPI0) || defined(CONFIG_SAMA5_SPI1)
uint8_t spino; /* SPI controller number (0 or 1) */ uint8_t spino; /* SPI controller number (0 or 1) */
@ -280,9 +277,7 @@ static inline uintptr_t spi_physregaddr(struct sam_spics_s *spics,
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(struct spi_dev_s *dev, bool lock); static int spi_lock(struct spi_dev_s *dev, bool lock);
#endif
static void spi_select(struct spi_dev_s *dev, enum spi_dev_e devid, static void spi_select(struct spi_dev_s *dev, enum spi_dev_e devid,
bool selected); bool selected);
static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency);
@ -319,9 +314,7 @@ static const uint8_t g_csroffset[4] =
static const struct spi_ops_s g_spi0ops = static const struct spi_ops_s g_spi0ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = spi_select, .select = spi_select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -360,9 +353,7 @@ static struct sam_spidev_s g_spi0dev =
static const struct spi_ops_s g_spi1ops = static const struct spi_ops_s g_spi1ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = spi_select, .select = spi_select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -885,7 +876,6 @@ static inline uintptr_t spi_physregaddr(struct sam_spics_s *spics,
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(struct spi_dev_s *dev, bool lock) static int spi_lock(struct spi_dev_s *dev, bool lock)
{ {
struct sam_spics_s *spics = (struct sam_spics_s *)dev; struct sam_spics_s *spics = (struct sam_spics_s *)dev;
@ -912,7 +902,6 @@ static int spi_lock(struct spi_dev_s *dev, bool lock)
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_select * Name: spi_select
@ -1002,14 +991,12 @@ static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency)
/* Check if the requested frequency is the same as the frequency selection */ /* Check if the requested frequency is the same as the frequency selection */
#ifndef CONFIG_SPI_OWNBUS
if (spics->frequency == frequency) if (spics->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return spics->actual; return spics->actual;
} }
#endif
/* Configure SPI to a frequency as close as possible to the requested frequency. /* Configure SPI to a frequency as close as possible to the requested frequency.
* *
@ -1074,10 +1061,8 @@ static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
spics->frequency = frequency; spics->frequency = frequency;
spics->actual = actual; spics->actual = actual;
#endif
spidbg("Frequency %d->%d\n", frequency, actual); spidbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -1109,10 +1094,8 @@ static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != spics->mode) if (mode != spics->mode)
{ {
#endif
/* Yes... Set the mode appropriately: /* Yes... Set the mode appropriately:
* *
* SPI CPOL NCPHA * SPI CPOL NCPHA
@ -1154,10 +1137,8 @@ static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configurations will be faster */ /* Save the mode so that subsequent re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
spics->mode = mode; spics->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -1194,10 +1175,8 @@ static void spi_setbits(struct spi_dev_s *dev, int nbits)
/* Has the number of bits changed? */ /* Has the number of bits changed? */
#ifndef CONFIG_SPI_OWNBUS
if (nbits != spics->nbits) if (nbits != spics->nbits)
{ {
#endif
/* Yes... Set number of bits appropriately */ /* Yes... Set number of bits appropriately */
offset = (unsigned int)g_csroffset[spics->cs]; offset = (unsigned int)g_csroffset[spics->cs];
@ -1210,10 +1189,8 @@ static void spi_setbits(struct spi_dev_s *dev, int nbits)
/* Save the selection so the subsequence re-configurations will be faster */ /* Save the selection so the subsequence re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
spics->nbits = nbits; spics->nbits = nbits;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -1690,10 +1667,8 @@ struct spi_dev_s *up_spiinitialize(int port)
int csno = (port & __SPI_CS_MASK) >> __SPI_CS_SHIFT; int csno = (port & __SPI_CS_MASK) >> __SPI_CS_SHIFT;
int spino = (port & __SPI_SPI_MASK) >> __SPI_SPI_SHIFT; int spino = (port & __SPI_SPI_MASK) >> __SPI_SPI_SHIFT;
irqstate_t flags; irqstate_t flags;
#ifndef CONFIG_SPI_OWNBUS
uint32_t regval; uint32_t regval;
unsigned int offset; unsigned int offset;
#endif
/* The support SAM parts have only a single SPI port */ /* The support SAM parts have only a single SPI port */
@ -1842,14 +1817,12 @@ struct spi_dev_s *up_spiinitialize(int port)
(void)spi_getreg(spi, SAM_SPI_SR_OFFSET); (void)spi_getreg(spi, SAM_SPI_SR_OFFSET);
(void)spi_getreg(spi, SAM_SPI_RDR_OFFSET); (void)spi_getreg(spi, SAM_SPI_RDR_OFFSET);
#ifndef CONFIG_SPI_OWNBUS
/* Initialize the SPI semaphore that enforces mutually exclusive /* Initialize the SPI semaphore that enforces mutually exclusive
* access to the SPI registers. * access to the SPI registers.
*/ */
sem_init(&spi->spisem, 0, 1); sem_init(&spi->spisem, 0, 1);
spi->initialized = true; spi->initialized = true;
#endif
#ifdef CONFIG_SAMA5_SPI_DMA #ifdef CONFIG_SAMA5_SPI_DMA
/* Initialize the SPI semaphore that is used to wake up the waiting /* Initialize the SPI semaphore that is used to wake up the waiting
@ -1867,10 +1840,8 @@ struct spi_dev_s *up_spiinitialize(int port)
spi_dumpregs(spi, "After initialization"); spi_dumpregs(spi, "After initialization");
} }
#ifndef CONFIG_SPI_OWNBUS /* Set to mode=0 and nbits=8 and impossible frequency. The SPI will only
/* Set to mode=0 and nbits=8 and impossible frequency. It is only * be reconfigured if there is a change.
* critical to do this if CONFIG_SPI_OWNBUS is not defined because in
* that case, the SPI will only be reconfigured if there is a change.
*/ */
offset = (unsigned int)g_csroffset[csno]; offset = (unsigned int)g_csroffset[csno];
@ -1881,7 +1852,6 @@ struct spi_dev_s *up_spiinitialize(int port)
spics->nbits = 8; spics->nbits = 8;
spivdbg("csr[offset=%02x]=%08x\n", offset, regval); spivdbg("csr[offset=%02x]=%08x\n", offset, regval);
#endif
return &spics->spidev; return &spics->spidev;
} }

View File

@ -132,12 +132,10 @@ struct sam_spidev_s
/* Dynamic configuration */ /* Dynamic configuration */
#ifndef CONFIG_SPI_OWNBUS
sem_t spilock; /* Used to managed exclusive access to the bus */ sem_t spilock; /* Used to managed exclusive access to the bus */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
uint8_t nbits; /* Width of word in bits (8 to 16) */ uint8_t nbits; /* Width of word in bits (8 to 16) */
/* Debug stuff */ /* Debug stuff */
@ -209,9 +207,7 @@ static int spi5_interrupt(int irq, void *context);
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(struct spi_dev_s *dev, bool lock); static int spi_lock(struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency);
static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode);
static void spi_setbits(struct spi_dev_s *dev, int nbits); static void spi_setbits(struct spi_dev_s *dev, int nbits);
@ -239,9 +235,7 @@ static void spi_pad_configure(struct sam_spidev_s *priv);
static const struct spi_ops_s g_spi0ops = static const struct spi_ops_s g_spi0ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = sam_spi0select, .select = sam_spi0select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -284,9 +278,7 @@ static struct sam_spidev_s g_spi0dev =
#if 0 /* Not used */ #if 0 /* Not used */
.handler = spi0_interrupt, .handler = spi0_interrupt,
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
.spilock = SEM_INITIALIZER(1), .spilock = SEM_INITIALIZER(1),
#endif
}; };
#endif #endif
@ -295,9 +287,7 @@ static struct sam_spidev_s g_spi0dev =
static const struct spi_ops_s g_spi1ops = static const struct spi_ops_s g_spi1ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = sam_spi1select, .select = sam_spi1select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -337,9 +327,7 @@ static struct sam_spidev_s g_spi1dev =
#if 0 /* Not used */ #if 0 /* Not used */
.handler = spi1_interrupt, .handler = spi1_interrupt,
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
.spilock = SEM_INITIALIZER(1), .spilock = SEM_INITIALIZER(1),
#endif
}; };
#endif #endif
@ -348,9 +336,7 @@ static struct sam_spidev_s g_spi1dev =
static const struct spi_ops_s g_spi2ops = static const struct spi_ops_s g_spi2ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = sam_spi0select, .select = sam_spi0select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -390,9 +376,7 @@ static struct sam_spidev_s g_spi2dev =
#if 0 /* Not used */ #if 0 /* Not used */
.handler = spi2_interrupt, .handler = spi2_interrupt,
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
.spilock = SEM_INITIALIZER(1), .spilock = SEM_INITIALIZER(1),
#endif
}; };
#endif #endif
@ -401,9 +385,7 @@ static struct sam_spidev_s g_spi2dev =
static const struct spi_ops_s g_spi3ops = static const struct spi_ops_s g_spi3ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = sam_spi3select, .select = sam_spi3select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -443,9 +425,7 @@ static struct sam_spidev_s g_spi3dev =
#if 0 /* Not used */ #if 0 /* Not used */
.handler = spi3_interrupt, .handler = spi3_interrupt,
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
.spilock = SEM_INITIALIZER(1), .spilock = SEM_INITIALIZER(1),
#endif
}; };
#endif #endif
@ -454,9 +434,7 @@ static struct sam_spidev_s g_spi3dev =
static const struct spi_ops_s g_spi4ops = static const struct spi_ops_s g_spi4ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = sam_spi4select, .select = sam_spi4select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -496,9 +474,7 @@ static struct sam_spidev_s g_spi4dev =
#if 0 /* Not used */ #if 0 /* Not used */
.handler = spi4_interrupt, .handler = spi4_interrupt,
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
.spilock = SEM_INITIALIZER(1), .spilock = SEM_INITIALIZER(1),
#endif
}; };
#endif #endif
@ -507,9 +483,7 @@ static struct sam_spidev_s g_spi4dev =
static const struct spi_ops_s g_spi5ops = static const struct spi_ops_s g_spi5ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = sam_spi5select, .select = sam_spi5select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -549,16 +523,10 @@ static struct sam_spidev_s g_spi5dev =
#if 0 /* Not used */ #if 0 /* Not used */
.handler = spi5_interrupt, .handler = spi5_interrupt,
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
.spilock = SEM_INITIALIZER(1), .spilock = SEM_INITIALIZER(1),
#endif
}; };
#endif #endif
/****************************************************************************
* Public Data
****************************************************************************/
/**************************************************************************** /****************************************************************************
* Private Functions * Private Functions
****************************************************************************/ ****************************************************************************/
@ -917,7 +885,6 @@ static int spi5_interrupt(int irq, void *context)
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(struct spi_dev_s *dev, bool lock) static int spi_lock(struct spi_dev_s *dev, bool lock)
{ {
struct sam_spidev_s *priv = (struct sam_spidev_s *)dev; struct sam_spidev_s *priv = (struct sam_spidev_s *)dev;
@ -943,7 +910,6 @@ static int spi_lock(struct spi_dev_s *dev, bool lock)
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency
@ -983,14 +949,12 @@ static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency)
/* Check if the requested frequency is the same as the frequency selection */ /* Check if the requested frequency is the same as the frequency selection */
#ifndef CONFIG_SPI_OWNBUS
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* For synchronous mode, the BAUAD rate (Fbaud) is generated from the /* For synchronous mode, the BAUAD rate (Fbaud) is generated from the
* source clock frequency (Fref) as follows: * source clock frequency (Fref) as follows:
@ -1048,10 +1012,8 @@ static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
spivdbg("Frequency %d->%d\n", frequency, actual); spivdbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -1081,9 +1043,7 @@ static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
#endif
{ {
/* Yes... Set the mode appropriately */ /* Yes... Set the mode appropriately */
@ -1116,9 +1076,7 @@ static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configurations will be faster */ /* Save the mode so that subsequent re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
#endif
} }
} }

View File

@ -163,12 +163,9 @@
struct sam_spics_s struct sam_spics_s
{ {
struct spi_dev_s spidev; /* Externally visible part of the SPI interface */ struct spi_dev_s spidev; /* Externally visible part of the SPI interface */
#ifndef CONFIG_SPI_OWNBUS
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
uint8_t nbits; /* Width of word in bits (8 to 16) */ uint8_t nbits; /* Width of word in bits (8 to 16) */
#if defined(CONFIG_SAMV7_SPI0_MASTER) || defined(CONFIG_SAMV7_SPI1_MASTER) #if defined(CONFIG_SAMV7_SPI0_MASTER) || defined(CONFIG_SAMV7_SPI1_MASTER)
@ -275,9 +272,7 @@ static inline uintptr_t spi_regaddr(struct sam_spics_s *spics,
/* SPI master methods */ /* SPI master methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(struct spi_dev_s *dev, bool lock); static int spi_lock(struct spi_dev_s *dev, bool lock);
#endif
static void spi_select(struct spi_dev_s *dev, enum spi_dev_e devid, static void spi_select(struct spi_dev_s *dev, enum spi_dev_e devid,
bool selected); bool selected);
static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency);
@ -314,9 +309,7 @@ static const uint8_t g_csroffset[4] =
static const struct spi_ops_s g_spi0ops = static const struct spi_ops_s g_spi0ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = spi_select, .select = spi_select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -355,9 +348,7 @@ static struct sam_spidev_s g_spi0dev =
static const struct spi_ops_s g_spi1ops = static const struct spi_ops_s g_spi1ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = spi_select, .select = spi_select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -880,7 +871,6 @@ static inline uintptr_t spi_regaddr(struct sam_spics_s *spics,
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(struct spi_dev_s *dev, bool lock) static int spi_lock(struct spi_dev_s *dev, bool lock)
{ {
struct sam_spics_s *spics = (struct sam_spics_s *)dev; struct sam_spics_s *spics = (struct sam_spics_s *)dev;
@ -907,7 +897,6 @@ static int spi_lock(struct spi_dev_s *dev, bool lock)
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_select * Name: spi_select
@ -997,14 +986,12 @@ static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency)
/* Check if the requested frequency is the same as the frequency selection */ /* Check if the requested frequency is the same as the frequency selection */
#ifndef CONFIG_SPI_OWNBUS
if (spics->frequency == frequency) if (spics->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return spics->actual; return spics->actual;
} }
#endif
/* Configure SPI to a frequency as close as possible to the requested frequency. /* Configure SPI to a frequency as close as possible to the requested frequency.
* *
@ -1069,10 +1056,8 @@ static uint32_t spi_setfrequency(struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
spics->frequency = frequency; spics->frequency = frequency;
spics->actual = actual; spics->actual = actual;
#endif
spidbg("Frequency %d->%d\n", frequency, actual); spidbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -1104,10 +1089,8 @@ static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != spics->mode) if (mode != spics->mode)
{ {
#endif
/* Yes... Set the mode appropriately: /* Yes... Set the mode appropriately:
* *
* SPI CPOL NCPHA * SPI CPOL NCPHA
@ -1149,10 +1132,8 @@ static void spi_setmode(struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configurations will be faster */ /* Save the mode so that subsequent re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
spics->mode = mode; spics->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -1182,9 +1163,7 @@ static void spi_setbits(struct spi_dev_s *dev, int nbits)
/* Has the number of bits changed? */ /* Has the number of bits changed? */
#ifndef CONFIG_SPI_OWNBUS
if (nbits != spics->nbits) if (nbits != spics->nbits)
#endif
{ {
/* Yes... Set number of bits appropriately */ /* Yes... Set number of bits appropriately */
@ -1740,10 +1719,8 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
int csno = (port & __SPI_CS_MASK) >> __SPI_CS_SHIFT; int csno = (port & __SPI_CS_MASK) >> __SPI_CS_SHIFT;
int spino = (port & __SPI_SPI_MASK) >> __SPI_SPI_SHIFT; int spino = (port & __SPI_SPI_MASK) >> __SPI_SPI_SHIFT;
irqstate_t flags; irqstate_t flags;
#ifndef CONFIG_SPI_OWNBUS
uint32_t regval; uint32_t regval;
unsigned int offset; unsigned int offset;
#endif
/* The support SAM parts have only a single SPI port */ /* The support SAM parts have only a single SPI port */
@ -1889,14 +1866,12 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
(void)spi_getreg(spi, SAM_SPI_SR_OFFSET); (void)spi_getreg(spi, SAM_SPI_SR_OFFSET);
(void)spi_getreg(spi, SAM_SPI_RDR_OFFSET); (void)spi_getreg(spi, SAM_SPI_RDR_OFFSET);
#ifndef CONFIG_SPI_OWNBUS
/* Initialize the SPI semaphore that enforces mutually exclusive /* Initialize the SPI semaphore that enforces mutually exclusive
* access to the SPI registers. * access to the SPI registers.
*/ */
sem_init(&spi->spisem, 0, 1); sem_init(&spi->spisem, 0, 1);
spi->initialized = true; spi->initialized = true;
#endif
#ifdef CONFIG_SAMV7_SPI_DMA #ifdef CONFIG_SAMV7_SPI_DMA
/* Initialize the SPI semaphore that is used to wake up the waiting /* Initialize the SPI semaphore that is used to wake up the waiting
@ -1914,10 +1889,8 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
spi_dumpregs(spi, "After initialization"); spi_dumpregs(spi, "After initialization");
} }
#ifndef CONFIG_SPI_OWNBUS /* Set to mode=0 and nbits=8 and impossible frequency. The SPI will only
/* Set to mode=0 and nbits=8 and impossible frequency. It is only * be reconfigured if there is a change.
* critical to do this if CONFIG_SPI_OWNBUS is not defined because in
* that case, the SPI will only be reconfigured if there is a change.
*/ */
offset = (unsigned int)g_csroffset[csno]; offset = (unsigned int)g_csroffset[csno];
@ -1928,7 +1901,6 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
spics->nbits = 8; spics->nbits = 8;
spivdbg("csr[offset=%02x]=%08x\n", offset, regval); spivdbg("csr[offset=%02x]=%08x\n", offset, regval);
#endif
return &spics->spidev; return &spics->spidev;
} }

View File

@ -199,13 +199,11 @@ struct stm32_spidev_s
uint32_t txccr; /* DMA control register for TX transfers */ uint32_t txccr; /* DMA control register for TX transfers */
uint32_t rxccr; /* DMA control register for RX transfers */ uint32_t rxccr; /* DMA control register for RX transfers */
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
int8_t nbits; /* Width of word in bits (8 or 16) */ int8_t nbits; /* Width of word in bits (8 or 16) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
}; };
/************************************************************************************ /************************************************************************************
@ -240,9 +238,7 @@ static inline void spi_dmatxstart(FAR struct stm32_spidev_s *priv);
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void spi_setbits(FAR struct spi_dev_s *dev, int nbits); static void spi_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -267,9 +263,7 @@ static void spi_portinitialize(FAR struct stm32_spidev_s *priv);
#ifdef CONFIG_STM32_SPI1 #ifdef CONFIG_STM32_SPI1
static const struct spi_ops_s g_sp1iops = static const struct spi_ops_s g_sp1iops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = stm32_spi1select, .select = stm32_spi1select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -313,9 +307,7 @@ static struct stm32_spidev_s g_spi1dev =
#ifdef CONFIG_STM32_SPI2 #ifdef CONFIG_STM32_SPI2
static const struct spi_ops_s g_sp2iops = static const struct spi_ops_s g_sp2iops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = stm32_spi2select, .select = stm32_spi2select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -356,9 +348,7 @@ static struct stm32_spidev_s g_spi2dev =
#ifdef CONFIG_STM32_SPI3 #ifdef CONFIG_STM32_SPI3
static const struct spi_ops_s g_sp3iops = static const struct spi_ops_s g_sp3iops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = stm32_spi3select, .select = stm32_spi3select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -399,9 +389,7 @@ static struct stm32_spidev_s g_spi3dev =
#ifdef CONFIG_STM32_SPI4 #ifdef CONFIG_STM32_SPI4
static const struct spi_ops_s g_sp4iops = static const struct spi_ops_s g_sp4iops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = stm32_spi4select, .select = stm32_spi4select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -442,9 +430,7 @@ static struct stm32_spidev_s g_spi4dev =
#ifdef CONFIG_STM32_SPI5 #ifdef CONFIG_STM32_SPI5
static const struct spi_ops_s g_sp5iops = static const struct spi_ops_s g_sp5iops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = stm32_spi5select, .select = stm32_spi5select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -485,9 +471,7 @@ static struct stm32_spidev_s g_spi5dev =
#ifdef CONFIG_STM32_SPI6 #ifdef CONFIG_STM32_SPI6
static const struct spi_ops_s g_sp6iops = static const struct spi_ops_s g_sp6iops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = stm32_spi6select, .select = stm32_spi6select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -944,7 +928,6 @@ static void spi_modifycr1(FAR struct stm32_spidev_s *priv, uint16_t setbits, uin
* *
************************************************************************************/ ************************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct stm32_spidev_s *priv = (FAR struct stm32_spidev_s *)dev; FAR struct stm32_spidev_s *priv = (FAR struct stm32_spidev_s *)dev;
@ -968,7 +951,6 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
} }
return OK; return OK;
} }
#endif
/************************************************************************************ /************************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency
@ -1000,10 +982,8 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Has the frequency changed? */ /* Has the frequency changed? */
#ifndef CONFIG_SPI_OWNBUS
if (frequency != priv->frequency) if (frequency != priv->frequency)
{ {
#endif
/* Choices are limited by PCLK frequency with a set of divisors */ /* Choices are limited by PCLK frequency with a set of divisors */
if (frequency >= priv->spiclock >> 1) if (frequency >= priv->spiclock >> 1)
@ -1073,14 +1053,11 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
spivdbg("Frequency %d->%d\n", frequency, actual); spivdbg("Frequency %d->%d\n", frequency, actual);
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
} }
return priv->actual; return priv->actual;
#else
return actual;
#endif
} }
/************************************************************************************ /************************************************************************************
@ -1108,10 +1085,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set CR1 appropriately */ /* Yes... Set CR1 appropriately */
switch (mode) switch (mode)
@ -1146,10 +1121,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configurations will be faster */ /* Save the mode so that subsequent re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/************************************************************************************ /************************************************************************************
@ -1177,10 +1150,8 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Has the number of bits changed? */ /* Has the number of bits changed? */
#ifndef CONFIG_SPI_OWNBUS
if (nbits != priv->nbits) if (nbits != priv->nbits)
{ {
#endif
/* Yes... Set CR1 appropriately */ /* Yes... Set CR1 appropriately */
switch (nbits) switch (nbits)
@ -1215,10 +1186,8 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Save the selection so the subsequence re-configurations will be faster */ /* Save the selection so the subsequence re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->nbits = nbits; priv->nbits = nbits;
} }
#endif
} }
/************************************************************************************ /************************************************************************************
@ -1511,11 +1480,9 @@ static void spi_portinitialize(FAR struct stm32_spidev_s *priv)
setbits = SPI_CR1_MSTR | SPI_CR1_SSI | SPI_CR1_SSM; setbits = SPI_CR1_MSTR | SPI_CR1_SSI | SPI_CR1_SSM;
spi_modifycr1(priv, setbits, clrbits); spi_modifycr1(priv, setbits, clrbits);
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = 0; priv->frequency = 0;
priv->nbits = 8; priv->nbits = 8;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Select a default frequency of approx. 400KHz */ /* Select a default frequency of approx. 400KHz */
@ -1527,9 +1494,7 @@ static void spi_portinitialize(FAR struct stm32_spidev_s *priv)
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
/* Initialize the SPI semaphores that is used to wait for DMA completion */ /* Initialize the SPI semaphores that is used to wait for DMA completion */

View File

@ -218,17 +218,14 @@ struct tiva_ssidev_s
uint8_t irq; /* SSI IRQ number */ uint8_t irq; /* SSI IRQ number */
#endif #endif
/* If there is more than one device on the SPI bus, then we have to enforce /* Enforce mutual exclusion and remember some configuration settings to
* mutual exclusion and remember some configuration settings to reduce the * reduce the overhead of constant SPI re-configuration.
* overhead of constant SPI re-configuration.
*/ */
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* For exclusive access to the SSI bus */ sem_t exclsem; /* For exclusive access to the SSI bus */
uint32_t frequency; /* Current desired SCLK frequency */ uint32_t frequency; /* Current desired SCLK frequency */
uint32_t actual; /* Current actual SCLK frequency */ uint32_t actual; /* Current actual SCLK frequency */
uint8_t mode; /* Current mode 0,1,2,3 */ uint8_t mode; /* Current mode 0,1,2,3 */
#endif
}; };
/**************************************************************************** /****************************************************************************
@ -280,9 +277,7 @@ static int ssi_interrupt(int irq, void *context);
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int ssi_lock(FAR struct spi_dev_s *dev, bool lock); static int ssi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t ssi_setfrequencyinternal(struct tiva_ssidev_s *priv, static uint32_t ssi_setfrequencyinternal(struct tiva_ssidev_s *priv,
uint32_t frequency); uint32_t frequency);
static uint32_t ssi_setfrequency(FAR struct spi_dev_s *dev, static uint32_t ssi_setfrequency(FAR struct spi_dev_s *dev,
@ -311,9 +306,7 @@ static void ssi_recvblock(FAR struct spi_dev_s *dev, FAR void *buffer,
static const struct spi_ops_s g_spiops = static const struct spi_ops_s g_spiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = ssi_lock, .lock = ssi_lock,
#endif
.select = tiva_spiselect, /* Provided externally by board logic */ .select = tiva_spiselect, /* Provided externally by board logic */
.setfrequency = ssi_setfrequency, .setfrequency = ssi_setfrequency,
.setmode = ssi_setmode, .setmode = ssi_setmode,
@ -457,7 +450,7 @@ static inline void ssi_putreg(struct tiva_ssidev_s *priv,
* State of the SSI before the SSE was disabled * State of the SSI before the SSE was disabled
* *
* Assumption: * Assumption:
* Caller holds a lock on the SPI bus (if CONFIG_SPI_OWNBUS not defined) * Caller holds a lock on the SPI bus
* *
****************************************************************************/ ****************************************************************************/
@ -486,7 +479,7 @@ static uint32_t ssi_disable(struct tiva_ssidev_s *priv)
* Returned Value: * Returned Value:
* *
* Assumption: * Assumption:
* Caller holds a lock on the SPI bus (if CONFIG_SPI_OWNBUS not defined) * Caller holds a lock on the SPI bus
* *
****************************************************************************/ ****************************************************************************/
@ -836,7 +829,7 @@ static inline void ssi_performrx(struct tiva_ssidev_s *priv)
* 0: success, <0:Negated error number on failure * 0: success, <0:Negated error number on failure
* *
* Assumption: * Assumption:
* Caller holds a lock on the SPI bus (if CONFIG_SPI_OWNBUS not defined) * Caller holds a lock on the SPI bus
* *
****************************************************************************/ ****************************************************************************/
@ -1092,7 +1085,6 @@ static int ssi_interrupt(int irq, void *context)
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int ssi_lock(FAR struct spi_dev_s *dev, bool lock) static int ssi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct tiva_ssidev_s *priv = (FAR struct tiva_ssidev_s *)dev; FAR struct tiva_ssidev_s *priv = (FAR struct tiva_ssidev_s *)dev;
@ -1117,7 +1109,6 @@ static int ssi_lock(FAR struct spi_dev_s *dev, bool lock)
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: ssi_setfrequency * Name: ssi_setfrequency
@ -1133,7 +1124,7 @@ static int ssi_lock(FAR struct spi_dev_s *dev, bool lock)
* Returns the actual frequency selected * Returns the actual frequency selected
* *
* Assumption: * Assumption:
* Caller holds a lock on the SPI bus (if CONFIG_SPI_OWNBUS not defined) * Caller holds a lock on the SPI bus
* *
****************************************************************************/ ****************************************************************************/
@ -1151,10 +1142,8 @@ static uint32_t ssi_setfrequencyinternal(struct tiva_ssidev_s *priv,
/* Has the frequency changed? */ /* Has the frequency changed? */
#ifndef CONFIG_SPI_OWNBUS
if (frequency != priv->frequency) if (frequency != priv->frequency)
{ {
#endif
/* "The serial bit rate is derived by dividing down the input clock /* "The serial bit rate is derived by dividing down the input clock
* (FSysClk). The clock is first divided by an even prescale value * (FSysClk). The clock is first divided by an even prescale value
* CPSDVSR from 2 to 254, which is programmed in the SSI Clock Prescale * CPSDVSR from 2 to 254, which is programmed in the SSI Clock Prescale
@ -1228,16 +1217,11 @@ static uint32_t ssi_setfrequencyinternal(struct tiva_ssidev_s *priv,
* faster. * faster.
*/ */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
} }
return priv->actual; return priv->actual;
#else
return actual;
#endif
} }
static uint32_t ssi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency) static uint32_t ssi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
@ -1268,7 +1252,7 @@ static uint32_t ssi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
* none * none
* *
* Assumption: * Assumption:
* Caller holds a lock on the SPI bus (if CONFIG_SPI_OWNBUS not defined) * Caller holds a lock on the SPI bus
* *
****************************************************************************/ ****************************************************************************/
@ -1282,10 +1266,8 @@ static void ssi_setmodeinternal(struct tiva_ssidev_s *priv, enum spi_mode_e mode
/* Has the number of bits per word changed? */ /* Has the number of bits per word changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Select the CTL register bits based on the selected mode */ /* Select the CTL register bits based on the selected mode */
switch (mode) switch (mode)
@ -1320,10 +1302,8 @@ static void ssi_setmodeinternal(struct tiva_ssidev_s *priv, enum spi_mode_e mode
/* Save the mode so that subsequent re-configuratins will be faster */ /* Save the mode so that subsequent re-configuratins will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
static void ssi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode) static void ssi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
@ -1352,7 +1332,7 @@ static void ssi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
* none * none
* *
* Assumption: * Assumption:
* Caller holds a lock on the SPI bus (if CONFIG_SPI_OWNBUS not defined) * Caller holds a lock on the SPI bus
* *
****************************************************************************/ ****************************************************************************/
@ -1662,9 +1642,7 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
#ifndef CONFIG_SSI_POLLWAIT #ifndef CONFIG_SSI_POLLWAIT
sem_init(&priv->xfrsem, 0, 0); sem_init(&priv->xfrsem, 0, 0);
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
/* Set all CR1 fields to reset state. This will be master mode. */ /* Set all CR1 fields to reset state. This will be master mode. */

View File

@ -90,12 +90,10 @@
struct avr_spidev_s struct avr_spidev_s
{ {
struct spi_dev_s spidev; /* Externally visible part of the SPI interface */ struct spi_dev_s spidev; /* Externally visible part of the SPI interface */
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
}; };
/**************************************************************************** /****************************************************************************
@ -104,9 +102,7 @@ struct avr_spidev_s
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void spi_setbits(FAR struct spi_dev_s *dev, int nbits); static void spi_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -120,9 +116,7 @@ static void spi_recvblock(FAR struct spi_dev_s *dev, FAR void *buffer, size_
static const struct spi_ops_s g_spiops = static const struct spi_ops_s g_spiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = avr_spiselect, .select = avr_spiselect,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -174,7 +168,6 @@ static struct avr_spidev_s g_spidev =
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct avr_spidev_s *priv = (FAR struct avr_spidev_s *)dev; FAR struct avr_spidev_s *priv = (FAR struct avr_spidev_s *)dev;
@ -198,7 +191,6 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
} }
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency
@ -217,15 +209,13 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency) static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
{ {
uint32_t actual;
#ifndef CONFIG_SPI_OWNBUS
FAR struct avr_spidev_s *priv = (FAR struct avr_spidev_s *)dev; FAR struct avr_spidev_s *priv = (FAR struct avr_spidev_s *)dev;
uint32_t actual;
/* Has the request frequency changed? */ /* Has the request frequency changed? */
if (frequency != priv->frequency) if (frequency != priv->frequency)
{ {
#endif
/* Read the SPI status and control registers, clearing all divider bits */ /* Read the SPI status and control registers, clearing all divider bits */
uint8_t spcr = SPCR & ~((1 << SPR0) | (1 << SPR1)); uint8_t spcr = SPCR & ~((1 << SPR0) | (1 << SPR1));
@ -274,7 +264,6 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
} }
@ -282,7 +271,6 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
{ {
actual = priv->actual; actual = priv->actual;
} }
#endif
spidbg("Frequency %d->%d\n", frequency, actual); spidbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -305,14 +293,12 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode) static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
{ {
#ifndef CONFIG_SPI_OWNBUS
FAR struct avr_spidev_s *priv = (FAR struct avr_spidev_s *)dev; FAR struct avr_spidev_s *priv = (FAR struct avr_spidev_s *)dev;
/* Has the mode changed? */ /* Has the mode changed? */
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
uint8_t regval; uint8_t regval;
/* Yes... Set SPI CR appropriately */ /* Yes... Set SPI CR appropriately */
@ -346,10 +332,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configuratins will be faster */ /* Save the mode so that subsequent re-configuratins will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -524,10 +508,8 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
/* Set the initial SPI configuration */ /* Set the initial SPI configuration */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = 0; priv->frequency = 0;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Select a default frequency of approx. 400KHz */ /* Select a default frequency of approx. 400KHz */
@ -535,9 +517,7 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
irqrestore(flags); irqrestore(flags);
return &priv->spidev; return &priv->spidev;

View File

@ -101,13 +101,11 @@ struct pic32mx_dev_s
uint8_t rxirq; /* SPI receive done interrupt number */ uint8_t rxirq; /* SPI receive done interrupt number */
uint8_t txirq; /* SPI transfer done interrupt number */ uint8_t txirq; /* SPI transfer done interrupt number */
#endif #endif
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t nbits; /* Width of word in bits (8 to 16) */ uint8_t nbits; /* Width of word in bits (8 to 16) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
}; };
/**************************************************************************** /****************************************************************************
@ -122,9 +120,7 @@ static void spi_putreg(FAR struct pic32mx_dev_s *priv,
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void spi_setbits(FAR struct spi_dev_s *dev, int nbits); static void spi_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -140,9 +136,7 @@ static void spi_recvblock(FAR struct spi_dev_s *dev, FAR void *buffer, size_
static const struct spi_ops_s g_spi1ops = static const struct spi_ops_s g_spi1ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = pic32mx_spi1select, .select = pic32mx_spi1select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -180,9 +174,7 @@ static struct pic32mx_dev_s g_spi1dev =
#ifdef CONFIG_PIC32MX_SPI2 #ifdef CONFIG_PIC32MX_SPI2
static const struct spi_ops_s g_spi2ops = static const struct spi_ops_s g_spi2ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = pic32mx_spi2select, .select = pic32mx_spi2select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -217,9 +209,7 @@ static struct pic32mx_dev_s g_spi2dev =
#ifdef CONFIG_PIC32MX_SPI3 #ifdef CONFIG_PIC32MX_SPI3
static const struct spi_ops_s g_spi3ops = static const struct spi_ops_s g_spi3ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = pic32mx_spi3select, .select = pic32mx_spi3select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -254,9 +244,7 @@ static struct pic32mx_dev_s g_spi3dev =
#ifdef CONFIG_PIC32MX_SPI4 #ifdef CONFIG_PIC32MX_SPI4
static const struct spi_ops_s g_spi4ops = static const struct spi_ops_s g_spi4ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = pic32mx_spi4select, .select = pic32mx_spi4select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -441,7 +429,6 @@ static void spi_putreg(FAR struct pic32mx_dev_s *priv, unsigned int offset,
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct pic32mx_dev_s *priv = (FAR struct pic32mx_dev_s *)dev; FAR struct pic32mx_dev_s *priv = (FAR struct pic32mx_dev_s *)dev;
@ -465,7 +452,6 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
} }
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency
@ -489,23 +475,17 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
uint32_t actual; uint32_t actual;
uint32_t regval; uint32_t regval;
#ifndef CONFIG_SPI_OWNBUS
spivdbg("Old frequency: %d actual: %d New frequency: %d\n", spivdbg("Old frequency: %d actual: %d New frequency: %d\n",
priv->frequency, priv->actual, frequency); priv->frequency, priv->actual, frequency);
#else
spivdbg("New frequency: %d\n", regval);
#endif
/* Check if the requested frequency is the same as the frequency selection */ /* Check if the requested frequency is the same as the frequency selection */
#ifndef CONFIG_SPI_OWNBUS
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* Calculate the divisor /* Calculate the divisor
* *
@ -542,10 +522,8 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
spidbg("New frequency: %d Actual: %d\n", frequency, actual); spidbg("New frequency: %d Actual: %d\n", frequency, actual);
return actual; return actual;
@ -571,18 +549,12 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
FAR struct pic32mx_dev_s *priv = (FAR struct pic32mx_dev_s *)dev; FAR struct pic32mx_dev_s *priv = (FAR struct pic32mx_dev_s *)dev;
uint32_t regval; uint32_t regval;
#ifndef CONFIG_SPI_OWNBUS
spivdbg("Old mode: %d New mode: %d\n", priv->mode, mode); spivdbg("Old mode: %d New mode: %d\n", priv->mode, mode);
#else
spivdbg("New mode: %d\n", mode);
#endif
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set CON register appropriately. /* Yes... Set CON register appropriately.
* *
* Standard terminology is as follows: * Standard terminology is as follows:
@ -643,10 +615,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configuratins will be faster */ /* Save the mode so that subsequent re-configuratins will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -670,19 +640,14 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
uint32_t setting; uint32_t setting;
uint32_t regval; uint32_t regval;
#ifndef CONFIG_SPI_OWNBUS
spivdbg("Old nbits: %d New nbits: %d\n", priv->nbits, nbits); spivdbg("Old nbits: %d New nbits: %d\n", priv->nbits, nbits);
#else
spivdbg("New nbits: %d\n", nbits);
#endif
/* Has the number of bits changed? */ /* Has the number of bits changed? */
DEBUGASSERT(priv && nbits > 7 && nbits < 17); DEBUGASSERT(priv && nbits > 7 && nbits < 17);
#ifndef CONFIG_SPI_OWNBUS
if (nbits != priv->nbits) if (nbits != priv->nbits)
{ {
#endif
/* Yes... Set the CON register appropriately */ /* Yes... Set the CON register appropriately */
if (nbits == 8) if (nbits == 8)
@ -711,10 +676,8 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Save the selection so the subsequence re-configurations will be faster */ /* Save the selection so the subsequence re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->nbits = nbits; priv->nbits = nbits;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -992,16 +955,12 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
/* Set the initial SPI configuration */ /* Set the initial SPI configuration */
#ifndef CONFIG_SPI_OWNBUS
priv->nbits = 8; priv->nbits = 8;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
#ifdef CONFIG_PIC32MX_SPI_INTERRUPTS #ifdef CONFIG_PIC32MX_SPI_INTERRUPTS
/* Enable interrupts at the SPI controller */ /* Enable interrupts at the SPI controller */

View File

@ -106,13 +106,10 @@ struct pic32mz_dev_s
{ {
struct spi_dev_s spidev; /* Externally visible part of the SPI interface */ struct spi_dev_s spidev; /* Externally visible part of the SPI interface */
FAR const struct pic32mz_config_s *config; FAR const struct pic32mz_config_s *config;
#ifndef CONFIG_SPI_OWNBUS
sem_t exclsem; /* Held while chip is selected for mutual exclusion */ sem_t exclsem; /* Held while chip is selected for mutual exclusion */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
#endif
uint8_t nbits; /* Width of word in bits (8 to 16) */ uint8_t nbits; /* Width of word in bits (8 to 16) */
#ifdef CONFIG_PIC32MZ_SPI_REGDEBUG #ifdef CONFIG_PIC32MZ_SPI_REGDEBUG
@ -152,9 +149,7 @@ static void spi_exchange8(FAR struct pic32mz_dev_s *priv,
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void spi_setbits(FAR struct spi_dev_s *dev, int nbits); static void spi_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -177,9 +172,7 @@ static void spi_recvblock(FAR struct spi_dev_s *dev, FAR void *buffer,
static const struct spi_ops_s g_spi1ops = static const struct spi_ops_s g_spi1ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = pic32mz_spi1select, .select = pic32mz_spi1select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -228,9 +221,7 @@ static struct pic32mz_dev_s g_spi1dev =
#ifdef CONFIG_PIC32MZ_SPI2 #ifdef CONFIG_PIC32MZ_SPI2
static const struct spi_ops_s g_spi2ops = static const struct spi_ops_s g_spi2ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = pic32mz_spi2select, .select = pic32mz_spi2select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -276,9 +267,7 @@ static struct pic32mz_dev_s g_spi2dev =
#ifdef CONFIG_PIC32MZ_SPI3 #ifdef CONFIG_PIC32MZ_SPI3
static const struct spi_ops_s g_spi3ops = static const struct spi_ops_s g_spi3ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = pic32mz_spi3select, .select = pic32mz_spi3select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -324,9 +313,7 @@ static struct pic32mz_dev_s g_spi3dev =
#ifdef CONFIG_PIC32MZ_SPI4 #ifdef CONFIG_PIC32MZ_SPI4
static const struct spi_ops_s g_spi4ops = static const struct spi_ops_s g_spi4ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = pic32mz_spi4select, .select = pic32mz_spi4select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -372,9 +359,7 @@ static struct pic32mz_dev_s g_spi4dev =
#ifdef CONFIG_PIC32MZ_SPI5 #ifdef CONFIG_PIC32MZ_SPI5
static const struct spi_ops_s g_spi5ops = static const struct spi_ops_s g_spi5ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = pic32mz_spi5select, .select = pic32mz_spi5select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -420,9 +405,7 @@ static struct pic32mz_dev_s g_spi5dev =
#ifdef CONFIG_PIC32MZ_SPI6 #ifdef CONFIG_PIC32MZ_SPI6
static const struct spi_ops_s g_spi6ops = static const struct spi_ops_s g_spi6ops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spi_lock, .lock = spi_lock,
#endif
.select = pic32mz_spi6select, .select = pic32mz_spi6select,
.setfrequency = spi_setfrequency, .setfrequency = spi_setfrequency,
.setmode = spi_setmode, .setmode = spi_setmode,
@ -807,7 +790,6 @@ static void spi_exchange16(FAR struct pic32mz_dev_s *priv,
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct pic32mz_dev_s *priv = (FAR struct pic32mz_dev_s *)dev; FAR struct pic32mz_dev_s *priv = (FAR struct pic32mz_dev_s *)dev;
@ -831,7 +813,6 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
} }
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency
@ -855,23 +836,17 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
uint32_t actual; uint32_t actual;
uint32_t regval; uint32_t regval;
#ifndef CONFIG_SPI_OWNBUS
spivdbg("Old frequency: %d actual: %d New frequency: %d\n", spivdbg("Old frequency: %d actual: %d New frequency: %d\n",
priv->frequency, priv->actual, frequency); priv->frequency, priv->actual, frequency);
#else
spivdbg("New frequency: %d\n", regval);
#endif
/* Check if the requested frequency is the same as the frequency selection */ /* Check if the requested frequency is the same as the frequency selection */
#ifndef CONFIG_SPI_OWNBUS
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* Calculate the divisor /* Calculate the divisor
* *
@ -908,10 +883,8 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
spidbg("New frequency: %d Actual: %d\n", frequency, actual); spidbg("New frequency: %d Actual: %d\n", frequency, actual);
return actual; return actual;
@ -937,18 +910,12 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
FAR struct pic32mz_dev_s *priv = (FAR struct pic32mz_dev_s *)dev; FAR struct pic32mz_dev_s *priv = (FAR struct pic32mz_dev_s *)dev;
uint32_t regval; uint32_t regval;
#ifndef CONFIG_SPI_OWNBUS
spivdbg("Old mode: %d New mode: %d\n", priv->mode, mode); spivdbg("Old mode: %d New mode: %d\n", priv->mode, mode);
#else
spivdbg("New mode: %d\n", mode);
#endif
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set CON register appropriately. /* Yes... Set CON register appropriately.
* *
* Standard terminology is as follows: * Standard terminology is as follows:
@ -1009,10 +976,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configuratins will be faster */ /* Save the mode so that subsequent re-configuratins will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -1392,16 +1357,12 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
/* Set the initial SPI configuration */ /* Set the initial SPI configuration */
#ifndef CONFIG_SPI_OWNBUS
priv->nbits = 8; priv->nbits = 8;
priv->mode = SPIDEV_MODE0; priv->mode = SPIDEV_MODE0;
#endif
/* Initialize the SPI semaphore that enforces mutually exclusive access */ /* Initialize the SPI semaphore that enforces mutually exclusive access */
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
#ifdef CONFIG_PIC32MZ_SPI_INTERRUPTS #ifdef CONFIG_PIC32MZ_SPI_INTERRUPTS
/* Enable interrupts at the SPI controller */ /* Enable interrupts at the SPI controller */

View File

@ -204,9 +204,7 @@ struct sim_spiflashdev_s
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spiflash_lock(FAR struct spi_dev_s *dev, bool lock); static int spiflash_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spiflash_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t spiflash_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void spiflash_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spiflash_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void spiflash_setbits(FAR struct spi_dev_s *dev, int nbits); static void spiflash_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -235,9 +233,7 @@ static uint16_t spiflash_readword(FAR struct sim_spiflashdev_s *priv);
static const struct spi_ops_s g_spiops = static const struct spi_ops_s g_spiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
.lock = spiflash_lock, .lock = spiflash_lock,
#endif
.select = spiflash_select, .select = spiflash_select,
.setfrequency = spiflash_setfrequency, .setfrequency = spiflash_setfrequency,
.setmode = spiflash_setmode, .setmode = spiflash_setmode,
@ -293,12 +289,10 @@ struct sim_spiflashdev_s g_spidev =
* *
************************************************************************************/ ************************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spiflash_lock(FAR struct spi_dev_s *dev, bool lock) static int spiflash_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
return OK; return OK;
} }
#endif
/************************************************************************************ /************************************************************************************
* Name: spiflash_select * Name: spiflash_select

View File

@ -90,13 +90,11 @@ struct z16f_spi_s
{ {
struct spi_dev_s spi; /* Externally visible part of the SPI interface */ struct spi_dev_s spi; /* Externally visible part of the SPI interface */
bool initialized; /* TRUE: Controller has been initialized */ bool initialized; /* TRUE: Controller has been initialized */
#ifndef CONFIG_SPI_OWNBUS
uint8_t nbits; /* Width of word in bits (1-8) */ uint8_t nbits; /* Width of word in bits (1-8) */
uint8_t mode; /* Mode 0,1,2,3 */ uint8_t mode; /* Mode 0,1,2,3 */
sem_t exclsem; /* Assures mutually exclusive access to SPI */ sem_t exclsem; /* Assures mutually exclusive access to SPI */
uint32_t frequency; /* Requested clock frequency */ uint32_t frequency; /* Requested clock frequency */
uint32_t actual; /* Actual clock frequency */ uint32_t actual; /* Actual clock frequency */
#endif
/* Debug stuff */ /* Debug stuff */
@ -138,9 +136,7 @@ static void spi_flush(FAR struct z16f_spi_s *priv);
/* SPI methods */ /* SPI methods */
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency); static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
static void spi_setbits(FAR struct spi_dev_s *dev, int nbits); static void spi_setbits(FAR struct spi_dev_s *dev, int nbits);
@ -162,9 +158,7 @@ static void spi_recvblock(FAR struct spi_dev_s *dev, FAR void *buffer,
static const struct spi_ops_s g_epsiops = static const struct spi_ops_s g_epsiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
spi_lock, spi_lock,
#endif
z16f_espi_select, z16f_espi_select,
spi_setfrequency, spi_setfrequency,
spi_setmode, spi_setmode,
@ -396,7 +390,6 @@ static void spi_flush(FAR struct z16f_spi_s *priv)
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
FAR struct z16f_spi_s *priv = (FAR struct z16f_spi_s *)dev; FAR struct z16f_spi_s *priv = (FAR struct z16f_spi_s *)dev;
@ -422,7 +415,6 @@ static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
return OK; return OK;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency
@ -449,14 +441,12 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Check if the requested frequency is the same as the frequency selection */ /* Check if the requested frequency is the same as the frequency selection */
#ifndef CONFIG_SPI_OWNBUS
if (priv->frequency == frequency) if (priv->frequency == frequency)
{ {
/* We are already at this frequency. Return the actual. */ /* We are already at this frequency. Return the actual. */
return priv->actual; return priv->actual;
} }
#endif
/* Fbaud = Fsystem / (2 * BRG) /* Fbaud = Fsystem / (2 * BRG)
* BRG = Fsystem / (2 * Fbaud) * BRG = Fsystem / (2 * Fbaud)
@ -482,10 +472,8 @@ static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency)
/* Save the frequency setting */ /* Save the frequency setting */
#ifndef CONFIG_SPI_OWNBUS
priv->frequency = frequency; priv->frequency = frequency;
priv->actual = actual; priv->actual = actual;
#endif
spidbg("Frequency %d->%d\n", frequency, actual); spidbg("Frequency %d->%d\n", frequency, actual);
return actual; return actual;
@ -515,10 +503,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Has the mode changed? */ /* Has the mode changed? */
#ifndef CONFIG_SPI_OWNBUS
if (mode != priv->mode) if (mode != priv->mode)
{ {
#endif
/* Yes... Set the mode appropriately: /* Yes... Set the mode appropriately:
* *
* SPI CPOL CPHA * SPI CPOL CPHA
@ -559,10 +545,8 @@ static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode)
/* Save the mode so that subsequent re-configurations will be faster */ /* Save the mode so that subsequent re-configurations will be faster */
#ifndef CONFIG_SPI_OWNBUS
priv->mode = mode; priv->mode = mode;
} }
#endif
} }
/**************************************************************************** /****************************************************************************
@ -590,9 +574,7 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
/* Has the number of bits changed? */ /* Has the number of bits changed? */
#ifndef CONFIG_SPI_OWNBUS
if (nbits != priv->nbits) if (nbits != priv->nbits)
#endif
{ {
/* Yes... Set number of bits appropriately */ /* Yes... Set number of bits appropriately */
@ -609,11 +591,9 @@ static void spi_setbits(FAR struct spi_dev_s *dev, int nbits)
spi_putreg8(priv, regval, Z16F_ESPI_MODE); spi_putreg8(priv, regval, Z16F_ESPI_MODE);
spivdbg("ESPI MODE: %02x\n", regval); spivdbg("ESPI MODE: %02x\n", regval);
#ifndef CONFIG_SPI_OWNBUS
/* Save the selection so the subsequence re-configurations will be faster */ /* Save the selection so the subsequence re-configurations will be faster */
priv->nbits = nbits; priv->nbits = nbits;
#endif
} }
} }
@ -840,9 +820,6 @@ struct spi_dev_s *up_spiinitialize(int port)
{ {
FAR struct z16f_spi_s *priv; FAR struct z16f_spi_s *priv;
irqstate_t flags; irqstate_t flags;
#ifndef CONFIG_SPI_OWNBUS
unsigned int offset;
#endif
uint8_t regval; uint8_t regval;
spivdbg("port: %d\n", port); spivdbg("port: %d\n", port);
@ -857,9 +834,7 @@ struct spi_dev_s *up_spiinitialize(int port)
flags = irqsave(); flags = irqsave();
priv->spi.ops = &g_epsiops; priv->spi.ops = &g_epsiops;
#ifndef CONFIG_SPI_OWNBUS
sem_init(&priv->exclsem, 0, 1); sem_init(&priv->exclsem, 0, 1);
#endif
/* Set up the SPI pin configuration (board-specific logic is required to /* Set up the SPI pin configuration (board-specific logic is required to
* configure and manage all chip selects). * configure and manage all chip selects).

View File

@ -68,9 +68,7 @@
* Private Function Prototypes * Private Function Prototypes
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock); static int spi_lock(FAR struct spi_dev_s *dev, bool lock);
#endif
static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev, static uint32_t spi_setfrequency(FAR struct spi_dev_s *dev,
uint32_t frequency); uint32_t frequency);
static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode); static void spi_setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);
@ -86,9 +84,7 @@ static void spi_recvblock(FAR struct spi_dev_s *dev, FAR uint8_t *buffer,
static const struct spi_ops_s g_spiops = static const struct spi_ops_s g_spiops =
{ {
#ifndef CONFIG_SPI_OWNBUS
spi_lock, spi_lock,
#endif
ez80_spiselect, /* select: Provided externally by board logic */ ez80_spiselect, /* select: Provided externally by board logic */
spi_setfrequency, spi_setfrequency,
spi_setmode, spi_setmode,
@ -142,14 +138,12 @@ static struct spi_dev_s g_spidev = { &g_spiops };
* *
****************************************************************************/ ****************************************************************************/
#ifndef CONFIG_SPI_OWNBUS
static int spi_lock(FAR struct spi_dev_s *dev, bool lock) static int spi_lock(FAR struct spi_dev_s *dev, bool lock)
{ {
/* Not implemented */ /* Not implemented */
return -ENOSYS; return -ENOSYS;
} }
#endif
/**************************************************************************** /****************************************************************************
* Name: spi_setfrequency * Name: spi_setfrequency