當前位置:首頁 > 公眾號精選 > 嵌入式微處理器
[導讀]最近,嵌入式ARM分享一篇《GD32也開始假貨泛濫了》文章,嵌入式ARM的老友StrongerHuang也表示其技術交流群正在討論芯片漲價和咸魚上賣芯片的話題,并撰寫了一文揭露了背景和識別翻新假貨的方法。



最近,嵌入式ARM分享一篇GD32也開始假貨泛濫了》文章,嵌入式ARM的老友StrongerHuang也表示其技術交流群正在討論芯片漲價咸魚上賣芯片的話題,并撰寫了一文揭露了背景和識別翻新假貨的方法。特此轉(zhuǎn)載供大家參考。

1 芯片漲價背景
前兩年的中美毛衣戰(zhàn),使國內(nèi)一些技術型大企業(yè)受到了影響,比如華為。但是絕大部分電子相關的企業(yè),受到的影響很小。
2020年,一場疫情,導致了一些半導體企業(yè)受到很大打擊,比如工人罷工。
然后,一些原材料價格開始出現(xiàn)了不同程度的上漲,特別是今年初開始,很多金屬、塑料等絕大部分原材料價格都上漲了,小到電阻電容,大到電視冰箱等消費電子產(chǎn)品,都出現(xiàn)了不同程度的漲價。

(圖片來源網(wǎng)絡,侵刪)


芯片亦如此,我們熟知的MCU價格出現(xiàn)了不同程度的漲價,相信大家都知道了,特別是STM32部分型號價格甚至翻了好幾倍。
在這種漲價潮的背景下,必定存在一些不良商家,然后,出現(xiàn)假貨的概率就增加了。

2

STM32/GD32翻新或假貨
STM32/GD32翻新或假貨這個問題,有經(jīng)驗的工程師可能遇到過,包括我之前就遇到過,把GD32標志擦除,然后搞成STM32,還有從舊板子上拆下來的翻新STM32。
下面就來說說芯片翻新或假貨的一些情況:
1.擦除標志
芯片擦除標志這種做法很常見,包括我們有時候開發(fā)的產(chǎn)品,為了防止別人山寨,也可能將芯片表面的標志擦除,以起到防止被人山寨的作用。
一些商家就會利用這種“貍貓換太子”的手段來牟利,一些兼容的芯片,比如早期我就知道很多STM32就是用GD32假冒的。
2.虛假型號
STM32內(nèi)部Flash實際大小可能與型號不匹配,比如:STM32F103RF標準容量為768K,但Flash實際不止768K。

由此延伸出話題:你的STM32芯片F(xiàn)LASH容量真如ST官方選型手冊那樣嗎?

1先說點其它

一般對于初學者來說,內(nèi)部FLASH完全足夠,跑一個簡單的裸機Demo,或者一個RTOS加上兩個任務的Demo,對于現(xiàn)在的MCU完全沒有壓力。
但是,一旦你接觸到實際項目,你會發(fā)現(xiàn)很多地方都會開支FLASH,而且有些項目占用FLASH還不小。比如:某種特定算法,加載字庫,甚至放兩張圖片在FLASH里面。
再拿一個IAP應用編程的例子來說:一般對升級這個功能做的好一點的,會有一塊區(qū)域(備份區(qū)域)與應用程序差不多大小的FLASH區(qū)域。就是說:為了保證安全,你程序下載保存在一個備份區(qū)域,等下載成功再更新應用程序。 這樣做的目的:就是防止在下載的時候中途掉線,導致失敗
找了一個圖,大致如下,將FLASH劃分為3個區(qū)域(引導程序FLASH區(qū)域、應用程序FLASH區(qū)域、備份程序FLASH區(qū)域),你們琢磨一下。



2STM32芯片選型
一般我們項目提出需求之后,都會選擇一款合適的MCU,首先想到的就是查看【選型手冊】,除了選擇外設資源之外,還有就是選擇適合的FLASH容量大小。STM32產(chǎn)品命令規(guī)則如下:


3驗證STM32內(nèi)部FLASH究竟有多大

說了關于FLASH的一些話題,回來說說本文的重點:我們的STM32內(nèi)部FLASH可能不止上面選型手冊說的那么大一點。
比如:我的MCU芯片具體型號為STM32F103RF,查看手冊可以知道其容量為768K,但實際它有1M的FLASH容量。

我這里大概說兩點簡單驗證的方法:
1.通過編程驗證

簡單來說就是通過擦除,寫入,讀取指定地址(就是超過FLASH大小的地址)。
FLASH_EraseSector
FLASH_ProgramWord
2.通過工具讀取FLASH數(shù)據(jù)
這個辦法是最直接,也是最簡單的辦法。拿STM32 ST-LINK Utility這個下載工具來舉例說明:

重點其實都在圖中描述出來了:超過768K地址,實際上還可以讀出來數(shù)據(jù)的
(上圖是我拿STM32F103RF真實MCU讀出來的,應用程序起始地址就是0x080C0000,應用程序?qū)嶋H也運行起來了)
說了這么多,其實我想說的是:STM32芯片有許多也是類似,不止我上面舉例的STM32F103RF,103RC標稱的是256K,其實不止256K空間。如果你發(fā)現(xiàn)你FLASH空間不足了,通過上面方法可以看看是否不止那么大的空間。
3.翻新為原裝正品 這種在某寶上最常見,那種看起來價格便宜,你零售買幾個也發(fā)貨這種十有八九都是翻新芯片。
翻新芯片,你買回來,可能寫一個LED流水燈測試一下沒有問題。但是,你上項目之后,特別是要求外設比較多,功能又復雜一點的項目,可能很快就原形畢露了。
運氣不好,可能會出現(xiàn)以下幾種情況:
  • 軟件通宵加班數(shù)日無果,甩鍋硬件;
  • 硬件飛線各種測試,換一塊芯片解決問題;
  • 軟件和硬件工程師干一架;

······
所以,現(xiàn)在市面上出現(xiàn)很多假貨,或者有問題的芯片不足為奇,包括嵌入式ARM說的“GD32也開始假貨泛濫了”,我覺得肯定存在。

3 識別翻新或假貨

識別STM32/GD32翻新或假貨,常規(guī)的操作就是先焊接在PCB板(或在工裝夾具),上電看是否正常,如果出現(xiàn)發(fā)燙、電流過大、甚至冒煙等情況,要注意了。
然后讀取一下芯片信息,比如Flash容量,UID信息、選項字節(jié)等。
這里分享之前的文章:關于STM32的這幾個寄存器,你知道嗎?
讀取的具體方式如下:

1Flash容量寄存器

1.通過讀寄存器
在STM32的“參考手冊”中有Flash size data register這么一個寄存器(一般在手冊最后),明確寫了寄存器的基地址。
提示:不同芯片型號,可能這個寄存器地址不同。比如F103的基地址為:0x1FFFF7E0。


是一個16位的數(shù)值,出廠寫入,程序只能讀取。讀取方法很簡單,可以如下:
uint16_t Flash_size;
Flash_size = *(uint16_t *)0x1FFFF7E0;
2.通過STM32 ST-LINK Utility直接讀取
通過ST-Link連接芯片,直接讀取,可以看到容量信息:

2UID寄存器
之前有人問我,可以通過STM32的UID來加密嗎? 這個肯定是可以的。
但又問了我一個問題,我不希望讀取全部(96位),可以只讀取部分寄存器來作為標識嗎?讀取的部分會不會重復?
STM32的UID唯一標識符適用于
  • 用來作為序列號。
  • 用來作為密碼,在編寫閃存時,將此唯一標識與軟件加解密算法結合使用,提高代碼在閃存存儲器內(nèi)的安全性。
  • 用來激活帶安全機制的自舉過程。
STM32的UID共有96位(32 x 3)。所有,就有朋友,我是否可以只讀取其中某一部分來作為唯一識別?
這個問題,嚴格來說,不可以。但如果不是特別嚴格,還是可以。因為這個UID是通過晶元、分批等來進行編號的。如果你買同一批次,你會發(fā)現(xiàn)那個編號可能連續(xù)。


我之前曾讀取過幾塊生產(chǎn)的板卡(購買得_MCU是同一批次),芯片的UID是連續(xù)的,感興趣的可以試試。

所以,通過讀取部分UID來作為標識,只能說不嚴格的情況是可以的。

3 寄存器偏移地址

現(xiàn)在還有許多初學的朋友在學習底層的一些知識,比如前面就有朋友想自己通過寄存器來編程,但是卻不知道什么是寄存器基地址,什么是寄存器偏移地址。
1.基地址
每一個片內(nèi)外設都有一個對應的基地址,而且是由廠商決定我們不能修改。如下圖:

在程序中,你會發(fā)現(xiàn)和上面對應的代碼:

2.偏移地址
偏移地址就是在基地址基礎上偏移(一般是以4字節(jié)增加),比如TIM定時器的偏移地址:

同樣,在程序中對應的代碼通過結構體實現(xiàn)偏移:

關于基地址和偏移地址,不管是標準外設庫還是HAL庫,都是上面所示那種基地址+偏移的方法實現(xiàn)。
還是之前多次在文章中提到的,想要了解寄存器原理,或者通過寄存器來實現(xiàn)的朋友,最好參考“標準外設庫”例程。HAL庫封裝的相對復雜,不適合研究最底層寄存器。
再進一步驗證,寫入數(shù)據(jù)(RAM、Flash)測試、各種外設基本功能測試等。

4 建議正規(guī)渠道

買到假貨或山寨貨,付出的代價是很大的,前期開發(fā)階段現(xiàn)了問題都還好,就怕批量生產(chǎn)之后才發(fā)現(xiàn)問題。
更可怕的是,大批量出貨,產(chǎn)品在客戶手里因為芯片假貨出現(xiàn)問題的情況。
今天交流群里有人在討論咸魚上賣芯片的情況,我覺得,咸魚買芯片來玩玩可以,做產(chǎn)品最好慎重。
比如淘寶搜出來十多元的STM32還是進口原裝正品,你信嗎?

正規(guī)渠道買的芯片,都還存在一定概率是芯片自身的問題,更別說咸魚這種平臺了。 我之前就遇到過,從正規(guī)且比較大的代理商買的STM32,出現(xiàn)了問題,F(xiàn)AE多次到公司都沒找出問題,最后拿回原廠解剖芯片,發(fā)現(xiàn)真的是芯片自身的問題。
所以,不要因為便宜就從淘寶、咸魚上購買芯片,建議走正規(guī)渠道。否則,可能會付出很大代價。

END

來源:StrongerHuang,作者:StrongerHuang
版權歸原作者所有,如有侵權,請聯(lián)系刪除。





免責聲明:本文內(nèi)容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!


嵌入式ARM

掃描二維碼,關注更多精彩內(nèi)容

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉