《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 業界動態 > 對 M6 智能健身手環進行逆向工程(上)

對 M6 智能健身手環進行逆向工程(上)

2021-08-02
來源:嘶吼專業版
關鍵詞: 手環 逆向工程

  概述

  1、了解它的硬件

  2、弄清楚如何與它交談

  3、轉儲其庫存固件

  4、讓它運行自定義代碼,最好利用它:

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

  彩色顯示

  藍牙低功耗 (BLE) 功能

  硬件介紹

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

  Telink TLSR8232芯片系統(SoC)

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

  一個約 100 mAh 的微型鋰電池和 USB 充電電路

  振動電機

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

  核心組件

  印刷電路板全圖

  M6中的SoC是Telink TLSR8232(數據表),規格如下:

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

  16kB 的 SRAM;

  512kB 內部閃存;

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

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

  集成藍牙低功耗 (BLE) 收發器;

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

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

  焊盤

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

  印刷電路板底部

  印刷電路板底部

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

  單線(又名 SWire 或 SWS)接口

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

  在Telink-land 中,類似的接口稱為Single Wire 或SWire。這就是應用程序如何加載到其閃存中、如何讀取和寫入內存以及如何在運行時調試的方式。

  然而,當我們嘗試了解有關此界面的更多信息時,真正的挑戰才剛剛開始。在現實世界中,這些芯片是使用Telink官方的調試工具進行調試的。

  研究人員在找到存儲庫 TlsrTools 時,其中有對 SWire 協議的兩頁描述。這似乎是一個舊版本的Telink數據表的一部分,已經被刪除。

  從 Pascal 到 Python

  在編程/調試芯片時,通常有三個活動部分:

  我們要編程的目標板

  程序員硬件

  與程序員通信的計算機軟件

  計算機軟件的作用是向程序員硬件發送命令,并使其從目標板讀寫數據。由于研究人員手邊沒有Windows設備,所以我實現了一個基本的Python腳本,即 tlsr82-debugger-client.py,它作為計算機軟件組件工作。

  我們現在可以使用這個 Python 腳本和 STM32 來解密 M6 手環中隱藏的信息。設置如下:

基于 STM32 的替代編程設置

  SWire 規范

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

  這意味著:

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

  半雙工:每個設備必須知道什么時候應該監聽消息,什么時候允許傳輸消息。

  為了實現協調,SWire 協議將責任歸屬于主盤和附屬設備。主盤負責發起通信并管理數據傳輸之間的總線邏輯層。從盤負責在預期的時間發送數據。下面我將一些真實世界的例子放在一起,以便更清楚地說明這一點。

  發送單個位

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

  要發送 0,請保持 1 個單元的低電壓和 4 個單元的高電壓;

  要發送 1,保持低電壓 4 個單位時間和高電壓 1 個單位;

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

  SWire 中 0 和 1 的示例

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

  發送單個字節

  我們現在知道為了傳輸一個完整的字節,SWire 協議規定需要 9 位:

  位 1:cmd 位。0 指定消息包含數據,1 指定消息是命令;

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

  低級別的一個時間單位表示消息結束;

  另外,讓我們看一下 0xb0 字節的真實示例傳輸:

在 SWire 中發送一個字節的示例

  發送最后一個低級別后,總線被釋放并恢復到其自然高電壓。換句話說,SWire 數據總線被拉高。

  寫入請求

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

  為此,主盤必須發送一個字節序列,每個字節都按照上一節所述進行編碼:

  START字節,這個值總是 0x5a;

  目標addr的最高有效8位;

  目標addr的最低有效8位;

  RW_ID字節,最重要的位應該設置為0,用于寫入操作;

  字節值 b;

  END字節,它的值始終為 0xff;

  讓我們看看下面的例子:

  在 SWire 中寫入數據的示例

  在這個例子中,我們可以看到字節 0x05 被寫入從盤的內存地址 0x0602。

  SWire 協議的變體

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

  寫入多個字節

  這是寫入單個字節要花費的能力,幸運的是,該協議讓我們一次寫入多個數據字節。為此,主盤只需發送一個字節序列,而不是像上面示例中的單個字節。




電子技術圖片.png

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产精品一区二区久久| 91久久精品国产91久久性色tv| 久热成人在线视频| 先锋a资源在线看亚洲| 亚洲午夜激情| 亚洲午夜av| 亚洲少妇在线| 亚洲一区二区三区在线播放| 这里只有精品视频| 亚洲视频一区二区| 亚洲一区欧美二区| 亚洲综合精品| 午夜精品一区二区在线观看| 亚洲在线观看免费| 亚洲欧美一区二区视频| 午夜精品短视频| 性欧美xxxx视频在线观看| 香港成人在线视频| 久久精品中文字幕免费mv| 久久久久久久97| 鲁鲁狠狠狠7777一区二区| 蜜臀久久99精品久久久画质超高清 | 久久午夜电影网| 老司机免费视频一区二区三区| 老牛嫩草一区二区三区日本| 欧美不卡在线| 欧美日韩高清免费| 国产精品久久网站| 国产日韩在线一区| 狠狠色狠狠色综合系列| 亚洲高清在线精品| 99视频在线观看一区三区| 在线一区二区三区做爰视频网站| 亚洲性夜色噜噜噜7777| 欧美一区二区三区免费在线看 | 欧美日韩在线播放一区| 国产精品毛片va一区二区三区| 国产欧美日本一区视频| 悠悠资源网亚洲青| 亚洲免费av观看| 亚洲欧美日韩系列| 亚洲黄色免费| 亚洲小视频在线| 久久国产一区| 欧美激情1区| 国产精品一区久久| 亚洲动漫精品| 中文精品99久久国产香蕉| 午夜精品一区二区三区在线| 亚洲黄页视频免费观看| 亚洲永久免费| 麻豆免费精品视频| 欧美午夜性色大片在线观看| 好吊妞**欧美| 夜夜精品视频一区二区| 亚洲欧美视频在线观看视频| 亚洲精品久久| 欧美专区日韩专区| 欧美国产日本| 国产日韩欧美黄色| 亚洲精品影院在线观看| 欧美一区二区在线看| 日韩一级不卡| 久久精品日韩欧美| 欧美日韩在线大尺度| 精品1区2区| 亚洲永久精品国产| 亚洲另类黄色| 久久精品亚洲| 欧美视频一区二区| 亚洲高清激情| 欧美一区二区三区免费看| 亚洲素人一区二区| 蜜乳av另类精品一区二区| 国产精品女主播在线观看| 亚洲精品欧美专区| 久久精品国亚洲| 午夜精品影院| 欧美日本精品在线| 精品成人在线| 欧美一区二区三区日韩| 亚洲午夜精品一区二区| 男人的天堂亚洲| 国模精品娜娜一二三区| 亚洲一区二区三区免费观看| 99国产精品视频免费观看| 久久综合亚洲社区| 国产欧美日韩亚洲| 在线亚洲自拍| 日韩视频不卡| 久久综合久久88| 国产日韩欧美| 亚洲一线二线三线久久久| 亚洲视频精选在线| 欧美大片网址| 一区二区在线看| 午夜一区二区三视频在线观看| 亚洲影院色无极综合| 欧美日韩亚洲激情| 亚洲精品国产精品国自产观看| 亚洲高清在线精品| 久久久人人人| 国产亚洲激情| 亚洲欧美精品在线观看| 亚洲欧美国产毛片在线| 欧美日韩中文字幕日韩欧美| 亚洲国产精品视频一区| 亚洲国产视频一区| 久久综合999| 狠狠爱www人成狠狠爱综合网 | 午夜精品一区二区三区在线视 | 亚洲高清123| 亚洲电影观看| 久久久久久**毛片大全| 国产一区二区三区久久悠悠色av| 亚洲一区视频在线| 午夜一区二区三区在线观看| 国产精品日韩在线| 亚洲欧美在线观看| 欧美在线免费看| 国产欧美一区二区三区在线看蜜臀| 亚洲免费在线视频| 欧美一区日本一区韩国一区| 国产精品影院在线观看| 午夜精品电影| 久久久夜夜夜| 在线欧美日韩精品| 999亚洲国产精| 欧美日韩一区二区三区四区在线观看| 亚洲理论在线| 亚洲欧美日韩国产另类专区| 国产精品人成在线观看免费| 亚洲制服欧美中文字幕中文字幕| 欧美一区二区三区免费观看| 国产日韩在线亚洲字幕中文| 久久国产婷婷国产香蕉| 欧美成人免费va影院高清| 亚洲精品小视频| 亚洲一区一卡| 国产日韩欧美亚洲一区| 亚洲国产第一| 欧美精品一二三| 中文在线一区| 欧美一区国产一区| 黄色亚洲免费| 夜夜嗨一区二区三区| 国产精品magnet| 亚洲免费视频一区二区| 久久久久国产精品www| 亚洲高清免费在线| 亚洲视频电影在线| 国产日韩综合| 亚洲免费观看视频| 国产精品视频你懂的| 亚洲电影自拍| 欧美日韩国产综合一区二区| 亚洲女人av| 欧美**字幕| 亚洲图片在线观看| 久久久久久夜| 亚洲精品一区二区在线观看| 午夜在线成人av| 亚洲第一中文字幕| 亚洲一区一卡| 精品电影一区| 亚洲伊人伊色伊影伊综合网 | av成人免费观看| 久久免费精品视频| 亚洲精品日韩在线观看| 欧美一级专区免费大片| 亚洲成色精品| 欧美一区二区精美| 亚洲精品乱码久久久久久久久 | 亚洲精品免费一二三区| 羞羞视频在线观看欧美| 在线日韩中文| 欧美一区观看| 亚洲精品三级| 久久一区二区视频| 一本不卡影院| 美腿丝袜亚洲色图| 亚洲免费婷婷| 欧美精品一线| 久久精品视频va| 国产精品久久久久毛片软件| 亚洲激情成人在线| 国产精品日韩欧美一区| 亚洲美女视频| 狠狠色狠色综合曰曰| 亚洲尤物在线| 亚洲国产精品成人综合| 欧美在线高清视频| 99riav国产精品| 欧美成人国产一区二区| 午夜在线播放视频欧美| 欧美日韩日韩| 亚洲精品女人| 韩国在线视频一区| 欧美一区二区三区啪啪| 日韩视频专区|