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

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

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

LPC4357FET256 CAN0復(fù)位后,需要插入NOP延遲一段時間

li1756686189 ? 來源:嵌入式 MCU ? 2023-01-14 14:28 ? 次閱讀

4f83c16e-93d4-11ed-bfe3-dac502259ad0.png

50bded5c-93d4-11ed-bfe3-dac502259ad0.png

CAN0復(fù)位后,在訪問CAN0外設(shè)之前,應(yīng)該添加至少20個NOP的復(fù)位延遲,而不是9個NOP復(fù)位延遲。否則無法訪問CAN0寄存器。9個NOP復(fù)位延遲是在將108MHz的Fcclk除以12MHz的FIRC內(nèi)部時鐘之后獲得的,如下LPC43xxUM文檔第15.4.1節(jié)備注所示。

50eef80c-93d4-11ed-bfe3-dac502259ad0.png

/* Chip_SetupCoreClock(CLKIN_CRYSTAL, MAX_CLOCK_FREQ, true); */

// Chip_SetupCoreClock(CLKIN_CRYSTAL, 108000000, true);

// CCLK 12MHz

Chip_SetupCoreClock(CLKIN_CRYSTAL, 12000000, true);

已通過輪詢復(fù)位標志成功等待CAN0退出復(fù)位。

Chip_RGU_TriggerReset( RGU_CAN0_RST );

//NOP_operation();

while(Chip_RGU_InReset(RGU_CAN0_RST))

為什么 9 或者10 個NOP復(fù)位延遲時間不滿足要求,而20個NOP確可以呢?使用108Mhz時鐘作為內(nèi)核時鐘,如用戶手冊所說,在復(fù)位CAN后,需要等待108Mhz/12Mhz = 9個周期。但是實際測試需要20個周期數(shù)。當內(nèi)核時鐘是12Mhz的時候,0或者1個等待周期數(shù)都是可以的。

-> 使用"NOP"來實現(xiàn) NOP_operation()是有風險的,由于Cortex-M用戶手冊提示如下:

NOP is not necessarily a time-consuming NOP. The processor might remove it from the pipeline before it reaches the execution stage.

511d9afe-93d4-11ed-bfe3-dac502259ad0.png

51431338-93d4-11ed-bfe3-dac502259ad0.png

可以使用MOV r0,r0或硬件定時器來實現(xiàn)等待周期,以避免編譯器和優(yōu)化級別配置的影響。

審核編輯:湯梓紅

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

    關(guān)注

    3

    文章

    1372

    瀏覽量

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

    關(guān)注

    57

    文章

    2754

    瀏覽量

    463703
  • 時鐘
    +關(guān)注

    關(guān)注

    10

    文章

    1733

    瀏覽量

    131480
  • Cortex-M
    +關(guān)注

    關(guān)注

    2

    文章

    229

    瀏覽量

    29763
  • nop
    nop
    +關(guān)注

    關(guān)注

    0

    文章

    9

    瀏覽量

    1927

原文標題:LPC4357FET256 CAN0復(fù)位后,需要插入NOP延遲一段時間

文章出處:【微信號:嵌入式 MCU,微信公眾號:嵌入式 MCU】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    tc264隔一段時間復(fù)位有些什么原因呢?

    tc264隔一段時間復(fù)位有些什么原因呢
    發(fā)表于 02-02 07:31

    STM8L運行一段時間死機,手動復(fù)位無效怎么解決?

    我們的是電池供電,LDO給主板供電,設(shè)備在用戶手上運行一段時間,莫名死機,回來拆機發(fā)現(xiàn)STM8L RST管腳始終處于低電平,必須拔電池上電才能復(fù)位復(fù)位
    發(fā)表于 04-11 06:19

    STM8串口工作一段時間出現(xiàn)通訊異常的原因?

    能串口。發(fā)送數(shù)據(jù)前先發(fā)送幾個0x00喚醒對方再發(fā)有用數(shù)據(jù)。通訊速率很低。 產(chǎn)品在終端客戶手上使用一段時間可能會出現(xiàn)通訊不上的問題。出現(xiàn)問題后過一段時間可能會自行恢復(fù)。通過對STM8
    發(fā)表于 04-15 08:05

    STM8L運行一段時間死機,手動復(fù)位無效,只能上電復(fù)位怎么解決?

    我們的是電池供電,LDO給主板供電,設(shè)備在用戶手上運行一段時間,莫名死機,回來拆機發(fā)現(xiàn)STM8L RST管腳始終處于低電平,必須拔電池上電才能復(fù)位復(fù)位
    發(fā)表于 04-15 07:56

    STM3218B20讀取一段時間0是怎么回事?

    18b20讀取一段時間0
    發(fā)表于 04-22 06:58

    VL53L0在使用一段時間無法讀取數(shù)據(jù)如何解決?

    VL53L0在使用一段時間無法讀取數(shù)據(jù),已經(jīng)有好幾個模塊了,返回的錯誤代碼有-6,-7和-20,這個到底是怎么回事?如何解決?
    發(fā)表于 05-28 08:07

    ADS1013采集運放輸出數(shù)據(jù),一段時間變的很低是為什么?

    我用ADS1013采集AD8237運放輸出直流數(shù)據(jù),開始采集得到的原始數(shù)據(jù)為683,對應(yīng)1.3v。一段時間大概5-9分鐘,ads1013讀出來的數(shù)據(jù)變成11,對應(yīng)0.02v,然后不再發(fā)生變化。需要系統(tǒng)
    發(fā)表于 12-17 07:09

    請問CC2630運行一段時間會自動復(fù)位是什么原因

    CC2630成功加入CC2530組建的網(wǎng)絡(luò),運行一段時間大概幾十秒吧,就自動復(fù)位了,從斷點中可以看到他從新開始運行,目前排除是電源的問題,使用的是zstack_home_1.2.2a協(xié)議棧,用的是SampleSwitch工程。
    發(fā)表于 08-18 06:40

    STM32運行一段時間死機,手動復(fù)位無效,只能上電復(fù)位才能正常運行

    STM32運行一段時間死機,手動復(fù)位無效,只能上電復(fù)位才能正常運行,是不是STM32F030R8T6的芯片問題?。?補充下,程序是做低功
    發(fā)表于 01-08 09:39

    回收LPC4357FET256 收購LPC4357FET256

    LPC4357FET256大量回收!高價收購LPC4357FET256??!高價收購LPC4357FET256!!! 大量回收LPC4357FET256!專業(yè)回收
    發(fā)表于 11-08 11:52

    STC使用一段時間真的會掉固件嗎?

    STC使用一段時間真的會掉固件?
    發(fā)表于 10-31 08:29

    米爾科技NXP LPC4357 LPC4350 Cortex-M4/M0開發(fā)板介紹

    NXP LPC4357FET256處理器
    的頭像 發(fā)表于 11-04 14:43 ?5774次閱讀
    米爾科技NXP <b class='flag-5'>LPC4357</b> <b class='flag-5'>LPC</b>4350 Cortex-M4/M<b class='flag-5'>0</b>開發(fā)板介紹

    微雪電子LPC Cortex M4開發(fā)板 Core4357簡介

    LPC4357FET256 核心板 最小系統(tǒng)板 引出了所有I/O資源 帶JTAG/SWD調(diào)試下載接口 型號 Core4357 產(chǎn)品簡介 Core4357款基于
    的頭像 發(fā)表于 12-27 09:31 ?2756次閱讀
    微雪電子<b class='flag-5'>LPC</b> Cortex M4開發(fā)板 Core<b class='flag-5'>4357</b>簡介

    Arduino 接MPU6050 9250使用IIC通訊,輸出數(shù)據(jù)一段時間死機卡死的問題解決

    Arduino 接MPU6050 9250使用IIC通訊,輸出數(shù)據(jù)一段時間死機卡死的問題解決
    發(fā)表于 12-06 15:06 ?24次下載
    Arduino 接MPU6050 9250使用IIC通訊,輸出數(shù)據(jù)<b class='flag-5'>一段時間</b><b class='flag-5'>后</b>死機卡死的問題解決

    維修力科示波器604ZI開機一段時間黑屏

    一段時間黑屏維修 、示波器維修型號:力科604ZI。 二、報修故障:開機使用一段時間黑屏。 三、故障檢測:對內(nèi)部元件進行詳細檢測。儀器
    的頭像 發(fā)表于 12-11 16:18 ?489次閱讀