Merged in alinjerpelea/nuttx (pull request #1038)

cxd56xx: various fixes

* arch: arm: cxd56xx: Support to set any i2c frequency

    This commit supports to be able to set the i2c frequency other than just
    100 or 400 Hz.

* arch: arm: cxd56xx: Enable SD clock during access to SD card

    - Improve GNSS low sensitivity with SD card inserted
    - Reduce power consumption by stopping SD clock

* arch: arm: cxd56xx: Do PANIC() when cpu rx fifo is overflow

    If CPU Rx FIFO is overflow, it's fatal error for system. In such a case,
    this commit changes to allow the user to notice by calling PANIC() for
    debuggability enhancement.

* arch: arm: cxd56xx: Fix compile error in sdhci debug code

* arch: arm: cxd56xx: Remove assertion in cpu tx queue

    When CPU Tx queue is overflow, it returns -EAGAIN instead of assertion
    to be able to retry.

* arch: arm: cxd56xx: Add configurations for cpu fifo elements

    Signed-off-by: Alin Jerpelea <alin.jerpelea@sony.com>

* arch: arm: cxd56xx: Fix LPADC configuration

    LPADC options defined in the same symbol name, so kconfig tool
    couldn't process them correctly.

    Signed-off-by: Alin Jerpelea <alin.jerpelea@sony.com>

* arch: arm: cxd56xx: Update loader and gnssfw ver.17660

* arch: arm: cxd56xx: Fix hang-up when error interrupt occurs

    Fix a problem that error interrupts are not cleared.

    Signed-off-by: Alin Jerpelea <alin.jerpelea@sony.com>

* arch: arm: cxd56xx: Fix sdhci semaphore

    Fix inital value of semaphore in sdhci drive.r

    Signed-off-by: Alin Jerpelea <alin.jerpelea@sony.com>

* boards: cxd56xx: Treat the initial value of LNA power as off

    LNA is always turned power on when GNSS is started. So it is desirable
    that the initial value of the LNA power is off by default.

* boards: cxd56xx: Remove initial setting of PIN_AP_CLK

    PIN_AP_CLK is used as a port selector of SDIO expander on the extension
    board, and is set output low in initalizing. Therefore, this pin cannot
    be used for other board. To avoid this restriction, remove this initial
    operation because this pin is pulled down by default on the extension
    board.

Approved-by: Gregory Nutt <gnutt@nuttx.org>
This commit is contained in:
Alin Jerpelea 2019-09-26 11:28:26 +00:00 committed by Gregory Nutt
parent 81aecdce1e
commit 7420f4dc5e
9 changed files with 163 additions and 291 deletions

View File

@ -69,6 +69,16 @@ config CXD56_ICC
bool bool
default y default y
config CXD56_CPUFIFO_ENTRIES
int "CPU Tx FIFO elements"
default 8
depends on CXD56_CPUFIFO
config CXD56_CPUFIFO_NBUFFERS
int "CPU Rx FIFO elements"
default 8
depends on CXD56_ICC
config CXD56_FARAPI config CXD56_FARAPI
bool bool
default y default y
@ -698,23 +708,41 @@ config CXD56_LPADC_ALL
Switch the LPADC all channels sampling in time division. Switch the LPADC all channels sampling in time division.
endchoice endchoice
menu "LADC0" menu "LPADC0"
depends on CXD56_LPADC0 depends on CXD56_LPADC0 || CXD56_LPADC0_1 || CXD56_LPADC_ALL
config CXD56_LPADC0_FREQ config CXD56_LPADC0_FREQ
int "Coefficient of sampling frequency" int "Coefficient of sampling frequency"
default 12 default 12
range 11 15 if CXD56_SCU_32K range 11 15 if CXD56_SCU_32K && CXD56_LPADC0
range 3 15 if CXD56_SCU_RCOSC range 3 15 if CXD56_SCU_RCOSC && CXD56_LPADC0
range 2 15 if CXD56_SCU_XOSC range 2 15 if CXD56_SCU_XOSC && CXD56_LPADC0
range 12 15 if CXD56_SCU_32K && CXD56_LPADC0_1
range 6 15 if CXD56_SCU_RCOSC && CXD56_LPADC0_1
range 6 15 if CXD56_SCU_XOSC && CXD56_LPADC0_1
range 11 15 if CXD56_SCU_32K && CXD56_LPADC_ALL
range 7 15 if CXD56_SCU_RCOSC && CXD56_LPADC_ALL
range 7 15 if CXD56_SCU_XOSC && CXD56_LPADC_ALL
---help--- ---help---
This configuration set to sampling frequency calculated by the following formula. This configuration set to sampling frequency calculated by the following formula.
Sampling frequency = SCU32K / 2 ^ n [Hz]
Note. Setable range depends on the SCU clock mode. Note: Available range depends on the SCU clock mode.
(Use channel 0 only) Sampling frequency = SCU32K / 2 ^ n [Hz]
SCU32K : 11 to 15 SCU32K : 11 to 15
RCOSC : 3 to 15 RCOSC : 3 to 15
XOSC : 2 to 15 XOSC : 2 to 15
(Use channel 0/1) Sampling frequency = SCU32K / 2 ^ (n+1) [Hz]
SCU32K : 12 to 15
RCOSC : 6 to 15
XOSC : 6 to 15
(Use all of channels) Sampling frequency = SCU32K / 2 ^ (n+2) [Hz]
SCU32K : 11 to 15
RCOSC : 7 to 15
XOSC : 7 to 15
config CXD56_LPADC0_OFFSET config CXD56_LPADC0_OFFSET
int "Offset" int "Offset"
default 0 default 0
@ -730,27 +758,45 @@ config CXD56_LPADC0_FSIZE
default 16 default 16
range 2 40960 range 2 40960
---help--- ---help---
SCU FIFO size SCU FIFO size
endmenu # CXD56_LPADC0 endmenu # CXD56_LPADC0
menu "LADC1" menu "LPADC1"
depends on CXD56_LPADC1 depends on CXD56_LPADC1 || CXD56_LPADC0_1 || CXD56_LPADC_ALL
config CXD56_LPADC1_FREQ config CXD56_LPADC1_FREQ
int "Coefficient of sampling frequency" int "Coefficient of sampling frequency"
default 12 default 12
range 11 15 if CXD56_SCU_32K range 11 15 if CXD56_SCU_32K && CXD56_LPADC1
range 3 15 if CXD56_SCU_RCOSC range 3 15 if CXD56_SCU_RCOSC && CXD56_LPADC1
range 2 15 if CXD56_SCU_XOSC range 2 15 if CXD56_SCU_XOSC && CXD56_LPADC1
range 12 15 if CXD56_SCU_32K && CXD56_LPADC0_1
range 6 15 if CXD56_SCU_RCOSC && CXD56_LPADC0_1
range 6 15 if CXD56_SCU_XOSC && CXD56_LPADC0_1
range 11 15 if CXD56_SCU_32K && CXD56_LPADC_ALL
range 7 15 if CXD56_SCU_RCOSC && CXD56_LPADC_ALL
range 7 15 if CXD56_SCU_XOSC && CXD56_LPADC_ALL
---help--- ---help---
This configuration set to sampling frequency calculated by the following formula. This configuration set to sampling frequency calculated by the following formula.
Sampling frequency = SCU32K / 2 ^ n [Hz]
Note. Setable range depends on the SCU clock mode. Note: Available range depends on the SCU clock mode.
(Use channel 1 only) Sampling frequency = SCU32K / 2 ^ n [Hz]
SCU32K : 11 to 15 SCU32K : 11 to 15
RCOSC : 3 to 15 RCOSC : 3 to 15
XOSC : 2 to 15 XOSC : 2 to 15
(Use channel 0/1) Sampling frequency = SCU32K / 2 ^ (n+1) [Hz]
SCU32K : 12 to 15
RCOSC : 6 to 15
XOSC : 6 to 15
(Use all of channels) Sampling frequency = SCU32K / 2 ^ (n+2) [Hz]
SCU32K : 11 to 15
RCOSC : 7 to 15
XOSC : 7 to 15
config CXD56_LPADC1_OFFSET config CXD56_LPADC1_OFFSET
int "Offset" int "Offset"
default 0 default 0
@ -770,235 +816,29 @@ config CXD56_LPADC1_FSIZE
endmenu # CXD56_LPADC1 endmenu # CXD56_LPADC1
menu "LADC2" menu "LPADC2"
depends on CXD56_LPADC2 depends on CXD56_LPADC2 || CXD56_LPADC_ALL
config CXD56_LPADC2_FREQ config CXD56_LPADC2_FREQ
int "Coefficient of sampling frequency" int "Coefficient of sampling frequency"
default 12 default 12
range 11 15 if CXD56_SCU_32K range 11 15 if CXD56_SCU_32K && CXD56_LPADC2
range 3 15 if CXD56_SCU_RCOSC range 3 15 if CXD56_SCU_RCOSC && CXD56_LPADC2
range 2 15 if CXD56_SCU_XOSC range 2 15 if CXD56_SCU_XOSC && CXD56_LPADC2
range 11 15 if CXD56_SCU_32K && CXD56_LPADC_ALL
range 7 15 if CXD56_SCU_RCOSC && CXD56_LPADC_ALL
range 7 15 if CXD56_SCU_XOSC && CXD56_LPADC_ALL
---help--- ---help---
This configuration set to sampling frequency calculated by the following formula. This configuration set to sampling frequency calculated by the following formula.
Sampling frequency = SCU32K / 2 ^ n [Hz]
Note. Setable range depends on the SCU clock mode. Note: Available range depends on the SCU clock mode.
(Use channel 2 only) Sampling frequency = SCU32K / 2 ^ n [Hz]
SCU32K : 11 to 15 SCU32K : 11 to 15
RCOSC : 3 to 15 RCOSC : 3 to 15
XOSC : 2 to 15 XOSC : 2 to 15
config CXD56_LPADC2_OFFSET (Use all of channels) Sampling frequency = SCU32K / 2 ^ (n+2) [Hz]
int "Offset"
default 0
range 0 65535
config CXD56_LPADC2_GAIN
int "Gain"
default 0
range 0 65535
config CXD56_LPADC2_FSIZE
int "SCU FIFO size"
default 16
range 2 40960
---help---
SCU FIFO size
endmenu # CXD56_LPADC2
menu "LADC3"
depends on CXD56_LPADC3
config CXD56_LPADC3_FREQ
int "Coefficient of sampling frequency"
default 12
range 11 15 if CXD56_SCU_32K
range 3 15 if CXD56_SCU_RCOSC
range 2 15 if CXD56_SCU_XOSC
---help---
This configuration set to sampling frequency calculated by the following formula.
Sampling frequency = SCU32K / 2 ^ n [Hz]
Note. Setable range depends on the SCU clock mode.
SCU32K : 11 to 15
RCOSC : 3 to 15
XOSC : 2 to 15
config CXD56_LPADC3_OFFSET
int "Offset"
default 0
range 0 65535
config CXD56_LPADC3_GAIN
int "Gain"
default 0
range 0 65535
config CXD56_LPADC3_FSIZE
int "SCU FIFO size"
default 16
range 2 40960
---help---
SCU FIFO size
endmenu # CXD56_LPADC3
menu "LADC0"
depends on CXD56_LPADC0_1
config CXD56_LPADC0_FREQ
int "Coefficient of sampling frequency"
default 12
range 12 15 if CXD56_SCU_32K
range 6 15 if CXD56_SCU_RCOSC
range 6 15 if CXD56_SCU_XOSC
---help---
This configuration set to sampling frequency calculated by the following formula.
Sampling frequency = SCU32K / 2 ^ (n+1) [Hz]
Note. Setable range depends on the SCU clock mode.
SCU32K : 12 to 15
RCOSC : 6 to 15
XOSC : 6 to 15
config CXD56_LPADC0_OFFSET
int "Offset"
default 0
range 0 65535
config CXD56_LPADC0_GAIN
int "Gain"
default 0
range 0 65535
config CXD56_LPADC0_FSIZE
int "SCU FIFO size"
default 16
range 2 40960
---help---
SCU FIFO size
endmenu # CXD56_LPADC0_1
menu "LADC1"
depends on CXD56_LPADC0_1
config CXD56_LPADC1_FREQ
int "Coefficient of sampling frequency"
default 12
range 12 15 if CXD56_SCU_32K
range 6 15 if CXD56_SCU_RCOSC
range 6 15 if CXD56_SCU_XOSC
---help---
This configuration set to sampling frequency calculated by the following formula.
Sampling frequency = SCU32K / 2 ^ (n+1) [Hz]
Note. Setable range depends on the SCU clock mode.
SCU32K : 12 to 15
RCOSC : 6 to 15
XOSC : 6 to 15
config CXD56_LPADC1_OFFSET
int "Offset"
default 0
range 0 65535
config CXD56_LPADC1_GAIN
int "Gain"
default 0
range 0 65535
config CXD56_LPADC1_FSIZE
int "SCU FIFO size"
default 16
range 2 40960
---help---
SCU FIFO size
endmenu # CXD56_LPADC0_1
menu "LADC0"
depends on CXD56_LPADC_ALL
config CXD56_LPADC0_FREQ
int "Coefficient of sampling frequency"
default 12
range 11 15 if CXD56_SCU_32K
range 7 15 if CXD56_SCU_RCOSC
range 7 15 if CXD56_SCU_XOSC
---help---
This configuration set to sampling frequency calculated by the following formula.
Sampling frequency = SCU32K / 2 ^ (n+2) [Hz]
Note. Setable range depends on the SCU clock mode.
SCU32K : 11 to 15
RCOSC : 7 to 15
XOSC : 7 to 15
config CXD56_LPADC0_OFFSET
int "Offset"
default 0
range 0 65535
config CXD56_LPADC0_GAIN
int "Gain"
default 0
range 0 65535
config CXD56_LPADC0_FSIZE
int "SCU FIFO size"
default 16
range 2 40960
---help---
SCU FIFO size
endmenu # CXD56_LPADC_ALL
menu "LADC1"
depends on CXD56_LPADC_ALL
config CXD56_LPADC1_FREQ
int "Coefficient of sampling frequency"
default 12
range 11 15 if CXD56_SCU_32K
range 7 15 if CXD56_SCU_RCOSC
range 7 15 if CXD56_SCU_XOSC
---help---
This configuration set to sampling frequency calculated by the following formula.
Sampling frequency = SCU32K / 2 ^ (n+2) [Hz]
Note. Setable range depends on the SCU clock mode.
SCU32K : 11 to 15
RCOSC : 7 to 15
XOSC : 7 to 15
config CXD56_LPADC1_OFFSET
int "Offset"
default 0
range 0 65535
config CXD56_LPADC1_GAIN
int "Gain"
default 0
range 0 65535
config CXD56_LPADC1_FSIZE
int "SCU FIFO size"
default 16
range 2 40960
---help---
SCU FIFO size
endmenu # CXD56_LPADC_ALL
menu "LADC2"
depends on CXD56_LPADC_ALL
config CXD56_LPADC2_FREQ
int "Coefficient of sampling frequency"
default 12
range 11 15 if CXD56_SCU_32K
range 7 15 if CXD56_SCU_RCOSC
range 7 15 if CXD56_SCU_XOSC
---help---
This configuration set to sampling frequency calculated by the following formula.
Sampling frequency = SCU32K / 2 ^ (n+2) [Hz]
Note. Setable range depends on the SCU clock mode.
SCU32K : 11 to 15 SCU32K : 11 to 15
RCOSC : 7 to 15 RCOSC : 7 to 15
XOSC : 7 to 15 XOSC : 7 to 15
@ -1020,21 +860,31 @@ config CXD56_LPADC2_FSIZE
---help--- ---help---
SCU FIFO size SCU FIFO size
endmenu # CXD56_LPADC_ALL endmenu # CXD56_LPADC2
menu "LADC3" menu "LPADC3"
depends on CXD56_LPADC_ALL depends on CXD56_LPADC3 || CXD56_LPADC_ALL
config CXD56_LPADC3_FREQ config CXD56_LPADC3_FREQ
int "Coefficient of sampling frequency" int "Coefficient of sampling frequency"
default 12 default 12
range 11 15 if CXD56_SCU_32K range 11 15 if CXD56_SCU_32K && CXD56_LPADC3
range 7 15 if CXD56_SCU_RCOSC range 3 15 if CXD56_SCU_RCOSC && CXD56_LPADC3
range 7 15 if CXD56_SCU_XOSC range 2 15 if CXD56_SCU_XOSC && CXD56_LPADC3
range 11 15 if CXD56_SCU_32K && CXD56_LPADC_ALL
range 7 15 if CXD56_SCU_RCOSC && CXD56_LPADC_ALL
range 7 15 if CXD56_SCU_XOSC && CXD56_LPADC_ALL
---help--- ---help---
This configuration set to sampling frequency calculated by the following formula. This configuration set to sampling frequency calculated by the following formula.
Sampling frequency = SCU32K / 2 ^ (n+2) [Hz]
Note. Setable range depends on the SCU clock mode. Note: Available range depends on the SCU clock mode.
(Use channel 3 only) Sampling frequency = SCU32K / 2 ^ n [Hz]
SCU32K : 11 to 15
RCOSC : 3 to 15
XOSC : 2 to 15
(Use all of channels) Sampling frequency = SCU32K / 2 ^ (n+2) [Hz]
SCU32K : 11 to 15 SCU32K : 11 to 15
RCOSC : 7 to 15 RCOSC : 7 to 15
XOSC : 7 to 15 XOSC : 7 to 15
@ -1056,12 +906,11 @@ config CXD56_LPADC3_FSIZE
---help--- ---help---
SCU FIFO size SCU FIFO size
endmenu # CXD56_LPADC_ALL endmenu # CXD56_LPADC3
endif # CXD56_LPADC endif # CXD56_LPADC
endif # CXD56_ADC endif # CXD56_ADC
menuconfig CXD56_SCU menuconfig CXD56_SCU
bool "Sensor Control Unit (SCU)" bool "Sensor Control Unit (SCU)"
default y default y

View File

@ -75,7 +75,7 @@ struct cfpushdata_s
static int cpufifo_txhandler(int irq, FAR void *context, FAR void *arg); static int cpufifo_txhandler(int irq, FAR void *context, FAR void *arg);
static int cpufifo_rxhandler(int irq, FAR void *context, FAR void *arg); static int cpufifo_rxhandler(int irq, FAR void *context, FAR void *arg);
static int cpufifo_trypush(uint32_t data[2]); static int cpufifo_trypush(uint32_t data[2]);
static void cpufifo_reserve(uint32_t data[2]); static int cpufifo_reserve(uint32_t data[2]);
/**************************************************************************** /****************************************************************************
* Private Data * Private Data
@ -148,21 +148,25 @@ static int cpufifo_trypush(uint32_t data[2])
return OK; return OK;
} }
static void cpufifo_reserve(uint32_t data[2]) static int cpufifo_reserve(uint32_t data[2])
{ {
FAR struct cfpushdata_s *pd; FAR struct cfpushdata_s *pd;
pd = (FAR struct cfpushdata_s *)sq_remfirst(&g_emptyqueue); pd = (FAR struct cfpushdata_s *)sq_remfirst(&g_emptyqueue);
/* This assertion indicate that need more sending buffer, it can be /* This error indicates that need more sending buffer, it can be
* configured by CONFIG_CXD56_CPUFIFO_ENTRIES. * configured by CONFIG_CXD56_CPUFIFO_ENTRIES.
*/ */
ASSERT(pd); if (!pd)
{
return -EAGAIN;
}
pd->data[0] = data[0]; pd->data[0] = data[0];
pd->data[1] = data[1]; pd->data[1] = data[1];
sq_addlast(&pd->entry, &g_pushqueue); sq_addlast(&pd->entry, &g_pushqueue);
return OK;
} }
/**************************************************************************** /****************************************************************************
@ -177,8 +181,8 @@ int cxd56_cfpush(uint32_t data[2])
flags = enter_critical_section(); flags = enter_critical_section();
if (!sq_empty(&g_pushqueue)) if (!sq_empty(&g_pushqueue))
{ {
cpufifo_reserve(data); ret = cpufifo_reserve(data);
return OK; return ret;
} }
ret = cpufifo_trypush(data); ret = cpufifo_trypush(data);

View File

@ -36,6 +36,6 @@
#ifndef __ARCH_ARM_SRC_CXD56XX_CXD56_FARAPISTUB_H #ifndef __ARCH_ARM_SRC_CXD56XX_CXD56_FARAPISTUB_H
#define __ARCH_ARM_SRC_CXD56XX_CXD56_FARAPISTUB_H #define __ARCH_ARM_SRC_CXD56XX_CXD56_FARAPISTUB_H
#define FARAPISTUB_VERSION 17639 #define FARAPISTUB_VERSION 17660
#endif /* __ARCH_ARM_SRC_CXD56XX_CXD56_FARAPISTUB_H */ #endif /* __ARCH_ARM_SRC_CXD56XX_CXD56_FARAPISTUB_H */

View File

@ -283,25 +283,20 @@ static void cxd56_i2c_setfrequency(struct cxd56_i2cdev_s *priv,
base /= 1000; base /= 1000;
switch (frequency) if (frequency <= 100000)
{ {
case 100000: tLow = 4700000;
tLow = 4700000; tHigh = 4000000;
tHigh = 4000000; }
break; else if (frequency <= 400000)
{
case 400000: tLow = 1300000;
tLow = 1300000; tHigh = 600000;
tHigh = 600000; }
break; else
{
case 1000000: tLow = 500000;
tLow = 500000; tHigh = 260000;
tHigh = 260000;
break;
default:
return;
} }
if (frequency > 100000) if (frequency > 100000)

View File

@ -234,7 +234,7 @@ static int icc_irqhandler(int cpuid, uint32_t word[2])
if (!req) if (!req)
{ {
iccerr("Receive buffer is full.\n"); iccerr("Receive buffer is full.\n");
return -ENOMEM; PANIC();
} }
req->word[0] = word[0]; req->word[0] = word[0];

View File

@ -344,8 +344,7 @@ struct cxd56_sdhcregs_s
uint32_t htcapblt; /* Host Controller Capabilities */ uint32_t htcapblt; /* Host Controller Capabilities */
uint32_t admaes; /* ADMA Error Status Register */ uint32_t admaes; /* ADMA Error Status Register */
uint32_t adsaddr; /* ADMA System Address Register */ uint32_t adsaddr; /* ADMA System Address Register */
uint32_t vendor; /* Vendor Specific Register */ uint32_t vendspec; /* Vendor Specific Register */
uint32_t hostver; /* Host Controller Version */
}; };
#endif #endif
@ -697,8 +696,7 @@ static void cxd56_sdhcsample(struct cxd56_sdhcregs_s *regs)
regs->htcapblt = getreg32(CXD56_SDHCI_HTCAPBLT); /* Host Controller Capabilities */ regs->htcapblt = getreg32(CXD56_SDHCI_HTCAPBLT); /* Host Controller Capabilities */
regs->admaes = getreg32(CXD56_SDHCI_ADMAES); /* ADMA Error Status Register */ regs->admaes = getreg32(CXD56_SDHCI_ADMAES); /* ADMA Error Status Register */
regs->adsaddr = getreg32(CXD56_SDHCI_ADSADDR); /* ADMA System Address Register */ regs->adsaddr = getreg32(CXD56_SDHCI_ADSADDR); /* ADMA System Address Register */
regs->vendor = getreg32(CXD56_SDHCI_VENDOR); /* Vendor Specific Register */ regs->vendspec = getreg32(CXD56_SDHCI_VENDSPEC); /* Vendor Specific Register */
regs->hostver = getreg32(CXD56_SDHCI_HOSTVER); /* Host Controller Version */
} }
#endif #endif
@ -748,7 +746,7 @@ static void cxd56_dumpsample(struct cxd56_sdiodev_s *priv,
mcinfo(" HTCAPBLT[%08x]: %08x\n", CXD56_SDHCI_HTCAPBLT, regs->htcapblt); mcinfo(" HTCAPBLT[%08x]: %08x\n", CXD56_SDHCI_HTCAPBLT, regs->htcapblt);
mcinfo(" ADMAES[%08x]: %08x\n", CXD56_SDHCI_ADMAES, regs->admaes); mcinfo(" ADMAES[%08x]: %08x\n", CXD56_SDHCI_ADMAES, regs->admaes);
mcinfo(" ADSADDR[%08x]: %08x\n", CXD56_SDHCI_ADSADDR, regs->adsaddr); mcinfo(" ADSADDR[%08x]: %08x\n", CXD56_SDHCI_ADSADDR, regs->adsaddr);
mcinfo(" HOSTVER[%08x]: %08x\n", CXD56_SDHCI_HOSTVER, regs->hostver); mcinfo(" VENDSPEC[%08x]: %08x\n", CXD56_SDHCI_VENDSPEC, regs->hostver);
} }
#endif #endif
@ -1285,6 +1283,16 @@ static int cxd56_interrupt(int irq, FAR void *context, FAR void *arg)
} }
#endif /* CONFIG_CXD56_SDIO_ENABLE_MULTIFUNCTION */ #endif /* CONFIG_CXD56_SDIO_ENABLE_MULTIFUNCTION */
/* Handle error interrupts ************************************************/
if ((getreg32(CXD56_SDHCI_IRQSTAT) & SDHCI_INT_EINT) != 0)
{
/* Clear error interrupts */
mcerr("ERROR: Occur error interrupts: %08x\n", enabled);
putreg32(enabled & SDHCI_EINT_MASK, CXD56_SDHCI_IRQSTAT);
}
/* Handle wait events *****************************************************/ /* Handle wait events *****************************************************/
pending = enabled & priv->waitints; pending = enabled & priv->waitints;
@ -1342,11 +1350,17 @@ static int cxd56_interrupt(int irq, FAR void *context, FAR void *arg)
#ifdef CONFIG_SDIO_MUXBUS #ifdef CONFIG_SDIO_MUXBUS
static int cxd56_sdio_lock(FAR struct sdio_dev_s *dev, bool lock) static int cxd56_sdio_lock(FAR struct sdio_dev_s *dev, bool lock)
{ {
/* Single SDIO instance so there is only one possibility. The multiplex /* Enable SD clock only while accessing to the SDIO. */
* bus is part of board support package.
*/ if (lock)
{
modifyreg32(CXD56_SDHCI_SYSCTL, 0, SDHCI_SYSCTL_SDCLKEN);
}
else
{
modifyreg32(CXD56_SDHCI_SYSCTL, SDHCI_SYSCTL_SDCLKEN, 0);
}
cxd56_muxbus_sdio_lock(lock);
return OK; return OK;
} }
#endif #endif
@ -1411,6 +1425,22 @@ static void cxd56_sdio_sdhci_reset(FAR struct sdio_dev_s *dev)
getreg32(CXD56_SDHCI_SYSCTL), getreg32(CXD56_SDHCI_PRSSTAT), getreg32(CXD56_SDHCI_SYSCTL), getreg32(CXD56_SDHCI_PRSSTAT),
getreg32(CXD56_SDHCI_IRQSTATEN)); getreg32(CXD56_SDHCI_IRQSTATEN));
/* Initialize the SDHC slot structure data structure */
/* Initialize semaphores */
sem_init(&priv->waitsem, 0, 0);
/* The waitsem semaphore is used for signaling and, hence, should not have
* priority inheritance enabled.
*/
sem_setprotocol(&priv->waitsem, SEM_PRIO_NONE);
/* Create a watchdog timer */
priv->waitwdog = wd_create();
DEBUGASSERT(priv->waitwdog);
/* The next phase of the hardware reset would be to set the SYSCTRL INITA /* The next phase of the hardware reset would be to set the SYSCTRL INITA
* bit to send 80 clock ticks for card to power up and then reset the card * bit to send 80 clock ticks for card to power up and then reset the card
* with CMD0. This is done elsewhere. * with CMD0. This is done elsewhere.
@ -1418,10 +1448,6 @@ static void cxd56_sdio_sdhci_reset(FAR struct sdio_dev_s *dev)
/* Reset state data */ /* Reset state data */
sem_init(&priv->waitsem, 0, 1);
priv->waitwdog = wd_create();
DEBUGASSERT(priv->waitwdog);
sem_init(&priv->waitsem, 0, 1);
priv->waitevents = 0; /* Set of events to be waited for */ priv->waitevents = 0; /* Set of events to be waited for */
priv->waitints = 0; /* Interrupt enables for event waiting */ priv->waitints = 0; /* Interrupt enables for event waiting */
priv->wkupevent = 0; /* The event that caused the wakeup */ priv->wkupevent = 0; /* The event that caused the wakeup */

View File

@ -82,7 +82,6 @@ extern "C"
#define CXD56_SDHCI_FEVT_OFFSET (0x0050) /* Force Event Register */ #define CXD56_SDHCI_FEVT_OFFSET (0x0050) /* Force Event Register */
#define CXD56_SDHCI_ADMAES_OFFSET (0x0054) /* ADMA Error Status Register */ #define CXD56_SDHCI_ADMAES_OFFSET (0x0054) /* ADMA Error Status Register */
#define CXD56_SDHCI_ADSADDR_OFFSET (0x0058) /* ADMA System Address Register */ #define CXD56_SDHCI_ADSADDR_OFFSET (0x0058) /* ADMA System Address Register */
#define CXD56_SDHCI_HOSTVER_OFFSET (0x00fc) /* Host Controller Version */
#define CXD56_SDHCI_VENDSPEC_OFFSET (0x0110) /* Vender Specific Control */ #define CXD56_SDHCI_VENDSPEC_OFFSET (0x0110) /* Vender Specific Control */
#define CXD56_SDHCI_OTHERIOLL_OFFSET (0x021C) /* IO Pin Control */ #define CXD56_SDHCI_OTHERIOLL_OFFSET (0x021C) /* IO Pin Control */
#define CXD56_SDHCI_USERDEF1CTL_OFFSET (0x0270) /* User Define1 Control Register */ #define CXD56_SDHCI_USERDEF1CTL_OFFSET (0x0270) /* User Define1 Control Register */
@ -112,7 +111,6 @@ extern "C"
#define CXD56_SDHCI_FEVT (CXD56_SDHCI_BASE+CXD56_SDHCI_FEVT_OFFSET) #define CXD56_SDHCI_FEVT (CXD56_SDHCI_BASE+CXD56_SDHCI_FEVT_OFFSET)
#define CXD56_SDHCI_ADMAES (CXD56_SDHCI_BASE+CXD56_SDHCI_ADMAES_OFFSET) #define CXD56_SDHCI_ADMAES (CXD56_SDHCI_BASE+CXD56_SDHCI_ADMAES_OFFSET)
#define CXD56_SDHCI_ADSADDR (CXD56_SDHCI_BASE+CXD56_SDHCI_ADSADDR_OFFSET) #define CXD56_SDHCI_ADSADDR (CXD56_SDHCI_BASE+CXD56_SDHCI_ADSADDR_OFFSET)
#define CXD56_SDHCI_HOSTVER (CXD56_SDHCI_BASE+CXD56_SDHCI_HOSTVER_OFFSET)
#define CXD56_SDHCI_VENDSPEC (CXD56_SDHCI_BASE+CXD56_SDHCI_VENDSPEC_OFFSET) #define CXD56_SDHCI_VENDSPEC (CXD56_SDHCI_BASE+CXD56_SDHCI_VENDSPEC_OFFSET)
#define CXD56_SDHCI_OTHERIOLL (CXD56_SDHCI_BASE+CXD56_SDHCI_OTHERIOLL_OFFSET) #define CXD56_SDHCI_OTHERIOLL (CXD56_SDHCI_BASE+CXD56_SDHCI_OTHERIOLL_OFFSET)
#define CXD56_SDHCI_USERDEF1CTL (CXD56_SDHCI_BASE+CXD56_SDHCI_USERDEF1CTL_OFFSET) #define CXD56_SDHCI_USERDEF1CTL (CXD56_SDHCI_BASE+CXD56_SDHCI_USERDEF1CTL_OFFSET)
@ -261,8 +259,9 @@ extern "C"
#define SDHCI_INT_CINS (1 << 6) /* Bit 6: Card Insertion */ #define SDHCI_INT_CINS (1 << 6) /* Bit 6: Card Insertion */
#define SDHCI_INT_CRM (1 << 7) /* Bit 7: Card Removal */ #define SDHCI_INT_CRM (1 << 7) /* Bit 7: Card Removal */
#define SDHCI_INT_CINT (1 << 8) /* Bit 8: Card Interrupt */ #define SDHCI_INT_CINT (1 << 8) /* Bit 8: Card Interrupt */
/* Bits 9-15: Reserved */ /* Bits 9-14: Reserved */
#define SDHCI_INT_EINT (1 << 15) /* Bit 15: Error Interrupt */
#define SDHCI_INT_CTOE (1 << 16) /* Bit 16: Command Timeout Error */ #define SDHCI_INT_CTOE (1 << 16) /* Bit 16: Command Timeout Error */
#define SDHCI_INT_CCE (1 << 17) /* Bit 17: Command CRC Error */ #define SDHCI_INT_CCE (1 << 17) /* Bit 17: Command CRC Error */
#define SDHCI_INT_CEBE (1 << 18) /* Bit 18: Command End Bit Error */ #define SDHCI_INT_CEBE (1 << 18) /* Bit 18: Command End Bit Error */
@ -278,6 +277,7 @@ extern "C"
#define SDHCI_INT_DMAE (1 << 28) /* Bit 28: DMA Error */ #define SDHCI_INT_DMAE (1 << 28) /* Bit 28: DMA Error */
/* Bits 29-31: Reserved */ /* Bits 29-31: Reserved */
#define SDHCI_EINT_MASK 0xffff0000
#define SDHCI_INT_ALL 0x117f01ff #define SDHCI_INT_ALL 0x117f01ff
/* Auto CMD12 Error Status Register */ /* Auto CMD12 Error Status Register */

View File

@ -70,7 +70,7 @@
****************************************************************************/ ****************************************************************************/
static sem_t g_ltsem = SEM_INITIALIZER(1); static sem_t g_ltsem = SEM_INITIALIZER(1);
static bool g_used_lna = true; static bool g_used_lna = false;
static bool g_used_tcxo = true; static bool g_used_tcxo = true;
#ifdef CONFIG_BOARDCTL_RESET #ifdef CONFIG_BOARDCTL_RESET
static struct pm_cpu_freqlock_s g_hv_lock = static struct pm_cpu_freqlock_s g_hv_lock =

View File

@ -336,15 +336,13 @@ int board_sdcard_initialize(void)
{ {
int ret = OK; int ret = OK;
cxd56_gpio_config(SDCARD_TXS02612_SEL, false);
#ifdef CONFIG_SDCARD_TXS02612_PORT0 #ifdef CONFIG_SDCARD_TXS02612_PORT0
/* Select port0 for SD-Card */ /* Select port0 for SD-Card (default) */
cxd56_gpio_write(SDCARD_TXS02612_SEL, false);
#else #else
/* Select port1 for SDIO other than SD-Card */ /* Select port1 for SDIO other than SD-Card */
cxd56_gpio_config(SDCARD_TXS02612_SEL, false);
cxd56_gpio_write(SDCARD_TXS02612_SEL, true); cxd56_gpio_write(SDCARD_TXS02612_SEL, true);
#endif #endif