《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 通信與網(wǎng)絡(luò) > 業(yè)界動(dòng)態(tài) > 對(duì) M6 智能健身手環(huán)進(jìn)行逆向工程(上)

對(duì) M6 智能健身手環(huán)進(jìn)行逆向工程(上)

2021-08-02
來源:嘶吼專業(yè)版
關(guān)鍵詞: 手環(huán) 逆向工程

  概述

  1、了解它的硬件

  2、弄清楚如何與它交談

  3、轉(zhuǎn)儲(chǔ)其庫存固件

  4、讓它運(yùn)行自定義代碼,最好利用它:

  GPIO 引腳(用于輸入和輸出)

  彩色顯示

  藍(lán)牙低功耗 (BLE) 功能

  硬件介紹

  拆開塑料外殼,我們看到了一些有趣的東西:

  Telink TLSR8232芯片系統(tǒng)(SoC)

  0.96 英寸(160x80 像素)彩色顯示屏

  一個(gè)約 100 mAh 的微型鋰電池和 USB 充電電路

  振動(dòng)電機(jī)

  一個(gè)(最有可能的)假心率傳感器

  核心組件

  印刷電路板全圖

  M6中的SoC是Telink TLSR8232(數(shù)據(jù)表),規(guī)格如下:

  32位中央處理器:封閉式架構(gòu)(通常稱為tc32,類似于ARM9,關(guān)于它的介紹并不多)和24 MHz 時(shí)鐘速度;

  16kB 的 SRAM;

  512kB 內(nèi)部閃存;

  用于低功耗模式的 32kHz 板載振蕩器;

  用于調(diào)試和編程的 SWS(Single Wire Slave)接口;

  集成藍(lán)牙低功耗 (BLE) 收發(fā)器;

  低功耗運(yùn)行(據(jù)稱在深度睡眠中約為 2 uA);

  幸運(yùn)的是,就在幾個(gè)月前,研究人員在其破解的小米溫度計(jì)中看到了Telink芯片。此時(shí),我用@atc1441 的替代固件重新刷了它。盡管它是不同的 SoC 模型,但這給了我一點(diǎn)希望和一個(gè)有價(jià)值的起點(diǎn)。

  焊盤

  焊盤 (Exposed-Pad),有些封裝具有裸露焊盤,用來改善器件散熱的焊盤。通常為非電氣絕緣,可根據(jù)電連接要求將其接地或電源。

  印刷電路板底部

  印刷電路板底部

  除了萬用表、數(shù)據(jù)表,我什么也沒有,我試圖找到這些焊盤的連接位置。這就是我想出的:

  單線(又名 SWire 或 SWS)接口

  現(xiàn)在我們確定了手環(huán)的核心部件,如果你之前對(duì) ESP32 進(jìn)行過編程,你可能會(huì)依賴其引導(dǎo)加載程序并通過 UART 與它通信。如果你之前編程或調(diào)試過 ARM 微控制器,你可能使用了 SWD(串行線調(diào)試)協(xié)議。

  在Telink-land 中,類似的接口稱為Single Wire 或SWire。這就是應(yīng)用程序如何加載到其閃存中、如何讀取和寫入內(nèi)存以及如何在運(yùn)行時(shí)調(diào)試的方式。

  然而,當(dāng)我們嘗試了解有關(guān)此界面的更多信息時(shí),真正的挑戰(zhàn)才剛剛開始。在現(xiàn)實(shí)世界中,這些芯片是使用Telink官方的調(diào)試工具進(jìn)行調(diào)試的。

  研究人員在找到存儲(chǔ)庫 TlsrTools 時(shí),其中有對(duì) SWire 協(xié)議的兩頁描述。這似乎是一個(gè)舊版本的Telink數(shù)據(jù)表的一部分,已經(jīng)被刪除。

  從 Pascal 到 Python

  在編程/調(diào)試芯片時(shí),通常有三個(gè)活動(dòng)部分:

  我們要編程的目標(biāo)板

  程序員硬件

  與程序員通信的計(jì)算機(jī)軟件

  計(jì)算機(jī)軟件的作用是向程序員硬件發(fā)送命令,并使其從目標(biāo)板讀寫數(shù)據(jù)。由于研究人員手邊沒有Windows設(shè)備,所以我實(shí)現(xiàn)了一個(gè)基本的Python腳本,即 tlsr82-debugger-client.py,它作為計(jì)算機(jī)軟件組件工作。

  我們現(xiàn)在可以使用這個(gè) Python 腳本和 STM32 來解密 M6 手環(huán)中隱藏的信息。設(shè)置如下:

基于 STM32 的替代編程設(shè)置

  SWire 規(guī)范

  顧名思義,單線用于在兩個(gè)設(shè)備之間來回傳輸數(shù)據(jù)。在我們的例子中,STM32 編程器(主)和目標(biāo)板(附屬)。沒有像 SPI 或 I2C 那樣單獨(dú)的時(shí)鐘線。單線拓?fù)湓试S兩個(gè)設(shè)備通信,但它們不能同時(shí)通信。換句話說,我們可以將 SWire 稱為異步、半雙工接口。

  這意味著:

  異步:由于沒有共享時(shí)鐘,兩個(gè)設(shè)備必須以某種方式采用兼容的讀寫速度;

  半雙工:每個(gè)設(shè)備必須知道什么時(shí)候應(yīng)該監(jiān)聽消息,什么時(shí)候允許傳輸消息。

  為了實(shí)現(xiàn)協(xié)調(diào),SWire 協(xié)議將責(zé)任歸屬于主盤和附屬設(shè)備。主盤負(fù)責(zé)發(fā)起通信并管理數(shù)據(jù)傳輸之間的總線邏輯層。從盤負(fù)責(zé)在預(yù)期的時(shí)間發(fā)送數(shù)據(jù)。下面我將一些真實(shí)世界的例子放在一起,以便更清楚地說明這一點(diǎn)。

  發(fā)送單個(gè)位

  首先要注意的是位是如何在線路中編碼的。每個(gè)位以五個(gè)時(shí)間單位傳輸:

  要發(fā)送 0,請(qǐng)保持 1 個(gè)單元的低電壓和 4 個(gè)單元的高電壓;

  要發(fā)送 1,保持低電壓 4 個(gè)單位時(shí)間和高電壓 1 個(gè)單位;

  具體來說,這是我用邏輯分析儀捕獲的真實(shí) SWire 傳輸:

  SWire 中 0 和 1 的示例

  在上面的截圖中,標(biāo)記為 25 和 26 的標(biāo)志之間有 8 位正在傳輸,但是很難解碼。

  發(fā)送單個(gè)字節(jié)

  我們現(xiàn)在知道為了傳輸一個(gè)完整的字節(jié),SWire 協(xié)議規(guī)定需要 9 位:

  位 1:cmd 位。0 指定消息包含數(shù)據(jù),1 指定消息是命令;

  位 2-8:消息內(nèi)容(8 位);

  低級(jí)別的一個(gè)時(shí)間單位表示消息結(jié)束;

  另外,讓我們看一下 0xb0 字節(jié)的真實(shí)示例傳輸:

在 SWire 中發(fā)送一個(gè)字節(jié)的示例

  發(fā)送最后一個(gè)低級(jí)別后,總線被釋放并恢復(fù)到其自然高電壓。換句話說,SWire 數(shù)據(jù)總線被拉高。

  寫入請(qǐng)求

  如上所述,單個(gè)位和字節(jié)是如何在線路中編碼的。接下來,我們來看看SWire協(xié)議是如何指定要寫入特定地址的字節(jié)的。在該示例中,主盤希望將一個(gè)字節(jié)b寫入從盤內(nèi)存中的地址addr。

  為此,主盤必須發(fā)送一個(gè)字節(jié)序列,每個(gè)字節(jié)都按照上一節(jié)所述進(jìn)行編碼:

  START字節(jié),這個(gè)值總是 0x5a;

  目標(biāo)addr的最高有效8位;

  目標(biāo)addr的最低有效8位;

  RW_ID字節(jié),最重要的位應(yīng)該設(shè)置為0,用于寫入操作;

  字節(jié)值 b;

  END字節(jié),它的值始終為 0xff;

  讓我們看看下面的例子:

  在 SWire 中寫入數(shù)據(jù)的示例

  在這個(gè)例子中,我們可以看到字節(jié) 0x05 被寫入從盤的內(nèi)存地址 0x0602。

  SWire 協(xié)議的變體

  值得注意的是,至少存在一個(gè)SWire協(xié)議的變體。在另一種變體中,主盤在 START 字節(jié)之后發(fā)送 3 個(gè)字節(jié)的 addr,而不是在我們的 SWire 協(xié)議中僅發(fā)送兩個(gè)字節(jié)。例如,Telink 的 TLSR8251 SoC 中采用了 3 字節(jié)變體,用于我們上面提到的小米溫度計(jì)。在 ATC_MiThermometer 存儲(chǔ)庫中基于 Python 的閃光器中,我們可以看到在從主盤到從盤的讀/寫請(qǐng)求中指定了 3 個(gè)字節(jié)的 addr。

  寫入多個(gè)字節(jié)

  這是寫入單個(gè)字節(jié)要花費(fèi)的能力,幸運(yùn)的是,該協(xié)議讓我們一次寫入多個(gè)數(shù)據(jù)字節(jié)。為此,主盤只需發(fā)送一個(gè)字節(jié)序列,而不是像上面示例中的單個(gè)字節(jié)。




電子技術(shù)圖片.png

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請(qǐng)及時(shí)通過電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美日韩国产精品一区二区亚洲| 国产欧美精品一区| 午夜免费在线观看精品视频| 99视频精品在线| 亚洲黄色性网站| 久久精品国产亚洲5555| 欧美与欧洲交xxxx免费观看| 午夜久久久久| 午夜久久黄色| 久久成人18免费观看| 欧美一区免费视频| 欧美中文在线免费| 久久精品一区四区| 亚洲黄色在线看| 亚洲欧洲日本在线| 亚洲日本欧美在线| 亚洲精品乱码久久久久久久久| 亚洲人成网站精品片在线观看 | 亚洲国产日韩欧美在线图片| 亚洲国产精品久久久久秋霞影院 | 免费人成网站在线观看欧美高清| 六月丁香综合| 欧美成人午夜激情| 欧美日韩伦理在线免费| 国产精品久久激情| 国产日韩欧美中文| 在线日韩日本国产亚洲| 亚洲精品视频在线观看网站 | 亚洲午夜视频在线观看| 午夜精品一区二区三区四区 | 亚洲国产高潮在线观看| 亚洲久久成人| 亚洲一区二区三区激情| 香蕉免费一区二区三区在线观看| 久久se精品一区精品二区| 久久人人超碰| 欧美精品日韩一本| 国产精品免费一区二区三区观看| 国产欧美日本| 亚洲丰满在线| 一区二区日韩| 久久精品久久99精品久久| 亚洲精品视频在线播放| 亚洲欧美色婷婷| 久久中文欧美| 欧美日韩一区在线播放| 国产区二精品视| 亚洲国产一区二区三区高清| 亚洲视频第一页| 小黄鸭精品aⅴ导航网站入口| 亚洲高清一二三区| 亚洲一区二区三区视频播放| 久久久久久久久久久成人| 欧美精品久久久久久久免费观看 | 欧美日韩国产欧美日美国产精品| 国产精品视频九色porn| 亚洲第一精品夜夜躁人人爽| 亚洲无毛电影| 亚洲激情自拍| 欧美亚洲专区| 欧美精品一区二区三区蜜桃| 国产精品一区二区在线| 亚洲精品久久久久| 欧美中在线观看| 亚洲尤物在线| 欧美va天堂va视频va在线| 国产精品乱子乱xxxx| 亚洲国产婷婷| 欧美影院午夜播放| 亚洲一区二区免费视频| 久久影院亚洲| 国产精品美女午夜av| 亚洲国产一区二区三区青草影视 | 欧美体内she精视频在线观看| 狠狠综合久久av一区二区小说| 一卡二卡3卡四卡高清精品视频| 久久精品一本| 欧美一二区视频| 欧美日韩免费看| 亚洲高清在线观看一区| 欧美一区二区三区在线观看| 一区二区三区福利| 免费看黄裸体一级大秀欧美| 国产欧美日韩亚洲一区二区三区 | 亚洲在线国产日韩欧美| 欧美激情视频在线免费观看 欧美视频免费一| 国产精品视频免费观看| 亚洲精品视频一区二区三区| 亚洲国产免费| 久久久久国产一区二区三区| 国产精品亚洲产品| 在线视频精品一区| 99精品国产高清一区二区| 乱中年女人伦av一区二区| 国产一区999| 亚洲欧美一区在线| 亚洲欧美国产77777| 欧美视频在线一区| 日韩亚洲欧美综合| 日韩网站在线观看| 欧美国产日韩精品| 亚洲狠狠婷婷| 亚洲精品乱码久久久久久蜜桃麻豆| 久久人人看视频| 国语自产精品视频在线看抢先版结局| 亚洲在线观看免费| 亚洲欧美在线磁力| 国产精品乱子久久久久| 亚洲午夜精品17c| 亚洲欧美美女| 国产精品久久久久久久午夜| 一区二区激情小说| 亚洲小说区图片区| 欧美午夜精品久久久久免费视| 日韩午夜免费| 亚洲特级片在线| 欧美午夜久久久| 在线亚洲成人| 最新国产成人av网站网址麻豆| 激情综合网址| 久久国产精品一区二区三区四区 | 欧美日韩激情网| 日韩视频中文字幕| 99这里只有久久精品视频| 欧美激情一二区| 日韩视频在线观看国产| 亚洲无吗在线| 国产精品嫩草影院av蜜臀| 亚洲午夜精品久久久久久浪潮 | 国产在线日韩| 亚洲国产精品久久久久秋霞影院| 老鸭窝91久久精品色噜噜导演| 伊人久久噜噜噜躁狠狠躁| 亚洲欧洲三级| 欧美日韩精品免费观看| 中日韩男男gay无套| 午夜精品久久久久久| 国产日韩欧美中文| 亚洲国产专区| 欧美日韩国产成人| 亚洲少妇中出一区| 久久精品国产精品亚洲精品| 狠狠久久综合婷婷不卡| 亚洲欧洲日韩综合二区| 欧美日韩国产欧美日美国产精品| 一区二区三区精品| 久久精品一区二区| 亚洲国产福利在线| 亚洲影院在线| 韩国三级在线一区| 亚洲美女在线看| 欧美视频官网| 欧美亚洲色图校园春色| 麻豆精品传媒视频| 99视频精品全部免费在线| 欧美在线亚洲综合一区| 在线免费高清一区二区三区| 在线亚洲伦理| 国产午夜精品理论片a级探花| 亚洲高清不卡av| 欧美日韩国产亚洲一区| 亚洲欧美日韩一区二区在线 | 国产欧美日韩亚洲精品| 亚洲欧洲综合另类在线| 欧美午夜精品久久久久免费视 | 亚洲国产视频直播| 午夜视频久久久| 在线观看日韩av先锋影音电影院| 亚洲桃花岛网站| 激情成人亚洲| 亚洲永久免费| 亚洲高清不卡av| 性8sex亚洲区入口| 亚洲国产日韩欧美综合久久| 欧美一级免费视频| 亚洲人成网站999久久久综合| 香蕉国产精品偷在线观看不卡| 在线日韩欧美视频| 欧美中文字幕| 日韩视频免费在线观看| 久久综合九色99| 亚洲视频视频在线| 欧美福利视频在线| 午夜一区二区三区在线观看| 欧美日韩精品是欧美日韩精品| 欧美与欧洲交xxxx免费观看| 欧美四级在线观看| 亚洲精品乱码久久久久久| 国产日韩精品综合网站| 在线视频精品一| 在线观看91久久久久久| 欧美一级成年大片在线观看| 亚洲精品偷拍| 麻豆av一区二区三区久久| 亚洲一区二区三区午夜| 欧美日韩裸体免费视频| 亚洲人成毛片在线播放女女| 国产一区二区在线观看免费播放 | 99爱精品视频| 亚洲大胆女人|