主頁 > 前端設計 > 在ART-Pi H750上移植TouchGFX(二)——制作MDK的外部QSPI-FLASH燒錄演算法

在ART-Pi H750上移植TouchGFX(二)——制作MDK的外部QSPI-FLASH燒錄演算法

2020-09-18 05:25:03 前端設計

目錄

在ART-Pi H750上移植TouchGFX(一)——使用STM32CUBMX生成TouchGFX工程
在ART-Pi H750上移植TouchGFX(二)——制作MDK的外部QSPI-FLASH燒錄演算法
在ART-Pi H750上移植TouchGFX(三)——移植TouchGFX到RT-Thread系統
在ART-Pi H750上移植TouchGFX(四)——使用RT-Thread Studio移植TouchGFX
在ART-Pi H750上移植TouchGFX(五)——制作ST-LINK的外部QSPI-FLASH燒錄演算法

實驗平臺:

硬體: RT-Thread官方ART-PI H750開發版,正點原子4.3寸RGBLCD屏(800*480)
軟體: 最新版本的STM32CubeH7韌體庫,TouchGFXDesigner v4.14和 STM32CubeMX V6.0.1,開發環境MDK v5.29
在這里插入圖片描述

代碼下載:

CSDN:https://download.csdn.net/download/sinat_31039061/12849875

聯系作者:

關注公眾號,免費查看,回復“加群”,加入技術交流群
在這里插入圖片描述

為什么需要QSPI-FLASH燒錄演算法下載到外部flash

1.在實際的UI設計中往往需要大量的圖片和字體,而TouchGFX Designer是把所使用的圖片和字體自動轉換成了靜態陣列,這些大陣列在內部flash中一般是放不下的,所以需要把這些占用資源比較大的陣列放在外部flash中,然后通過QSPI地址映射的方式訪問,
打開上個工程的TouchGFX Designer,匯入一個帶圖片的例程:
Edit->import GUI
在這里插入圖片描述
在這里插入圖片描述

重新打開MDK工程,可以發現generated 分類下多了很多資源,通過如下宏定義可以知道該陣列會優先存放在名為“ExtFlashSection”的記憶體區域中:
generated 分類下
MDK的分散加載檔案默認是沒有“ExtFlashSection”區域的,我們需要通過撰寫分散加載檔案來配置“ExtFlashSection”段:
在這里插入圖片描述
通過Edit按鈕打開KEIL自己生成的sct檔案,然后進行改寫:
在這里插入圖片描述
通過以上配置后,再編譯代碼,就不會出現flash不足的錯誤提示了,但是這時候還不能下載代碼,因為沒有為該段區域配置下載演算法,下載會出現“No Algorithm found for: 90000000H - 9000FFFFH”等錯誤,
查看map檔案,可以發現以上資源的地址已經被分配到了0x90000000:在這里插入圖片描述

MDK的STM32H7升級包升級至V2.6.0版本后,對ST所有板子的外置Flash下載演算法提供了HAL庫版本的原始碼,可以在這個原始碼的基礎上改成你需要的,
下載地址:https://www.cnblogs.com/armfly/p/12564643.html

安裝完成后,找到安裝目錄,通過以下地址,可以找到源代碼:
(提醒一點:默認檔案夾的屬性是只讀型別,所以打開工程后,所有檔案都是加鎖的,如果想要修改代碼,需要把檔案夾的屬性取消只讀)
在這里插入圖片描述
由于我在更新最新的V2.6.0軟體包之前,已經制作了暫存器版本的燒錄演算法,所以不再使用HAL庫版本的了,感興趣的可以自行修改,
修改燒錄演算法的思路其實很簡單,只需要修改FlashDev.c里邊的外部flash大小,然后根據FlashPrg.c模板所需要的介面,添加你的外部flash驅動就行了,因為ART-PI使用的是W25Q128,和正點原子板子所使用的一樣,所以直接把正點原子W25Q128的驅動移植過來就可以了,
在這里插入圖片描述
工程模板默認已經做好了生成.FLM檔案的配置,編譯后會自動生成.FLM檔案,然后把STM32H7_W25QXX.FLM拷貝到你MDK的安裝目錄…Keil_v5\ARM\Flash下,
在這里插入圖片描述

添加完下載演算法,最后在MDK里修改一下配置,就可以把程式下載到板子里了:
在這里插入圖片描述
還差一步:雖然你把圖片和字體資源下載到了外部flash,但是這個時候還沒有配置地址映射,所以你的程式依然是讀不到資料的,需要添加qspi地址映射的代碼,我這里依然借用了正點原子的代碼:

//QSPI進入記憶體映射模式(執行QSPI代碼必備前提,為了減少引入的檔案,
//除了GPIO驅動外,其他的外設驅動均采用暫存器形式)
void QSPI_Enable_Memmapmode(void)
{
	uint32_t tempreg=0; 
	__IO uint32_t *data_reg=&QUADSPI->DR;
	GPIO_InitTypeDef qspi_gpio;
	
	RCC->AHB4ENR|=1<<6;    						//使能PORTG時鐘	   
	RCC->AHB4ENR|=1<<5;    						//使能PORTF時鐘	   
	RCC->AHB3ENR|=1<<14;   						//QSPI時鐘使能

	qspi_gpio.Pin=GPIO_PIN_6;					//PG6 AF10	
	qspi_gpio.Mode=GPIO_MODE_AF_PP;
	qspi_gpio.Speed=GPIO_SPEED_FREQ_VERY_HIGH;
	qspi_gpio.Pull=GPIO_NOPULL;
	qspi_gpio.Alternate=GPIO_AF10_QUADSPI;
	HAL_GPIO_Init(GPIOG,&qspi_gpio);
	
	qspi_gpio.Pin=GPIO_PIN_6|GPIO_PIN_7|GPIO_PIN_10;		//PF6,7,10 AF9	
	qspi_gpio.Alternate=GPIO_AF9_QUADSPI;
	HAL_GPIO_Init(GPIOF,&qspi_gpio);
	
	qspi_gpio.Pin=GPIO_PIN_8|GPIO_PIN_9;		//PF8,9 AF10		
	qspi_gpio.Alternate=GPIO_AF10_QUADSPI;
	HAL_GPIO_Init(GPIOF,&qspi_gpio);
	
	//QSPI設定,參考QSPI實驗的QSPI_Init函式
	RCC->AHB3RSTR|=1<<14;			//復位QSPI
	RCC->AHB3RSTR&=~(1<<14);		//停止復位QSPI
	while(QUADSPI->SR&(1<<5));		//等待BUSY位清零 
	QUADSPI->CR=0X01000310;			//設定CR暫存器,這些值怎么來的,請參考QSPI實驗/看H750參考手冊暫存器描述分析
	QUADSPI->DCR=0X00160401;		//設定DCR暫存器
	QUADSPI->CR|=1<<0;				//使能QSPI 

	//注意:QSPI QE位的使能,在QSPI燒寫演算法里面,就已經設定了
	//所以,這里可以不用設定QE位,否則需要加入對QE位置1的代碼
	//不過,代碼必須通過仿真器下載,直接燒錄到外部QSPI FLASH,是不可用的
	//如果想直接燒錄到外部QSPI FLASH也可以用,則需要在這里添加QE位置1的代碼
	
	//W25QXX進入QPI模式(0X38指令)
	while(QUADSPI->SR&(1<<5));		//等待BUSY位清零 
	QUADSPI->CCR=0X00000138;		//發送0X38指令,W25QXX進入QPI模式
	while((QUADSPI->SR&(1<<1))==0);	//等待指令發送完成
	QUADSPI->FCR|=1<<1;				//清除發送完成標志位 	

	//W25QXX寫使能(0X06指令)
	while(QUADSPI->SR&(1<<5));		//等待BUSY位清零 
	QUADSPI->CCR=0X00000106;		//發送0X06指令,W25QXX寫使能
	while((QUADSPI->SR&(1<<1))==0);	//等待指令發送完成
	QUADSPI->FCR|=1<<1;				//清除發送完成標志位 
	
	//W25QXX設定QPI相關讀引數(0XC0)
	while(QUADSPI->SR&(1<<5));		//等待BUSY位清零 
	QUADSPI->CCR=0X030003C0;		//發送0XC0指令,W25QXX讀引數設定
	QUADSPI->DLR=0;
	while((QUADSPI->SR&(1<<2))==0);	//等待FTF
	*(__IO uint8_t *)data_reg=3<<4;			//設定P4&P5=11,8個dummy clocks,104M
	QUADSPI->CR|=1<<2;				//終止傳輸 
	while((QUADSPI->SR&(1<<1))==0);	//等待資料發送完成
	QUADSPI->FCR|=1<<1;				//清除發送完成標志位  
	while(QUADSPI->SR&(1<<5));		//等待BUSY位清零 	 

	//MemroyMap 模式設定
	while(QUADSPI->SR&(1<<5));		//等待BUSY位清零 
	QUADSPI->ABR=0;					//交替位元組設定為0,實際上就是W25Q 0XEB指令的,M0~M7=0
	tempreg=0XEB;					//INSTRUCTION[7:0]=0XEB,發送0XEB指令(Fast Read QUAD I/O)
	tempreg|=3<<8;					//IMODE[1:0]=3,四線傳輸指令
	tempreg|=3<<10;					//ADDRESS[1:0]=3,四線傳輸地址
	tempreg|=2<<12;					//ADSIZE[1:0]=2,24位地址長度
	tempreg|=3<<14;					//ABMODE[1:0]=3,四線傳輸交替位元組
	tempreg|=0<<16;					//ABSIZE[1:0]=0,8位交替位元組(M0~M7)
	tempreg|=6<<18;					//DCYC[4:0]=6,6個dummy周期
	tempreg|=3<<24;					//DMODE[1:0]=3,四線傳輸資料
	tempreg|=3<<26;					//FMODE[1:0]=3,記憶體映射模式
	QUADSPI->CCR=tempreg;			//設定CCR暫存器
	
	//設定QSPI FLASH空間的MPU保護
	SCB->SHCSR&=~(1<<16);			//禁止MemManage 
	MPU->CTRL&=~(1<<0);				//禁止MPU
	MPU->RNR=0;						//設定保護區域編號為0(1~7可以給其他記憶體用)
	MPU->RBAR=0X90000000;			//基地址為0X9000 000,即QSPI的起始地址
	MPU->RASR=0X0303002D;			//設定相關保護引數(禁止共用,允許cache,允許緩沖),詳見MPU實驗的決議
	MPU->CTRL=(1<<2)|(1<<0);		//使能PRIVDEFENA,使能MPU 
	SCB->SHCSR|=1<<16;				//使能MemManage
}

燒錄驗證:
在這里插入圖片描述
2.STM32H750XBH6的官方指導手冊說明內部flash只要128K,這個空間對于做專案來說是遠遠不夠,所以也需要將部分代碼下載到外部flash,具體原理和上邊差不多,至于你想把哪部分代碼放到外部,可以有你自己決定,
可以參考一下正點原子的分散加載檔案:

#! armcc -E 
//  
//STM32H750分散加載檔案(.scf檔案)
//ALIENTEK STM32開發板  
//正點原子@ALIENTEK
//技術論壇:www.openedv.com
//創建日期:2019/4/21
//版本:V1.0
//著作權所有,盜版必究,
//Copyright(C) 廣州市星翼電子科技有限公司 2014-2024
//All rights reserved
//********************************************************************************
//修改說明
//無
//


#define m_stmflash_start				0X08000000		//m_stmflash(STM32內部FLASH)域起始地址
#define m_stmflash_size					0X20000			//m_stmflash(STM32內部FLASH)大小,H750是128KB

#define m_qspiflash_start				0X90000000		//m_qspiflash(外擴QSPI FLASH)域起始地址
#define m_qspiflash_size				0X800000		//m_qspiflash(外擴QSPI FLASH)大小,W25Q64是8MB
 
#define m_stmsram_start					0X24000000		//m_stmsram(STM32內部RAM)域起始地址,定義在D1,AXI SRAM
#define m_stmsram_size					0X80000			//m_stmsram(STM32內部RAM)大小,AXI SRAM共512KB

  
 
LR_m_stmflash m_stmflash_start m_stmflash_size {		//LR_m_stmflash加載域
  ER_m_stmflash m_stmflash_start m_stmflash_size {		//ER_m_stmfalsh運行域,起始地址為:m_stmflash_start,大小為:m_stmflash_size 
    *.o (RESET, +First)									//優先(+FIRST)將RESET(中斷向量表)段放這個域,實際上就是把中斷向量表拷貝到m_stmflash_start
														//RESET是一個段名,表示中斷向量表(在.s檔案定義);+FIRST表示時第一個要加載的.
	* (InRoot$$Sections)								//將所有的庫段(C/C++標準庫)放在root region.如__main.o,__scatter*.o等
	* (Veneer$$Code) 
	libinit.o
	libinit2.o
	libshutdown.o
	libshutdown2.o
	__rtentry.o
	__rtentry2.o
	__rtentry4.o
	rtexit.o
	rtexit2.o 
	
	use_no_semi_2.o
	heapauxi.o
	use_no_semi.o
	sys_stackheap_outer.o
	exit.o
	libspace.o
	fpinit.o
	lludivv7m.o
	startup_stm32h750xx.o
	 
	rt_locale_intlibspace.o  
	lc_numeric_c.o 
	lc_ctype_c.o

	startup_stm32h750xx.o
	system_stm32h7xx.o
	stm32h7xx_hal.o
	stm32h7xx_hal_cortex.o
	stm32h7xx_hal_rcc.o
	stm32h7xx_hal_gpio.o
	stm32h7xx_hal_msp.o
	
	main.o 
    sys.o 
	usart.o
	delay.o
  } 
  RW_m_stmsram m_stmsram_start m_stmsram_size {			//RW_m_stmsram運行域,起始地址為:m_stmsram_start,大小為:m_stmsram_size.
   .ANY (+RW +ZI)										//將所有用到的RAM都放在這個區域
  }
}

LR_m_qspiflash m_qspiflash_start m_qspiflash_size {		//LR_m_qspiflash加載域
   ER_m_qspiflash m_qspiflash_start m_qspiflash_size {	//ER_m_qspiflash加載域,起始地址為:m_qspiflash_start,大小為:m_qspiflash_size 
    .ANY (+RO) 											//將只讀資料(+RO)放這個域,任意分配.相當于程式就是存放在這個域的.
  }															 
}

(悄悄告訴你,雖然官方手冊上說明內部flash只有128k的大小,但是經過實際測驗,可以用到2M的空間,至于超出的空間安全不安全就不知道了)

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/70978.html

標籤:其他

上一篇:華為鴻蒙作業系統學習(1):查找學習資料,最重要的不是著急去買板子,這個關鍵在于軟體!這個關鍵在于軟體!這個關鍵在于軟體!準備直接在Linux上面進行編譯學習,就學習基礎的東西。

下一篇:RFID標簽列印機在加工制造業中的應用

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more