日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 單片機 > 單片機
[導(dǎo)讀]項目中需要使用STM32和FPGA通信,使用的是地址線和數(shù)據(jù)線,在FPGA中根據(jù)STM32的讀寫模式A的時序完成寫入和讀取。之前的PCB設(shè)計中只使用了8跟數(shù)據(jù)線和8根地址線,調(diào)試過程中沒有發(fā)現(xiàn)什么問題,在現(xiàn)在的PCB中使用了8根

項目中需要使用STM32和FPGA通信,使用的是地址線和數(shù)據(jù)線,在FPGA中根據(jù)STM32的讀寫模式A的時序完成寫入和讀取。之前的PCB設(shè)計中只使用了8跟數(shù)據(jù)線和8根地址線,調(diào)試過程中沒有發(fā)現(xiàn)什么問題,在現(xiàn)在的PCB中使用了8根地址線和16根數(shù)據(jù)線,數(shù)據(jù)寬度也改成了16位,剛開始是讀取數(shù)據(jù)不正確,后來發(fā)現(xiàn)了問題,STM32在16位數(shù)據(jù)寬度下有個內(nèi)外地址映射的問題,只需要把FPGA中的設(shè)定的地址乘以2在STM32中訪問就可以了,但是在寫操作的時候會出現(xiàn)寫當(dāng)前地址的時候把后面的地址寫成0的情況,比如說我給FPGA中定義的偏移地址0x01寫一個16位數(shù)據(jù),按照地址映射,在STM32中我把地址寫入0x02,。實際測試發(fā)現(xiàn)這個地址上的數(shù)據(jù)是對的,但是FPGA中0x02地址上的數(shù)據(jù)也變成了00。

經(jīng)過一晚上的測試,發(fā)現(xiàn)寫數(shù)據(jù)時實際上是進行了多次寫入,導(dǎo)致把后面的地址也給寫上了,最終導(dǎo)致數(shù)據(jù)混亂,后來經(jīng)過學(xué)長提醒,決定把訪問的地址定義為16位的,原來是32位的,經(jīng)過測試問題解決。所以這兒也算是長了經(jīng)驗,因為我只用了8根地址線,為了避免可能的問題,地址最好定義成對應(yīng)的位數(shù)。但是還是很納悶為什么之前八位數(shù)據(jù)線讀寫的時候沒有這個問題。

下面是改正之后的STM32程序,對應(yīng)的CPLD/FPGA程序參考我之前的博客

1 /**************************(C) COPYRIGHT emouse 2011***************************

2 名稱:CPLD.c

3 功能:配置fsmc,CPLD讀寫函數(shù)

4 作者:HHUC emouse miss1989@139.com

5 時間:2011.4.28

6 版本:1.0

7 注意:一定要使能RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE);

8 *******************************************************************************/

9 #include "STM32Lib//stm32f10x.h"

10 #include "hal.h"

11 //使用第一塊存儲區(qū),使用第四塊,定義基地址

12 #define Bank1_SRAM4_ADDR ((uint32_t)0x6c000000)

13 /*******************************************************************************

14 名稱:CPLD_Init(void)

15 功能:配置FSMC寄存器

16 參數(shù):無

17 時間:2011.1.15

18 版本:1.0

19 注意:實際CPLD只用了8根地址線和8根數(shù)據(jù)線

20 按照模式A-SRAM/PSRAM(CRAM)OE翻轉(zhuǎn)模式配置讀寫時序時序圖在STM32技術(shù)手冊P332

21 可以按照實際連接配置地址線數(shù)據(jù)線

22 實際CPLD中可以更改敏感信號,對STM32的時序要求放寬

23 *******************************************************************************/

24 void CPLD_Init(void)

25 {

26

27 FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure;

28 FSMC_NORSRAMTimingInitTypeDef p;

29 GPIO_InitTypeDef GPIO_InitStructure;

30 RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE);

31 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC |RCC_APB2Periph_GPIOD | RCC_APB2Periph_GPIOG |

32 RCC_APB2Periph_GPIOE | RCC_APB2Periph_GPIOF, ENABLE);

33 //數(shù)據(jù)線引腳初始化,輔助控制器中使用了16根數(shù)據(jù)線

34 //D 0 1 2 3 13 14 15

35 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_8 |GPIO_Pin_9 |

36 GPIO_Pin_10| GPIO_Pin_14 | GPIO_Pin_15;

37 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //復(fù)用推挽輸出

38 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

39 GPIO_Init(GPIOD, &GPIO_InitStructure);

40 //D4-D12

41 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10|

42 GPIO_Pin_11| GPIO_Pin_12| GPIO_Pin_13| GPIO_Pin_14| GPIO_Pin_15;

43 GPIO_Init(GPIOE, &GPIO_InitStructure);

44

45 //地址線引腳初始化,調(diào)試使用8根地址線

46 //A0-A7

47 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3 |

48 GPIO_Pin_4 | GPIO_Pin_5 | GPIO_Pin_12 | GPIO_Pin_13 |

49 GPIO_Pin_14;

50 GPIO_Init(GPIOF, &GPIO_InitStructure);

51

52 //其他控制信號線,調(diào)試使用NE4、NOE、NWE

53 //NOE and NWE configuration

54 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4 |GPIO_Pin_5;

55 GPIO_Init(GPIOD, &GPIO_InitStructure);

56 //NE4 configuration

57 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12;

58 GPIO_Init(GPIOG, &GPIO_InitStructure);

59

60 /*-- FSMC Configuration ------------------------------------------------------*/

61 p.FSMC_AddressSetupTime = 0;

62 p.FSMC_AddressHoldTime = 0;

63 p.FSMC_DataSetupTime = 1;

64 p.FSMC_BusTurnAroundDuration = 0;

65 p.FSMC_CLKDivision = 0;

66 p.FSMC_DataLatency = 0;

67 p.FSMC_AccessMode = FSMC_AccessMode_A;

68

69 FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM4;

70 FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;

71 FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_SRAM;

72 FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;

73 FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable;

74 FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait = FSMC_AsynchronousWait_Disable;

75 FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;

76 FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable;

77 FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;

78 FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;

79 FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;

80 FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Enable;

81 FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;

82 FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &p;

83 FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &p;

84

85 FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);

86

87 // Enable FSMC Bank1_SRAM Bank

88 FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM4, ENABLE);

89

90 //CPLD 復(fù)位信號,這里使用普通IO PD7

91 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7;

92 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //開漏輸出

93 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //50M時鐘速度

94 GPIO_Init(GPIOC, &GPIO_InitStructure);

95

96 GPIO_ResetBits(GPIOD, GPIO_Pin_7);

97 GPIO_SetBits(GPIOD, GPIO_Pin_7); //根據(jù)CPLD程序設(shè)置低電平復(fù)位

98 }

99 /*******************************************************************************

100 名稱:CPLD_Write

101 功能:CPLD寫時序

102 參數(shù):uint8_t pBuffer-寫入的數(shù)據(jù) uint32_t WriteAddr-寫入的地址

103 時間:2011.1.15

104 版本:1.0

105 注意:在硬件設(shè)計中使用了八根地址線和數(shù)據(jù)線,因此以八位的數(shù)據(jù)寫入

106 *******************************************************************************/

107 void CPLD_Write(uint16_t pBuffer, uint16_t WriteAddr)

108 {

109 *(uint16_t *) (Bank1_SRAM4_ADDR + WriteAddr) = pBuffer;

110 }

111 /*******************************************************************************

112 名稱:uint16_t CPLD_Read(uint32_t ReadAddr)

113 功能:CPLD讀

114 參數(shù):uint32_t ReadAddr需要讀取的地址,返回讀取的值

115 時間:2011.4.26

116 版本:1.0

117 注意:在硬件設(shè)計中使用了16根地址線和數(shù)據(jù)線,因此以16位的數(shù)據(jù)寫入

118 *******************************************************************************/

119 uint16_t CPLD_Read(uint16_t ReadAddr)

120 {

121 uint16_t pBuffer;

122 pBuffer = *(__IO uint16_t*) (Bank1_SRAM4_ADDR + ReadAddr);

123 return pBuffer;

124 }


本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

在嵌入式開發(fā)中,STM32的時鐘系統(tǒng)因其靈活性和復(fù)雜性成為開發(fā)者關(guān)注的焦點。然而,看似簡單的時鐘配置背后,隱藏著諸多易被忽視的陷阱,輕則導(dǎo)致系統(tǒng)不穩(wěn)定,重則引發(fā)硬件損壞。本文從時鐘源選擇、PLL配置、總線時鐘分配等關(guān)鍵環(huán)...

關(guān)鍵字: STM32 時鐘系統(tǒng)

在嵌入式系統(tǒng)開發(fā)中,STM32系列微控制器的內(nèi)部溫度傳感器因其低成本、高集成度特性,廣泛應(yīng)用于設(shè)備自檢、環(huán)境監(jiān)測等場景。然而,受芯片工藝差異和電源噪聲影響,其原始數(shù)據(jù)存在±1.5℃的固有誤差。本文從硬件配置、校準(zhǔn)算法、軟...

關(guān)鍵字: STM32 溫度傳感器

在能源效率與智能化需求雙重驅(qū)動下,AC-DC轉(zhuǎn)換器的數(shù)字控制技術(shù)正經(jīng)歷從傳統(tǒng)模擬方案向全數(shù)字架構(gòu)的深刻變革。基于STM32微控制器的PFM(脈沖頻率調(diào)制)+PWM(脈沖寬度調(diào)制)混合調(diào)制策略,結(jié)合動態(tài)電壓調(diào)整(Dynam...

關(guān)鍵字: AC-DC STM32

當(dāng)前智能家居產(chǎn)品需求不斷增長 ,在這一背景下 ,對現(xiàn)有澆花裝置缺陷進行了改進 ,設(shè)計出基于STM32單片機的全 自動家用澆花機器人。該設(shè)計主要由機械結(jié)構(gòu)和控制系統(tǒng)構(gòu)成 ,機械結(jié)構(gòu)通過麥克納姆輪底盤與噴灑裝置的結(jié)合實現(xiàn)機器...

關(guān)鍵字: STM32 麥克納姆輪 安全可靠 通過性強

用c++編程似乎是讓你的Arduino項目起步的障礙嗎?您想要一種更直觀的微控制器編程方式嗎?那你需要了解一下Visuino!這個圖形化編程平臺將復(fù)雜電子項目的創(chuàng)建變成了拖動和連接塊的簡單任務(wù)。在本文中,我們將帶您完成使...

關(guān)鍵字: Visuino Arduino ESP32 STM32

基于STM32與LoRa技術(shù)的無線傳感網(wǎng)絡(luò)憑借其低功耗、廣覆蓋、抗干擾等特性,成為環(huán)境監(jiān)測、工業(yè)自動化等場景的核心解決方案。然而,如何在復(fù)雜電磁環(huán)境中實現(xiàn)高效休眠調(diào)度與動態(tài)信道優(yōu)化,成為提升網(wǎng)絡(luò)能效與可靠性的關(guān)鍵挑戰(zhàn)。本...

關(guān)鍵字: STM32 LoRa

在實時控制系統(tǒng)、高速通信協(xié)議處理及高精度數(shù)據(jù)采集等對時間敏感的應(yīng)用場景中,中斷響應(yīng)延遲的優(yōu)化直接決定了系統(tǒng)的可靠性與性能上限。STM32系列微控制器憑借其靈活的嵌套向量中斷控制器(NVIC)、多通道直接內(nèi)存訪問(DMA)...

關(guān)鍵字: STM32 DMA

數(shù)字電源技術(shù)向高功率密度、高效率與高動態(tài)響應(yīng)方向加速演進,STM32微控制器憑借其基于DSP庫的算法加速能力與對LLC諧振變換器的精準(zhǔn)控制架構(gòu),成為優(yōu)化電源動態(tài)性能的核心平臺。相較于傳統(tǒng)模擬控制或通用型數(shù)字控制器,STM...

關(guān)鍵字: STM32 數(shù)字電源

STM32微控制器憑借其針對電機控制場景的深度優(yōu)化,成為高精度、高可靠性驅(qū)動系統(tǒng)的核心選擇。相較于通用型MCU,STM32在電機控制領(lǐng)域的核心優(yōu)勢集中體現(xiàn)在FOC(磁場定向控制)算法的硬件加速引擎與PWM死區(qū)時間的動態(tài)補...

關(guān)鍵字: STM32 電機控制

無線充電技術(shù)加速滲透消費電子與汽車電子領(lǐng)域,基于Qi協(xié)議的無線充電發(fā)射端開發(fā)成為智能設(shè)備能量補給的核心課題。傳統(tǒng)模擬控制方案存在響應(yīng)滯后、參數(shù)調(diào)整困難等問題,而基于STM32的數(shù)字PID控制結(jié)合FOD(Foreign O...

關(guān)鍵字: STM32 無線充電
關(guān)閉