Add support for CAN1 and CAN2 to zkit-arm-1769. From M. Kannan
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@5808 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
0bfa1b75e2
commit
83c4c55b12
@ -4484,3 +4484,6 @@
|
||||
sleep mode (2013-03-31).
|
||||
* arch/arm/src/stm32: Add architecure support for the STM32 F427/F437
|
||||
chips. Contributed by Mike Smith (2014-4-01).
|
||||
* configs/zkit-arm-1769/src/up_can.c: Add support for both CAN1
|
||||
and CAN2. Contributed by M.Kannan (2014-4-01).
|
||||
|
||||
|
@ -8,7 +8,7 @@
|
||||
<tr align="center" bgcolor="#e4e4e4">
|
||||
<td>
|
||||
<h1><big><font color="#3c34ec"><i>NuttX RTOS</i></font></big></h1>
|
||||
<p>Last Updated: March 15, 2013</p>
|
||||
<p>Last Updated: April 1, 2013</p>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
@ -2418,8 +2418,10 @@ nsh>
|
||||
<ul>
|
||||
<b>STATUS:</b>
|
||||
This is still a work in progess.
|
||||
At present there is a working basic port with OS verification and Nuttshell (<a href="http://www.nuttx.org/Documentation/NuttShell.html">NSH</a>) configurations.
|
||||
This is stablilizing nicely now and the next steps will involve getting solid driver support for the SD slot and the LCD on the WaveShare board.
|
||||
At present there is a working basic port with OS verification, Nuttshell (<a href="http://www.nuttx.org/Documentation/NuttShell.html">NSH</a>) configurations, and a graphics test configuration.
|
||||
The NSH configuration includes verfied support for (DMA-based) SD card interface.
|
||||
SDRAM is working.
|
||||
The LCD driver is not functional as of this writing, but is actively underwork and is expected to be available in the NuttX-6.27 release.
|
||||
</ul>
|
||||
</td>
|
||||
</tr>
|
||||
@ -2548,6 +2550,25 @@ nsh>
|
||||
<td><br></td>
|
||||
<td><hr></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><br></td>
|
||||
<td>
|
||||
<p>
|
||||
<b>STMicro STM32 F427/437</b>.
|
||||
General architectural support was provided for the F427/437 family in NuttX 4.27.
|
||||
Specific support includes the STM32F427I, STM32F427Z, and STM32F427V chips.
|
||||
This is <i>architecture-only</i> support, meaning that support for the boards with these chips is available, but not support for any publically available boards is included..
|
||||
This support was contributed by Mike Smith.
|
||||
</p>
|
||||
<p>
|
||||
The F427/f37 port adds (1) additional SPI ports, (2) additional UART ports, (3) analog and digital noise filters on the I2C ports, (4) up to 2MB of flash, (5) an additional lower-power mode for the internal voltage regulator, (6) a new prescaling option for timer clock, (7) a larger FSMSC write FIFO, and (8) additional crypto modes (F437 only).
|
||||
</p>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><br></td>
|
||||
<td><hr></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><br></td>
|
||||
<td>
|
||||
|
@ -67,10 +67,10 @@
|
||||
#define GPIO_UART0_RXD (GPIO_ALT1 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN3)
|
||||
#define GPIO_AD0p6 (GPIO_ALT2 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN3)
|
||||
#define GPIO_I2S_RXCLK_1 (GPIO_ALT1 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN4)
|
||||
#define GPIO_CAN2_RD (GPIO_ALT2 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN4)
|
||||
#define GPIO_CAN2_RD_1 (GPIO_ALT2 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN4)
|
||||
#define GPIO_CAP2p0 (GPIO_ALT3 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN4)
|
||||
#define GPIO_I2S_RXWS_1 (GPIO_ALT1 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN5)
|
||||
#define GPIO_CAN2_TD (GPIO_ALT2 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN5)
|
||||
#define GPIO_CAN2_TD_1 (GPIO_ALT2 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN5)
|
||||
#define GPIO_CAP2p1 (GPIO_ALT3 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN5)
|
||||
#define GPIO_I2S_RXSDA_1 (GPIO_ALT1 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN6)
|
||||
#define GPIO_SSP1_SSEL (GPIO_ALT2 | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN6)
|
||||
|
@ -231,6 +231,8 @@
|
||||
|
||||
#define GPIO_CAN1_RD GPIO_CAN1_RD_1
|
||||
#define GPIO_CAN1_TD GPIO_CAN1_TD_1
|
||||
#define GPIO_CAN2_RD GPIO_CAN2_RD_2
|
||||
#define GPIO_CAN2_TD GPIO_CAN2_TD_2
|
||||
#define GPIO_I2C1_SDA GPIO_I2C0_SDA
|
||||
#define GPIO_I2C1_SCL GPIO_I2C0_SCL
|
||||
#define GPIO_SSP1_SCK GPIO_SSP1_SCK_1
|
||||
|
@ -63,21 +63,9 @@
|
||||
* Pre-processor Definitions
|
||||
************************************************************************************/
|
||||
/* Configuration ********************************************************************/
|
||||
#define CAN_PORT1 1
|
||||
#define CAN_PORT2 2
|
||||
|
||||
#if defined(CONFIG_LPC17_CAN1) && defined(CONFIG_LPC17_CAN2)
|
||||
# warning "Both CAN1 and CAN2 are enabled. Assuming only CAN1."
|
||||
# undef CONFIG_LPC17_CAN2
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_LPC17_CAN2
|
||||
# warning "CAN2 is not connected on the ZKIT-ARM-1769"
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_LPC17_CAN1
|
||||
# define CAN_PORT 1
|
||||
#else
|
||||
# define CAN_PORT 2
|
||||
#endif
|
||||
|
||||
/* Debug ***************************************************************************/
|
||||
/* Non-standard debug that may be enabled just for testing CAN */
|
||||
@ -121,23 +109,45 @@ int can_devinit(void)
|
||||
|
||||
if (!initialized)
|
||||
{
|
||||
/* Call lpc17_caninitialize() to get an instance of the CAN interface */
|
||||
#ifdef CONFIG_LPC17_CAN1
|
||||
/* Call lpc17_caninitialize() to get an instance of the CAN1 interface */
|
||||
|
||||
can = lpc17_caninitialize(CAN_PORT);
|
||||
can = lpc17_caninitialize(CAN_PORT1);
|
||||
if (can == NULL)
|
||||
{
|
||||
candbg("ERROR: Failed to get CAN interface\n");
|
||||
candbg("ERROR: Failed to get CAN1 interface\n");
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
/* Register the CAN driver at "/dev/can0" */
|
||||
/* Register the CAN1 driver at "/dev/can0" */
|
||||
|
||||
ret = can_register("/dev/can0", can);
|
||||
if (ret < 0)
|
||||
{
|
||||
candbg("ERROR: can_register failed: %d\n", ret);
|
||||
candbg("ERROR: CAN1 register failed: %d\n", ret);
|
||||
return ret;
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_LPC17_CAN2
|
||||
/* Call lpc17_caninitialize() to get an instance of the CAN2 interface */
|
||||
|
||||
can = lpc17_caninitialize(CAN_PORT2);
|
||||
if (can == NULL)
|
||||
{
|
||||
candbg("ERROR: Failed to get CAN2 interface\n");
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
/* Register the CAN2 driver at "/dev/can1" */
|
||||
|
||||
ret = can_register("/dev/can1", can);
|
||||
if (ret < 0)
|
||||
{
|
||||
candbg("ERROR: CAN2 register failed: %d\n", ret);
|
||||
return ret;
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Now we are initialized */
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user