mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-18 19:03:31 +08:00
[LPC4088] update CAN driver baudrate config.
This commit is contained in:
parent
b5736b4bff
commit
7254c41207
@ -32,19 +32,6 @@ struct lpccandata
|
||||
en_CAN_unitId id;
|
||||
};
|
||||
|
||||
static const rt_uint32_t LPCBAUDTAB[] =
|
||||
{
|
||||
1000000,
|
||||
800000,
|
||||
500000,
|
||||
250000,
|
||||
125000,
|
||||
100000,
|
||||
50000,
|
||||
20000,
|
||||
10000,
|
||||
};
|
||||
|
||||
static LPC_CAN_TypeDef* lcpcan_get_reg_base(rt_uint32_t id)
|
||||
{
|
||||
LPC_CAN_TypeDef* pCan;
|
||||
@ -84,7 +71,7 @@ static void lpccan_irqstate_init(rt_uint32_t id)
|
||||
pCan->MOD = 0;// Return Normal operating
|
||||
}
|
||||
|
||||
static void lpccan_baud_set(rt_uint32_t id, rt_uint32_t baud)
|
||||
static rt_err_t lpccan_baud_set(rt_uint32_t id, rt_uint32_t baud)
|
||||
{
|
||||
uint32_t result = 0;
|
||||
uint8_t NT, TSEG1, TSEG2;
|
||||
@ -93,7 +80,8 @@ static void lpccan_baud_set(rt_uint32_t id, rt_uint32_t baud)
|
||||
LPC_CAN_TypeDef* pCan = lcpcan_get_reg_base(id);
|
||||
|
||||
CANPclk = CLKPWR_GetCLK(CLKPWR_CLKTYPE_PER);
|
||||
result = CANPclk / LPCBAUDTAB[baud];
|
||||
result = CANPclk / baud;
|
||||
|
||||
/* Calculate suitable nominal time value
|
||||
* NT (nominal time) = (TSEG1 + TSEG2 + 3)
|
||||
* NT <= 24
|
||||
@ -101,7 +89,7 @@ static void lpccan_baud_set(rt_uint32_t id, rt_uint32_t baud)
|
||||
*/
|
||||
for(NT = 24; NT > 0; NT = NT-2)
|
||||
{
|
||||
if ((result%NT) == 0)
|
||||
if ((result % NT) == 0)
|
||||
{
|
||||
BRP = result / NT - 1;
|
||||
NT--;
|
||||
@ -110,6 +98,7 @@ static void lpccan_baud_set(rt_uint32_t id, rt_uint32_t baud)
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* Enter reset mode */
|
||||
pCan->MOD = 0x01;
|
||||
/* Set bit timing
|
||||
@ -119,6 +108,8 @@ static void lpccan_baud_set(rt_uint32_t id, rt_uint32_t baud)
|
||||
pCan->BTR = (TSEG2 << 20) | (TSEG1 << 16) | (3 << 14) | BRP;
|
||||
/* Return to normal operating */
|
||||
pCan->MOD = 0;
|
||||
|
||||
return RT_EOK;
|
||||
}
|
||||
|
||||
static void lpccan_init_alut_ram(void)
|
||||
@ -183,7 +174,7 @@ static void lpccan2_filter_init(struct rt_can_device *can)
|
||||
{
|
||||
}
|
||||
|
||||
static void lpccan2_hw_init(enum CANBAUD baud, CAN_MODE_Type mode)
|
||||
static void lpccan2_hw_init(uint32_t baud, CAN_MODE_Type mode)
|
||||
{
|
||||
if(mode != CAN_SELFTEST_MODE)
|
||||
{
|
||||
@ -539,8 +530,10 @@ static rt_err_t control(struct rt_can_device *can, int cmd, void *arg)
|
||||
struct lpccandata* plpccan;
|
||||
rt_uint32_t argval;
|
||||
CAN_MODE_Type mode;
|
||||
|
||||
plpccan = (struct lpccandata* ) can->parent.user_data;
|
||||
RT_ASSERT(plpccan != RT_NULL);
|
||||
|
||||
switch (cmd)
|
||||
{
|
||||
case RT_DEVICE_CTRL_CLR_INT:
|
||||
@ -561,6 +554,7 @@ static rt_err_t control(struct rt_can_device *can, int cmd, void *arg)
|
||||
CAN_IRQCmd(plpccan->id, CANINT_EIE, DISABLE);
|
||||
}
|
||||
break;
|
||||
|
||||
case RT_DEVICE_CTRL_SET_INT:
|
||||
argval = (rt_uint32_t) arg;
|
||||
if(argval == RT_DEVICE_FLAG_INT_RX)
|
||||
@ -579,8 +573,10 @@ static rt_err_t control(struct rt_can_device *can, int cmd, void *arg)
|
||||
CAN_IRQCmd(plpccan->id, CANINT_EIE, ENABLE);
|
||||
}
|
||||
break;
|
||||
|
||||
case RT_CAN_CMD_SET_FILTER:
|
||||
return setfilter(plpccan, (struct rt_can_filter_config*) arg);
|
||||
|
||||
case RT_CAN_CMD_SET_MODE:
|
||||
argval = (rt_uint32_t) arg;
|
||||
if(argval != RT_CAN_MODE_NORMAL ||
|
||||
@ -613,26 +609,16 @@ static rt_err_t control(struct rt_can_device *can, int cmd, void *arg)
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
case RT_CAN_CMD_SET_BAUD:
|
||||
argval = (rt_uint32_t) arg;
|
||||
if(argval != CAN1MBaud &&
|
||||
argval != CAN800kBaud &&
|
||||
argval != CAN500kBaud &&
|
||||
argval != CAN250kBaud &&
|
||||
argval != CAN125kBaud &&
|
||||
argval != CAN100kBaud &&
|
||||
argval != CAN50kBaud &&
|
||||
argval != CAN20kBaud &&
|
||||
argval != CAN10kBaud )
|
||||
{
|
||||
return RT_ERROR;
|
||||
}
|
||||
if(argval != can->config.baud_rate)
|
||||
{
|
||||
can->config.baud_rate = argval;
|
||||
lpccan_baud_set(plpccan->id, (rt_uint32_t) arg);
|
||||
return lpccan_baud_set(plpccan->id, (rt_uint32_t) arg);
|
||||
}
|
||||
break;
|
||||
|
||||
case RT_CAN_CMD_SET_PRIV:
|
||||
argval = (rt_uint32_t) arg;
|
||||
if(argval != RT_CAN_MODE_PRIV ||
|
||||
@ -646,6 +632,7 @@ static rt_err_t control(struct rt_can_device *can, int cmd, void *arg)
|
||||
CAN_ModeConfig(plpccan->id, CAN_TXPRIORITY_MODE, ENABLE);
|
||||
}
|
||||
break;
|
||||
|
||||
case RT_CAN_CMD_GET_STATUS:
|
||||
{
|
||||
can->status.rcverrcnt = 0;
|
||||
@ -657,6 +644,7 @@ static rt_err_t control(struct rt_can_device *can, int cmd, void *arg)
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
}
|
||||
return RT_EOK;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user