0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

MM32F0160的FlexCAN FD位時(shí)間采樣點(diǎn)如何計(jì)算?

靈動(dòng)MM32MCU ? 來源:靈動(dòng)MM32MCU ? 2023-11-09 17:43 ? 次閱讀

1?

FlexCAN簡介

FlexCAN模塊是一個(gè)通信控制器,擴(kuò)展了CAN FD功能,遵循ISO 11898-1標(biāo)準(zhǔn)、CAN FD和CAN 2.0B協(xié)議規(guī)范。 CAN協(xié)議主要被設(shè)計(jì)用作車載串行總線,滿足實(shí)時(shí)處理,帶寬要求,車輛在電磁干擾環(huán)境下的可靠操作,該模塊支持標(biāo)準(zhǔn)和擴(kuò)展幀,支持最大64字節(jié)有效負(fù)載,傳輸速率高達(dá) 8Mbps,并且具有非常靈活的用于傳輸和接收的郵箱系統(tǒng)和RxFIFO接收機(jī)制。郵箱系統(tǒng)由 32 個(gè)報(bào)文緩沖區(qū)(MB)組成。

2?

FlexCAN的功能框圖

FlexCAN 的功能框圖如下圖1所示,包括用于存儲(chǔ)報(bào)文緩沖區(qū)(MB)、接收全局掩碼寄存器、接收私有掩碼寄存器、接收(Rx) FIFO 過濾器以及接收 FIFO 標(biāo)識(shí)符過濾器的內(nèi)存。

deb1b9f0-7ee2-11ee-939d-92fbcf53809c.png

圖1 FlexCAN功能框圖

如上圖1所示為FlexCAN的功能框圖,協(xié)議引擎(PE)子模塊管理 CAN 總線上的串行通信:

請(qǐng)求存取 RAM 接收和傳輸幀

驗(yàn)收接收到的報(bào)文

進(jìn)行錯(cuò)誤處理

檢測 CAN FD 報(bào)文

控制器主機(jī)接口(CHI)子模塊負(fù)責(zé)選擇接收和傳輸?shù)膱?bào)文緩沖區(qū),以及對(duì)報(bào)文的仲裁和 ID 匹配算法。

總線接口單元(BIU)子模塊控制內(nèi)部接口總線的訪問,建立與 CPU 和其他模塊的連接。時(shí)鐘、地址和數(shù)據(jù)總線、中斷輸出、 DMA 都通過 BIU 進(jìn)行訪問。

3?

FlexCAN的時(shí)鐘

如下圖2所示為產(chǎn)生 PE 時(shí)鐘的電路結(jié)構(gòu)。時(shí)鐘源選擇位(CAN_CTRL1.CLKSRC)定義了內(nèi)部時(shí)鐘為異步時(shí)鐘或同步時(shí)鐘。其中,同步時(shí)鐘為外設(shè)時(shí)鐘(由APB1總線時(shí)鐘提供);異步時(shí)鐘的時(shí)鐘源可選(細(xì)節(jié)請(qǐng)參考 RCC 章節(jié) RCC_CFGR2寄存器)。為保證可靠運(yùn)行,應(yīng)在模塊禁止模式時(shí)(CAN_MCR.MDIS 置位)選擇時(shí)鐘源。

debca63a-7ee2-11ee-939d-92fbcf53809c.png

圖2 FlexCAN的PE時(shí)鐘結(jié)構(gòu)

4?

FlexCAN的協(xié)議時(shí)序

FlexCAN支持多種方式來設(shè)置 CAN 協(xié)議所要求的位時(shí)序參數(shù)??刂萍拇嫫?1(CAN_CTRL1)有各種用于控制位時(shí)序參數(shù)的字段: PRESDIV、 PROPSEG、 PSEG1、 PSEG2 和 RJW。 CAN 位時(shí)序寄存器(CAN_CBT)擴(kuò)展了 CAN_CTRL1 中 CAN 位時(shí)序變量的范圍。 CAN_FDCBT 提供了用于 BRS 置位的 CAN FD 幀數(shù)據(jù)段的位時(shí)序變量。

CAN FD 使能時(shí),應(yīng)始終置位 CAN_CBT.BTF 或 CAN_CTRL2.BTE,并在 CAN_CBT 中配置CAN 位時(shí)序變量。

PRESDIV字段(及其擴(kuò)展范圍 EPRESDIV 和用于 CAN FD 報(bào)文數(shù)據(jù)段的 FDPRESDIV)定義了

串行時(shí)鐘(Sclock)的預(yù)分頻(見下列方程)。串行時(shí)鐘的周期定義了用于構(gòu)成 CAN 波形的時(shí)間單位 Tq(Time Quantum)。 Tq 為 CAN 引擎所能處理的最小時(shí)間單元。

dec74874-7ee2-11ee-939d-92fbcf53809c.png

比特率定義了接收或傳輸 CAN 報(bào)文的速率,公式如下:

deeef2ac-7ee2-11ee-939d-92fbcf53809c.png

FlexCAN的位時(shí)間可細(xì)分為三個(gè)部分:

同步段(SYNC_SEG)

1Tq 的固定長度;信號(hào)邊沿出現(xiàn)在該段內(nèi)。

時(shí)間段 1

包括 CAN 標(biāo)準(zhǔn)的傳播段和相位段1。該段可通過設(shè)置 CAN_CTRL1 寄存器的PROPSEG和PSEG1 字段來編程,其總和(+2)為 2 ~ 16Tq。當(dāng) CAN_CBT.BTF 被置位時(shí),F(xiàn)lexCAN 使用來自 CAN_CBT 寄存器的EPROPSEG和EPSEG1 字段,其總和(+2)為 2~ 96Tq 。對(duì)于BRS置位的CAN FD報(bào)文,F(xiàn)lexCAN使用CAN_FDCBT寄存器的FDPROPSEG 和 FDPSEG1 字段,其總和為 2 ~ 39Tq。

時(shí)間段 2

CAN 標(biāo)準(zhǔn)的相位段2。該段可通過設(shè)置CAN_CTRL1寄存器的PSEG2字段來編程,其值(+1)為 2 ~ 8Tq。當(dāng)CAN_CBT.BTF被置位時(shí), FlexCAN使用來自CAN_CBT寄存器的EPSEG2字段,其值(+1)為 2 ~ 32Tq。對(duì)于BRS置位的 CAN FD 報(bào)文, FlexCAN使用CAN_FDCBT寄存器的FDPSEG2字段,其值(+1)為 2 ~ 8Tq。時(shí)間段2不能小于信息處理時(shí)間(IPT),IPT 在 FlexCAN 中為 2Tq。

注意事項(xiàng):

FPRESDIV 定義了 BRS 置位的 CAN FD 幀數(shù)據(jù)比特率部分的PE時(shí)鐘頻率和串行時(shí)鐘(Sclock)頻率之間的比率。 Sclock 周期定義了CAN FD協(xié)議數(shù)據(jù)比特率的 Tq。Sclock 頻率 = PE 時(shí)鐘頻率 /(FPRESDIV + 1)注:為避免處理FD幀時(shí)出錯(cuò), FPRESDIV 和PRESDIV(CAN_CBT 或 CAN_CTRL1)請(qǐng)使用相同的值。FPRESDIV 只能在凍結(jié)模式下寫入,其他模式下被硬件鎖定。

如下圖3所示為FlexCAN位時(shí)間內(nèi)的段使用 CAN_CTRL1位時(shí)序變量的經(jīng)典 CAN 格式。

df000a2e-7ee2-11ee-939d-92fbcf53809c.png

圖3

如下圖4所示為FlexCAN FD位時(shí)間內(nèi)的段,使用CAN FD格式的CAN_CBT和CAN_FDCBT位時(shí)序變量,其中FlexCAN FD的仲裁段使用經(jīng)典CAN格式配置位時(shí)間,即使用CAN_CBT位時(shí)序變量用于配置仲裁段的位時(shí)間,F(xiàn)lexCAN FD的可變速率的位時(shí)間使用CAN_FDCBT位時(shí)序變量配置。

df212dd0-7ee2-11ee-939d-92fbcf53809c.png

圖4

FlexCAN的語法說明如下表1所示:

df384f06-7ee2-11ee-939d-92fbcf53809c.png

表1

當(dāng)采用CAN位作為持續(xù)時(shí)間的衡量標(biāo)準(zhǔn)時(shí)(例如,評(píng)估報(bào)文中的CAN位事件),一個(gè) CAN 位的外設(shè)時(shí)鐘個(gè)數(shù)(NumClkBit)為:

df58991e-7ee2-11ee-939d-92fbcf53809c.png

其中:

NumClkBit 為一個(gè) CAN 位的外設(shè)時(shí)鐘個(gè)數(shù)

fSYS 為系統(tǒng)(CHI)時(shí)鐘頻率,單位 Hz

PSEG1 為 CAN_CTRL1.PSEG1 的值

PSEG2 為 CAN_CTRL1.PSEG2 的值

PROPSEG 為 CAN_CTRL1.PROPSEG 的值

PRESDIV 為 CAN_CTRL1.PRESDIV 的值

上述公式也適用于 CAN 位時(shí)序寄存器(CAN_CBT)所述的 CAN 位時(shí)間變量。

因此,F(xiàn)lexCAN FD仲裁段使用經(jīng)典CAN位的速率計(jì)算公式為:

df67495a-7ee2-11ee-939d-92fbcf53809c.png

FlexCAN FD可變速率數(shù)據(jù)段的計(jì)算公式為:

df7675e2-7ee2-11ee-939d-92fbcf53809c.png

fCANCLK為PE時(shí)鐘,單位Hz

BITRATEN是由CAN 標(biāo)稱位時(shí)間變量計(jì)算出的 CAN 位速率,單位bps

BITRATEF是由CAN 數(shù)據(jù)位時(shí)間變量計(jì)算出的CAN位速率,單位bps

EPSEG1為CAN_CBT.EPSEG1的值(也可使用 CAN_CTRL1.PSEG1)

EPSEG2 為 CAN_CBT.EPSEG2 的值(也可使用 CAN_CTRL1.PSEG2)

EPROPSEG 為CAN_CBT.EPROPSEG 的值(也可使用 CAN_CTRL1.PROPSEG)

EPRESDIV 為CAN_CBT.EPRESDIV 的值(也可使用 CAN_CTRL1.PRESDIV)

那么CAN FD幀標(biāo)稱比特率相應(yīng)的每個(gè)CAN位的外設(shè)時(shí)鐘數(shù)量CPCBN為:

df845964-7ee2-11ee-939d-92fbcf53809c.png

CAN FD 幀數(shù)據(jù)比特率相應(yīng)的每個(gè)CAN位的外設(shè)時(shí)鐘數(shù)量CPCBF為:

df943d16-7ee2-11ee-939d-92fbcf53809c.png

因此在已知FlexCAN FD時(shí)鐘和預(yù)分頻系數(shù)以及波特率的情況下可以計(jì)算出FlexCAN FD的標(biāo)稱位時(shí)間TqN總數(shù)和可變速率數(shù)據(jù)位時(shí)間TqF總數(shù),計(jì)算公式分別如下所示:

fcanclk / BITRATEN x (EPRESDIV+1) = [1+(EPSEG1+1)+(EPSEG2+1)+(EPROPSEG+1)]

fcanclk / BITRATEF x (FPRESDIV+1) = [1+(FPSEG1+1)+(FPSEG2+1)+FPROPSEG]

根據(jù)以上FlexCAN FD的位時(shí)序可知可以分別根據(jù)標(biāo)稱位時(shí)間TqN總數(shù)和可變速率數(shù)據(jù)位時(shí)間TqF總數(shù)分別計(jì)算出其標(biāo)稱位時(shí)間的采樣點(diǎn)和可變速率數(shù)據(jù)位時(shí)間的采樣點(diǎn),即FlexCAN FD標(biāo)稱位時(shí)間的采樣點(diǎn)的計(jì)算公式為:

FlexCAN_samplepoint = (SYNC_SEG+(EPROPSEG+1) +(EPSEG1+1) )/ (SYNC_SEG+(EPROPSEG+1) +(EPSEG1+1)+ (EPSEG2+1))

FlexCAN FD可變速率位時(shí)間的采樣點(diǎn)的計(jì)算公式為:

FlexCAN_FDsamplepoint = (SYNC_SEG+FPROPSEG+(FPSEG1+1) )/ (SYNC_SEG+FPROPSEG+(FPSEG1+1)+ (FPSEG2+1))

5?

FlexCAN FD位時(shí)間采樣點(diǎn)的計(jì)算

根據(jù)以上4章節(jié)FlexCAN的位時(shí)間描述以及FlexCAN FD位時(shí)間和采樣點(diǎn)的計(jì)算公式推導(dǎo),在給定FlexCAN FD時(shí)鐘和波特率以及分頻系數(shù)的情況下,可以使用FlexCAN的庫函數(shù)通過循環(huán)遍歷的方式實(shí)現(xiàn)自動(dòng)計(jì)算FlexCAN FD的位時(shí)間的采樣點(diǎn)。

FlexCAN FD庫函數(shù)定義的協(xié)議時(shí)序代碼如下所示:

typedefstruct_flexcan_timing_config{
u16preDivider;/*!

FlexCAN FD標(biāo)稱位時(shí)間采樣點(diǎn)和可變速率采樣點(diǎn)的位時(shí)間的計(jì)算,可以通過循環(huán)遍歷方式實(shí)現(xiàn)自動(dòng)計(jì)算,代碼如下所示:

boolFLEXCAN_FDCalculateImprovedTimingValues(uint32_tbaudRate,uint32_tbaudRateFD,uint32_tsourceClock_Hz,flexcan_timing_config_t*pTimingConfig)
{
boolfgRet=false;
pTimingConfig->preDivider=0U;
pTimingConfig->fpreDivider=0U;
if(FLEXCAN_CalculateImprovedTimingValuesByFDCBT(baudRateFD,sourceClock_Hz,pTimingConfig))
{
if(FLEXCAN_CalculateImprovedTimingValuesByCBT(baudRate,sourceClock_Hz,pTimingConfig))
{
fgRet=true;
}
}

return(fgRet);
}

staticboolFLEXCAN_CalculateImprovedTimingValuesByFDCBT(uint32_tbaudRate,uint32_tsourceClock_Hz,flexcan_timing_config_t*pTimingConfig)
{
uint32_tclk;/*theclockistqNumbxbaudRateFD.*/
uint32_ttqNum;/*NumbersofTQ.*/
boolfgRet=false;
tqNum=FDCBT_MAX_TIME_QUANTA;
/*AutoImprovedProtocaltiming.*/
do
{
clk=baudRate*tqNum;

if(clk>sourceClock_Hz)
{
continue;/*tqNumtoolarge,clkhasbeenexceedsourceClock_Hz.*/
}
if((sourceClock_Hz/clk*clk)!=sourceClock_Hz)
{
continue;/*Non-supporting:thefrequencyofclocksourceisnotdivisiblebytargetbaudrate,theuser
shouldchangeadivisiblebaudrate.*/
}
/*Makesurethenewcalculateddividervalueisgreaterthanthepreviousone.*/
if(pTimingConfig->fpreDivider>((uint16_t)(sourceClock_Hz/clk)-1U))
{
continue;
}
else
{
pTimingConfig->fpreDivider=(uint16_t)(sourceClock_Hz/clk)-1U;
}
if(pTimingConfig->fpreDivider>MAX_FPRESDIV)
{
break;/*Thefrequencyofsourceclockistoolargeorthebaudrateistoosmall,thepre-dividercould
nothandleit.*/
}
/*Trytogetthebesttimingconfiguration.*/
if(FLEXCAN_FDGetSegmentswithBRS(baudRate,tqNum,pTimingConfig))
{
fgRet=true;
break;
}
}
while(--tqNum>=FDCBT_MIN_TIME_QUANTA);

return(fgRet);
}

staticboolFLEXCAN_FDGetSegmentswithBRS(uint32_tbaudRatebrs,uint32_ttqNum,flexcan_timing_config_t*pTimingConfig)
{
uint32_tideal_sp;
uint32_tp1;
boolfgRet=false;

/*getidealsamplepoint.*/
if(baudRatebrs>=1000000U)
{
ideal_sp=IDEAL_SP_LOW;
}
elseif(baudRatebrs>=800000U)
{
ideal_sp=IDEAL_SP_MID;
}
else
{
ideal_sp=IDEAL_SP_HIGH;
}

/*distributetimequanta.*/
p1=tqNum*(uint32_t)ideal_sp;
pTimingConfig->fpropSeg=(uint8_t)(p1/(uint32_t)IDEAL_SP_FACTOR-2U);

if(pTimingConfig->fpropSeg<=?(MAX_FPSEG1?+?MAX_FPROPSEG))
????{
????????if?(pTimingConfig->fpropSeg>MAX_FPROPSEG)
{
pTimingConfig->fphaseSeg1=pTimingConfig->fpropSeg-MAX_FPROPSEG;
pTimingConfig->fpropSeg=MAX_FPROPSEG;
}
else
{
pTimingConfig->fphaseSeg1=0;
}

if(pTimingConfig->fphaseSeg1<=?MAX_PSEG1)
????????{
????????????if?((pTimingConfig->fpropSeg+pTimingConfig->fphaseSeg1)fphaseSeg2=(uint8_t)tqNum-(pTimingConfig->fphaseSeg1+pTimingConfig->fpropSeg+3U);

if(pTimingConfig->fphaseSeg2<=?MAX_PSEG2)
????????????????{
????????????????????if?((pTimingConfig->fphaseSeg1fphaseSeg2)&&(pTimingConfig->fpropSeg>(pTimingConfig->fphaseSeg2-pTimingConfig->fphaseSeg1)))
{
pTimingConfig->fpropSeg-=(pTimingConfig->fphaseSeg2-pTimingConfig->fphaseSeg1);
pTimingConfig->fphaseSeg1=pTimingConfig->fphaseSeg2;
}

/*subtractoneTQforsyncseg.*/
/*sjwis20%oftotalTQ,roundedtonearestint.*/
pTimingConfig->frJumpwidth=((uint8_t)tqNum+4U)/5U-1U;

if(pTimingConfig->frJumpwidth>MAX_FRJW)
{
pTimingConfig->frJumpwidth=MAX_FRJW;
}

fgRet=true;
}
}
}
}

return(fgRet);
}

staticboolFLEXCAN_CalculateImprovedTimingValuesByCBT(uint32_tbaudRate,uint32_tsourceClock_Hz,flexcan_timing_config_t*pTimingConfig)
{
uint32_tclk;/*theclockistqNumbxbaudRateFD.*/
uint32_ttqNum;/*NumbersofTQ.*/
boolfgRet=false;

tqNum=CBT_MAX_TIME_QUANTA;

/*AutoImprovedProtocaltiming.*/
do
{
clk=baudRate*tqNum;

if(clk>sourceClock_Hz)
{
continue;/*tqNumtoolarge,clkhasbeenexceedsourceClock_Hz.*/
}

if((sourceClock_Hz/clk*clk)!=sourceClock_Hz)
{
continue;/*Non-supporting:thefrequencyofclocksourceisnotdivisiblebytargetbaudrate,theuser
shouldchangeadivisiblebaudrate.*/
}

/*Makesurethenewcalculateddividervalueisgreaterthanthepreviousone.*/
if(pTimingConfig->preDivider>((uint16_t)(sourceClock_Hz/clk)-1U))
{
continue;
}
else
{
pTimingConfig->preDivider=(uint16_t)(sourceClock_Hz/clk)-1U;
}

/*TominimizeerrorswhenprocessingFDframes,trytocalculatethesamevalueforFPRESDIVandPRESDIV(inCBT).*/
if(pTimingConfig->preDivider!=pTimingConfig->fpreDivider)
{
continue;
}

if(pTimingConfig->preDivider>MAX_EPRESDIV)
{
break;/*Thefrequencyofsourceclockistoolargeorthebaudrateistoosmall,thepre-dividercould
nothandleit.*/
}

/*Trytogetthebesttimingconfiguration.*/
if(FLEXCAN_FDGetSegments(baudRate,tqNum,pTimingConfig))
{
fgRet=true;
break;
}
}
while(--tqNum>=CBT_MIN_TIME_QUANTA);

return(fgRet);
}

FlexCAN FD位時(shí)間采樣點(diǎn)應(yīng)用舉例,本文示例以MM32F0160的FlexCAN FD外設(shè)為例,其中FlexCAN FD的標(biāo)稱波特率為500K,可變速率波特率為2MHz。fCAN的時(shí)鐘為72MHz,把FlexCAN FD的fCAN時(shí)鐘,標(biāo)稱波特率500K,可變速率波特率2MHz代入庫函數(shù)FLEXCAN_FDCalculateImprovedTimingValues分別計(jì)算得出FlexCAN FD標(biāo)稱波特率和可變速率波特率的位時(shí)間參數(shù)如下:

標(biāo)稱波特率的位時(shí)間參數(shù):

preDivider = 0x01;

propSeg = 0x34;

phaseSeg1 = 0x08;

phaseSeg2 = 0x08;

rJumpwidth = 0x0E

可變速率波特率位時(shí)間參數(shù):

fpreDivider = 0x01;

fpropSeg = 0x07;

fphaseSeg1 = 0x04;

fphaseSeg2 = 0x04;

frJumpwidth = 0x03

注:再同步參數(shù)rJumpwidth 和frJumpwidth不參與FlexCANFD采樣點(diǎn)的計(jì)算

又因?yàn)樵谝阎狥lexCAN FD時(shí)鐘和預(yù)分頻系數(shù),以及波特率的情況下可以計(jì)算出FlexCAN FD的標(biāo)稱位時(shí)間TqN總數(shù)和可變速率數(shù)據(jù)位時(shí)間TqF總數(shù),計(jì)算公式分別如下所示:

標(biāo)稱位時(shí)間TqN總數(shù):

fcanclk / BITRATEN x (EPRESDIV+1) = [1+(EPSEG1+1)+(EPSEG2+1)+(EPROPSEG+1)]

代入自動(dòng)計(jì)算得出的標(biāo)稱波特率500K的位時(shí)間參數(shù),計(jì)算出TqN:

TqN = 72000000/500000x(1+1)= 72

可變速率數(shù)據(jù)位時(shí)間TqF總數(shù):

fcanclk / BITRATEF x (FPRESDIV+1) = [1+(FPSEG1+1)+(FPSEG2+1)+FPROPSEG]

代入自動(dòng)計(jì)算得出的可變波特率2MHz的位時(shí)間參數(shù),計(jì)算出TqF:

TqF = 72000000/2000000x(1+1)= 18

根據(jù)以上FlexCAN FD使用庫自動(dòng)計(jì)算出的位時(shí)間參數(shù),以及標(biāo)稱位時(shí)間TqN總數(shù)和可變速率位時(shí)間TqF總數(shù),可以分別計(jì)算出其標(biāo)稱位時(shí)間的采樣點(diǎn)和可變速率數(shù)據(jù)位時(shí)間的采樣點(diǎn),即FlexCAN FD標(biāo)稱位時(shí)間的采樣點(diǎn)的計(jì)算公式為:

FlexCAN_samplepoint = (SYNC_SEG+(EPROPSEG+1) +(EPSEG1+1) )/ (SYNC_SEG+(EPROPSEG+1) +(EPSEG1+1)+ (EPSEG2+1))

代入標(biāo)稱波特率500K的位時(shí)間參數(shù)計(jì)算標(biāo)稱波特率的位時(shí)間的采樣點(diǎn)如下:

FlexCAN_samplepoint =(1+(52+1)+(8+1))/(1+(52+1)+(8+1)+(8+1))= 87.5%

FlexCAN FD可變速率位時(shí)間的采樣點(diǎn)的計(jì)算公式為:

FlexCAN_FDsamplepoint = (SYNC_SEG+FPROPSEG+(FPSEG1+1) )/ (SYNC_SEG+FPROPSEG+(FPSEG1+1)+ (FPSEG2+1))

代入可變速率2MHz波特率的位時(shí)間參數(shù)計(jì)算可變速率的位時(shí)間的采樣點(diǎn)如下:

FlexCAN_FDsamplepoint = (1+7+(4+1))/(1+7+(4+1)+(4+1))= 72%

CAN采樣點(diǎn)一般設(shè)置在75%—80%之間,具體要根據(jù)CAN通信波特率大小配置。當(dāng)波特率不超過500K時(shí),建議采樣點(diǎn)設(shè)置在87.5%;當(dāng)波特率大小在500K—800K之間的時(shí)候,建議采樣點(diǎn)設(shè)置在80%;當(dāng)波特率大于800K的時(shí)候,建議采樣點(diǎn)設(shè)置在75%。以上建議并不是絕對(duì)的,需根據(jù)應(yīng)用環(huán)境復(fù)雜程度通過調(diào)整FlexCAN FD的再同步參數(shù)rJumpwidth和frJumpwidth使得phaseSeg1和phaseSeg2以及fphaseSeg1和fphaseSeg2在標(biāo)稱波特率和可變波特率的位時(shí)間上前移或后移N(0-15)個(gè)Tq值來微調(diào)采樣點(diǎn)(雖然rJumpwidth和frJumpwidth不參與采樣點(diǎn)計(jì)算)。

注意事項(xiàng):

關(guān)于采樣點(diǎn)的配置的一些額外建議:當(dāng)用戶在實(shí)際車用環(huán)境中出現(xiàn)FlexCAN無正常收發(fā)數(shù)據(jù)時(shí)除了根據(jù)錯(cuò)誤標(biāo)志查找問題定位問題外,還可使用專業(yè)的CAN診斷儀測試出多節(jié)點(diǎn)總線上的rJumpwidth和frJumpwidth,phaseSeg1和phaseSeg2以及fphaseSeg1和fphaseSeg2參數(shù),參考這些位時(shí)間參數(shù)值來調(diào)整適配rJumpwidth和frJumpwidth,phaseSeg1和phaseSeg2以及fphaseSeg1和fphaseSeg2參數(shù)到CAN通信的合適的采樣點(diǎn)。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 緩沖器
    +關(guān)注

    關(guān)注

    6

    文章

    1924

    瀏覽量

    45551
  • CAN
    CAN
    +關(guān)注

    關(guān)注

    57

    文章

    2760

    瀏覽量

    463993
  • 接收機(jī)
    +關(guān)注

    關(guān)注

    8

    文章

    1183

    瀏覽量

    53550
  • FIFO芯片
    +關(guān)注

    關(guān)注

    0

    文章

    10

    瀏覽量

    8837

原文標(biāo)題:靈動(dòng)微課堂 (第277講)|MM32F0160的FlexCAN FD位時(shí)間采樣點(diǎn)的計(jì)算

文章出處:【微信號(hào):MindMotion-MMCU,微信公眾號(hào):靈動(dòng)MM32MCU】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    使用MM32F0160 FlexCAN-FD接口實(shí)現(xiàn)CAN FD通信

    MM32F0160 系列 MCU 具有一個(gè) FlexCAN 模塊,該模塊遵循 ISO 11898-1 標(biāo)準(zhǔn)、 CAN FD 和 CAN 2.0B 協(xié)議規(guī)范,不僅兼容傳統(tǒng)CAN,還支持CAN F
    的頭像 發(fā)表于 12-14 16:44 ?2411次閱讀
    使用<b class='flag-5'>MM32F0160</b> <b class='flag-5'>FlexCAN-FD</b>接口實(shí)現(xiàn)CAN <b class='flag-5'>FD</b>通信

    靈動(dòng)重磅發(fā)布MM32G新系列MCU產(chǎn)品:G0140 & G0160

    發(fā)布會(huì)上,靈動(dòng)股份隆重介紹了MM32G01系列產(chǎn)品,其擁有以下四大特點(diǎn),一是所集成的FlexCAN-FD提供了更快的通信速度、更長的數(shù)據(jù)長度和更多的幀格式等優(yōu)勢;二是配置的XTAL-LESS USB
    發(fā)表于 02-14 09:23

    S32K344 FlexCAN如何設(shè)置Rx MB掩碼以接收具有不同ID的CAN FD消息?

    嗨,朋友們,我參考下面的掩碼設(shè)置演示,但我只收到具有單個(gè) ID 的 CAN FD 消息。基于下面的代碼,我只收到 ID 為 0x300 的 CAN FD 消息 64 字節(jié)有效負(fù)載。其他 ID 無法
    發(fā)表于 03-29 07:48

    靈動(dòng)股份全新MM32F0160系列MCU發(fā)布

    靈動(dòng)股份發(fā)布全新MM32F0160 系列 MCU,其搭載 72MHz Arm Cortex-M0 處理器,內(nèi)置 128KB Flash,16KB RAM,配備高速 ADC、USB、CAN-FD
    的頭像 發(fā)表于 12-20 13:55 ?777次閱讀

    MM32F0160 產(chǎn)品手冊(中文版)

    MM32F0160 產(chǎn)品手冊(中文版)
    發(fā)表于 02-22 18:50 ?0次下載
    <b class='flag-5'>MM32F0160</b> 產(chǎn)品手冊(中文版)

    MM32F0160 產(chǎn)品手冊(英文版)

    MM32F0160 產(chǎn)品手冊(英文版)
    發(fā)表于 02-22 18:51 ?0次下載
    <b class='flag-5'>MM32F0160</b> 產(chǎn)品手冊(英文版)

    MM32F0160 用戶手冊(中文版)

    MM32F0160 用戶手冊(中文版)
    發(fā)表于 02-22 18:51 ?0次下載
    <b class='flag-5'>MM32F0160</b> 用戶手冊(中文版)

    MM32F0160 用戶手冊(英文版)

    MM32F0160 用戶手冊(英文版)
    發(fā)表于 02-22 18:52 ?0次下載
    <b class='flag-5'>MM32F0160</b> 用戶手冊(英文版)

    MM32G0160 產(chǎn)品簡介(中文版)

    MM32G0160 產(chǎn)品簡介(中文版)
    發(fā)表于 02-27 18:21 ?0次下載
    <b class='flag-5'>MM32G0160</b> 產(chǎn)品簡介(中文版)

    MM32G0160 產(chǎn)品簡介(英文版)

    MM32G0160 產(chǎn)品簡介(英文版)
    發(fā)表于 02-27 18:21 ?0次下載
    <b class='flag-5'>MM32G0160</b> 產(chǎn)品簡介(英文版)

    基于MM32F0160微控制器的機(jī)械鍵盤

    最近,為了配合新品推廣,靈動(dòng)的軟件與系統(tǒng)工程SE團(tuán)隊(duì),基于帶有 USB 外設(shè)模塊的 MM32F0160 微控制器,實(shí)現(xiàn)了一套低成本帶RGB燈效的機(jī)械鍵盤。這里將設(shè)計(jì)機(jī)械鍵盤的全過程開源出來,感興趣
    的頭像 發(fā)表于 04-21 09:11 ?1232次閱讀

    如何通過Mini-F0160開發(fā)板實(shí)現(xiàn)USB轉(zhuǎn)三路虛擬串口功能?

    Mini-F0160 開發(fā)板搭載 MM32F0160 ,產(chǎn)品內(nèi)嵌 1 個(gè) USB 控制器,內(nèi)置 USB PHY,兼容 USB 2.0 全速規(guī)范,提供最高 12 Mbps 數(shù)據(jù)速率,支持設(shè)備模式,USB 控制器提供了最高 8 個(gè)雙向端點(diǎn)。
    的頭像 發(fā)表于 05-06 15:45 ?827次閱讀
    如何通過Mini-<b class='flag-5'>F0160</b>開發(fā)板實(shí)現(xiàn)USB轉(zhuǎn)三路虛擬串口功能?

    MM32F0140 FlexCAN一致性測試 (2)

    MM32F0140 FlexCAN一致性測試 (2)
    的頭像 發(fā)表于 11-10 18:23 ?711次閱讀
    <b class='flag-5'>MM32F</b>0140 <b class='flag-5'>FlexCAN</b>一致性測試 (2)

    MM32F0140 FlexCAN一致性測試(1)

    MM32F0140 FlexCAN一致性測試 (1)
    的頭像 發(fā)表于 11-10 17:50 ?655次閱讀
    <b class='flag-5'>MM32F</b>0140 <b class='flag-5'>FlexCAN</b>一致性測試(1)

    MM32F0140學(xué)習(xí)筆記——FlexCAN 控制器局域網(wǎng)

    MM32F0140學(xué)習(xí)筆記——FlexCAN 控制器局域網(wǎng)
    的頭像 發(fā)表于 10-27 09:25 ?1499次閱讀
    <b class='flag-5'>MM32F</b>0140學(xué)習(xí)筆記——<b class='flag-5'>FlexCAN</b> 控制器局域網(wǎng)