无主之地2配置高吗|看真人裸体BBBBB|秋草莓丝瓜黄瓜榴莲色多多|真人強奷112分钟|精品一卡2卡3卡四卡新区|日本成人深夜苍井空|八十年代动画片

網易首頁 > 網易號 > 正文 申請入駐

手把手教你用位圖映射方式優化灰度液晶控制器驅動

0
分享至

單色液晶控制器通常的寫顯示RAM方式是一次寫8個像素,容易實現MCU主存到控制器的位圖映射。但是支持灰度的液晶控制器不一定有這樣的操作方式,于是只用黑白二色的顯示時,也不得不每個像素都要寫灰階編碼到控制器。但是在MCU主存中每個像素用8-bit甚至16-bit來表示,開銷就大多了,很多時候是不必要的。如果用二值的位圖存放顯示內容,在顯示驅動軟件中轉換,就可能實現和單色液晶在圖形庫上的兼容性。

例如ST7529液晶控制器的顯存數據是5-bit灰度,采用并行接口(8080模式)驅動時,有16-bit表示3個像素的辦法和3個8-bit表示3個像素的辦法。這個控制器是給CSTN液晶設計的,所以總是要RGB 3個像素一起寫,作為FSTN的驅動顯得有些別扭——列方向的坐標只能以3像素為單位。如果能忍受這一點,用8-bit數據模式,每次寫顯存操作就是更新一個像素,按列優先模式能實現逐條掃描線的數據寫入。

現在考慮類似ST7529這種控制器的位圖映射軟件驅動。在MCU的SRAM中開辟一塊連續空間作為顯示區域內容的位圖存儲(只顯示兩種顏色,每個像素1 bit),向控制器寫像素數據時每次根據位圖中的一個bit,決定寫控制器的數據是兩種顏色代碼中哪一個。如果控制器是用MCU的內存控制器(如STM32的FMC)連接的,寫操作就對應到一條STR指令;如果不能用FMC,就要用一組GPIO輸出并行數據,另一單獨GPIO產生寫脈沖。

基本的顯示代碼:

在寫每個像素數據的時候,要進行位運算測試內存中數據的某位是1還是0. 按照低地址數據在前,每個字中LSB在前的順序訪問整個位圖。取數據的時候一次取32 bit的效率要高于8 bit. 內層循環就是逐位處理。在Cortex-m4上,以上代碼的實現效率約為12.2 時鐘周期每像素。

這樣的代碼足夠簡潔了。用位運算是因為不能直接尋址SRAM的某一位…… 但是真的不能嗎?Cortex-m3/m4有bit-banding的功能,雖然我以前沒覺得有什么用,SRAM是處于bit-band區域中的。也就是,在SRAM中存儲了位圖,就有某一段地址是每個32-bit映射到位圖中一個bit的。按連續地址訪問就可以遍歷位圖中每個像素。于是顯示代碼就只需要一個循環了:

針對ST7529,如果輸出是全黑和全白兩種顏色,數據接口上有效位是全0或者全1,還可以把條件判斷也省去,修改成這樣:

代碼中直接輸出數據 -p[n] , 因為p[n]為1則寫數據就成了 0xFF,是滿足需要的。這樣又能少用指令了。實際測試的執行時間減少到 8~9 時鐘周期每像素,有一個浮動可能是CPU流水線的關系??匆幌戮幾g的結果:

標出的部分就是循環主體,一共7條指令,顯得沒有任何多余操作,實際執行時間變化可能是總線的緣故。

到這里,好象已經優化到頭了,不繞彎。

回頭看,從原理上呢,根據每個像素判斷一下要寫什么數據是沒錯的,但是如果寫的數據和上次一樣其實可以不用更新接口上的并行數據,所以可以少一步操作?然而要增加這個條件判斷其實是又繞彎了,因為測試、保存前次結果和條件分支會消耗更多的周期。實際測試也是平均執行時間到了 10.4 時鐘周期每像素。 程序如下:

雖然上面這個嘗試改進失敗,減少不必要的操作的思路是有價值的。實際的顯示驅動就是寫連續一串(個數不確定)的前景色像素,再寫連續一串背景色像素,交替進行的。假如SRAM存儲的不是位圖,而是按順序排列的兩種顏色各自連續的像素個數的序列,則顯示代碼有可能執行更快。

但是現在SRAM存儲的是位圖,只能在此前提下討論。那么,從位圖掃描的角度,統計連續的1個的個數,再統計后面連續的0的個數,再統計后面連續1的個數……如此下去也可以,只不過效率是個問題。不妨對比以下:

這段程序將"1"像素和"0"像素分組輸出,包含了測試統計和連續寫脈沖的過程,屬于是繞了彎路的做法,最后的執行時間大約是 15.5 時鐘周期每像素. 比最基本的方法還要慢,也是可想而知的。

如果不用bit-banding呢,像最基本的方法那樣每次先取一個字,那么程序還會可預期地多耗費點時間:

上面這段程序實際測試大約平均 20.4 時鐘周期每像素, 是明顯慢多了。

但之所以要這么改寫,是我想嘗試一下能否快速地找出連續的1或0的個數——Cortex-m3/m4有CLZ (Count Leading Zeros)指令。在一個32-bit字之內,用這條指令直接得到從最高位開始往下有多少個連續的0. 它能省去一個循環的位測試。

還是要嘗試的,下面的代碼看起來過于復雜了。可能還有可優化的地方。

調試查錯過后,上面這段代碼在我用的測試位圖(文本字符為主)上達到了平均約 8 時鐘周期每像素的效率,追上了前面用bit-band的最快的代碼。不枉這份努力啊。這種方式,執行時間與顯示內容是關聯的,一般圖形界面的話像素顏色連續出現的時候多,所以應該是適用的。

到了這個地步,覺得還有更快的可能嗎?其實使用CLZ指令得以提升效率的原因是減少了循環次數,上面這個程序仍然有循環:除了不可避免的從SRAM中取數據之外,連續產生多少次寫脈沖是用循環來實現。而后者還有優化的可能:

  1. 不用GPIO翻轉的方式,用硬件自動產生N個脈沖。STM32的TIM1/TIM8等定時器的PWM能做到,或者用一個定時器作為另一個輸出PWM的定時器的門控。我暫時還沒有實驗,好象用的板子GPIO連接缺少條件。

  2. 如果用了FMC接口的話可以用借用這個思路,用DMA內存到內存的方式快速寫。

  3. 循環展開,這要費一些代碼空間了。在上面的程序中,連續的寫脈沖一般不會太長。比如說,在32個以內就完全展開循環:

用這個 wr_pulses() 函數代替前一段代碼中的產生WR脈沖的循環,實現部分的循環展開,之后…… 執行速度提升到了 6 時鐘周期每像素的水平。

當然,要求刷屏刷得快簡單地把時鐘頻率提上去就是了,是否要糾結這種優化是MCU玩家自己決定,本文只是假期時候的一點研究分享。關鍵點:一是bit-band的使用,二是CLZ指令的使用。這兩個特性都得要m3/m4起才有,m0是沒有的(現在國產m4也很便宜了嘛)。

歡迎將我們設為“星標”,這樣才能第一時間收到推送消息。

歡迎關注EEWorld旗下訂閱號:“汽車開發圈”

掃碼添加小助手回復“進群”

和電子工程師們面對面交流經驗

特別聲明:以上內容(如有圖片或視頻亦包括在內)為自媒體平臺“網易號”用戶上傳并發布,本平臺僅提供信息存儲服務。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相關推薦
熱點推薦
梅西16球并列世界杯射手王!中國球迷2.48萬拍下親簽球衣: “感覺一下縮短了跟他的距離”

梅西16球并列世界杯射手王!中國球迷2.48萬拍下親簽球衣: “感覺一下縮短了跟他的距離”

極目新聞
2026-06-17 12:50:04
為什么"地下停車位"突然沒人買了?內行人說出實情,恍然大悟

為什么"地下停車位"突然沒人買了?內行人說出實情,恍然大悟

尋墨閣
2026-05-19 05:08:08
105比72狂勝33分!廣東掀翻遼籃苦主晉級:鎖定第1沖冠穩了?

105比72狂勝33分!廣東掀翻遼籃苦主晉級:鎖定第1沖冠穩了?

籃球快餐車
2026-06-18 00:52:48
葡萄牙VS民主剛果前瞻:葡萄牙實力斷層領先,41歲C羅能否破門?

葡萄牙VS民主剛果前瞻:葡萄牙實力斷層領先,41歲C羅能否破門?

體育吐槽
2026-06-17 20:57:20
被“VCD”逼退圈的女星!

被“VCD”逼退圈的女星!

文刀萬
2026-06-15 07:00:12
馬卡:皇馬已將目光投向恩佐,阿隆索不想留下不夠投入的球員

馬卡:皇馬已將目光投向恩佐,阿隆索不想留下不夠投入的球員

懂球帝
2026-06-17 23:33:56
醫生發現:大量喝茶的糖尿病患者,用不了多久,身體或有5大變化

醫生發現:大量喝茶的糖尿病患者,用不了多久,身體或有5大變化

芹姐說生活
2026-06-16 14:28:33
TA:如今C羅只負責射門,他在場上其他葡萄牙球員踢得像劇本

TA:如今C羅只負責射門,他在場上其他葡萄牙球員踢得像劇本

懂球帝
2026-06-17 23:33:57
G7峰會變烏克蘭專場,澤連斯基風頭蓋過川普

G7峰會變烏克蘭專場,澤連斯基風頭蓋過川普

史政先鋒
2026-06-17 14:59:42
美父親為救女兒開16槍殺戀童癖!警方“不小心”弄丟證據后判他無罪?

美父親為救女兒開16槍殺戀童癖!警方“不小心”弄丟證據后判他無罪?

英國報姐
2026-06-16 21:08:05
知名女主持金佳悅曬出工作照,清純可人又灑脫干練

知名女主持金佳悅曬出工作照,清純可人又灑脫干練

懂球帝
2026-06-15 22:59:28
李世民在HK風評很差?為何教科書上全是負面評價?

李世民在HK風評很差?為何教科書上全是負面評價?

小豫講故事
2026-06-17 06:00:10
濱州市紀委監委通報:1人被雙開!

濱州市紀委監委通報:1人被雙開!

齊魯壹點
2026-06-17 17:24:32
從女籃未來到泯然眾人 昔日新星轉身鄉村球場 也是一種傳承?

從女籃未來到泯然眾人 昔日新星轉身鄉村球場 也是一種傳承?

你看球呢
2026-06-17 11:04:55
美國發話也不行,中方正式通告全球:打日本,中國具備“正當性”

美國發話也不行,中方正式通告全球:打日本,中國具備“正當性”

鳳語談
2026-05-28 12:13:58
囚禁2000同胞斂財10億,假面僑領,柬埔寨安徽商會長劉忍電詐黑幕

囚禁2000同胞斂財10億,假面僑領,柬埔寨安徽商會長劉忍電詐黑幕

易玄
2026-06-16 21:23:31
有沒有人敢爆自己的瓜?網友:確定玩這么大嗎?

有沒有人敢爆自己的瓜?網友:確定玩這么大嗎?

夜深愛雜談
2026-02-18 20:55:58
世界杯:英格蘭vs克羅地亞

世界杯:英格蘭vs克羅地亞

足球賽事交流解析
2026-06-17 10:00:07
勞力士被指為百年大展55元雇群演:客不好請,表不易賣

勞力士被指為百年大展55元雇群演:客不好請,表不易賣

界面新聞
2026-06-17 11:40:53
美貌大賞!江疏影出席活動,簡約的黑白配很高級,懟臉拍皮膚絕了

美貌大賞!江疏影出席活動,簡約的黑白配很高級,懟臉拍皮膚絕了

東方不敗然多多
2026-06-18 01:17:20
2026-06-18 03:12:51
EEWorld電子工程世界 incentive-icons
EEWorld電子工程世界
即時參與討論電子工程世界最火話題,搶先知曉電子工程業界資訊。
308文章數 27關注度
往期回顧 全部

科技要聞

馬斯克好友長文:他最可怕的,是這套方法論

頭條要聞

荷蘭政府對中國進行無理指責 中使館發聲

頭條要聞

荷蘭政府對中國進行無理指責 中使館發聲

體育要聞

梅西帽子戲法:紀錄厚重,球王輕盈

娛樂要聞

陳紅一反常態保持沉默

財經要聞

拉加德警告:AI可能引爆下一場金融危機

汽車要聞

23.99萬起 比亞迪大唐帶2+2+3大七座掀桌子 這才是中國大家庭夢中情車!

態度原創

房產
旅游
數碼
本地
公開課

房產要聞

最新房價:???、三亞;新房、二手房全線下跌!

旅游要聞

1800余場端午活動打造城市游樂園

數碼要聞

GuliKit推出Switch 2便攜底座 可連電視亦可桌面充電 售價29.99美元

本地新聞

世界杯黑馬佛得角:河北人開超市,溫州人當老板

公開課

李玫瑾:為什么性格比能力更重要?

無障礙瀏覽 進入關懷版