《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 其他 > Linux教學——探討內核代碼

Linux教學——探討內核代碼

2022-08-18
來源:電子技術應用專欄作家 嵌入式Linux
關鍵詞: 內核代碼

  最近因為要解決一個bug,需要在內核的f_hid.c里面做一些適配,需要把這部分代碼研究透徹。

  在這幾天之前我是根本不知道什么是In端點,Out端點,以及什么是endpoint 0的,而且最近的一段時間,我一直是在寫應用方面的代碼,也是趁著這個機會,好好拜讀這部分。

  ——

  在HID 1.0之前,是沒有什么OUT 端點的,都是用端點0來進行數據傳輸,不過端點0有一個問題,他的最大傳輸包的大小有限制。

  微信圖片_20220818152226.jpg

  謝謝我飛哥給的截圖

  之后,就有一個大佬在原來的內核代碼上面做了一部分修改,在原來的enpoint 0 上加了一個OUT端點,意思就是說,本來從深圳到廣州有綠皮火車,但是綠皮火車一次只能裝下20個人,有一個人就發明了高鐵,高鐵一次可以裝200個人。

  這個提交的鏈接

  https://github.com/torvalds/linux/commit/99c515005857ff7d6cd5c2ba272ccab5dc0ea648

  微信圖片_20220818152245.png

  這個修改的commit里面說明了修改的原因,比如說使用端點0不能同步到字符設備,而且端點0的使用可能會導致數據丟失,所以加了一個OUT interrupt endpoint接口。

  重點來了

  并且這個補丁還會繼續處理SET_REPORT  接口請求事件。

  ——

  好了,上面是這個文件的第一次修改,我們的代碼里面也是用的原廠的SDK代碼修改,但是這個修改有一個問題,實際上端點0的SET REPORT并沒有正確請求,這是一個問題,但是這個問題不是Linux 代碼的問題,應該是芯片原廠移植過來后出現的問題。

  之后,又有一個大佬重新對這個內核代碼進行了改造

  提交的commit鏈接如下

  https://github.com/torvalds/linux/commit/d7428bc26fc767942c38d74b80299bcd4f01e7cb

  他的修改的主要是增加了配置選項,就是可以軟件配置使用OUT endpoint還是端點0,這主要是不同的產品定義可能需求會不同。

  這個改造的原因是什么呢?

  微信圖片_20220818152314.png

  有些主機設備,我們說的主機指的是USB的HOST設備,它不支持OUT endpoint 。

  還有一些蘋果產品,他們天然就不能使用OUT端點來傳輸。

  其他巴拉巴拉的一些大家就自己看吧。

  ——

  截圖給大家看看什么是端點0和OUT endpoint

  微信圖片_20220818152333.jpg

  ——

  寫了很多,還沒有說到我要改造什么,其實就是對這部分機制熟悉了,要修改掉因為SET REPORT導致的一個bug。

  這也是一些看代碼的思路吧,內核是分成很多很多模塊的,大家想看哪些模塊,去看看commit,去看看代碼,其實挺有意思的。

  不過里面的一些命名并不是很清晰明了,比如IN這個東西,太簡潔了,不是做USB的人估計很難明白,這些還有,要是去調試HID描述符,就知道那是太要繞腦子了。

  ——問題是什么?

  還是從HID來說,上面留言說的沒問題,USB嘛,不就是一個發送,一個接口,設備到主機通過in端口,這個沒問題。

  在HID低版本的時候用的是endpoint 0端口,也不能說是低版本,即使在高版本,也是可以用endpoint 0端口的「不同之處在于低版本只有endpoint 0」,我也拿了一些競品的產品來看,他們也是可以通過endpoint 0來發送信息給設備端的。

  問題是,我們用的RK方案打開了out端點后不可以。

  其他產品在打開out端口的時候,也是可以用endpoint 0 發送數據到設備的。

  為什么我揪著這個endpoint 0發送呢?

  是因為測試發現通過這個端口可以使用set report 函數,用這個函數來發送消息不會出現偶發的超時問題。

  RK是怎么回復的呢?

  他們說他們提供的方案是用endpoint 0的,都不會有問題。

  而且看了內核代碼,確實是配置想用哪個就用哪個,用戶自己選擇,用了out ,endpoint 0 就用不了了。

  微信圖片_20220819154823.png

  人家代碼也是寫得很清楚了,就是更子的。

  ——那我們為什么不直接用RK的方案,直接用endpoint 0 就好了

  直接用endpoint 0我在之前的文章也說了,這樣就可以兼容MAC的電腦,也不會出現一些亂七八糟可能性的問題。

  但是問題是,我們的應用程序開發的很多功能,都已經實現,都是用的out端點,包的長度也是1024, 這方案一搞下去,那所有人都要重寫代碼,重新測試了。

  微信圖片_20220819154851.png

  —— 后面怎么修改了?

  因為如果加上

  微信圖片_20220819154911.png

  設備是可以調用HOST的setreport接口的,我要做的,無非就是在這里判斷下數據指令,然后傳給應用程序就好了。

  問題就出在這里,usb的一些結構體,如果沒有好好寫,就可能影響到系統的東西。

  OUT端點寫入數據的時候,是直接用到req結構體的

  微信圖片_20220819154931.png

  這段代碼在out端點接收沒有問題,但是放到setreport部分來處理就出現了問題。

  setreport的處理不一樣

  他給HOST來的數據在內核重新分配了空間。

  微信圖片_20220819154949.png

  然后就針對這些不同的邏輯修改修改。

  細節就不說了

  內核代碼不像應用代碼,應用的調試是比較方便的,內核的調試涉及硬件設備就不同了,而且接口的處理也會不同,稍不注意引起的空指針問題,整個系統就掛了,應用還可以用守護進程拉起來,內核就不行,只能重啟。

  不過內核都是C,看起來還是比較舒服的。


    更多信息可以來這里獲取==>>電子技術應用-AET<<

微信圖片_20210517164139.jpg

微信圖片_20220706154608.jpg

電子技術應用專欄作家  嵌入式Linux

原文鏈接:https://mp.weixin.qq.com/s/humym3KbZsEzT2XSi-texw

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
西瓜成人精品人成网站| 亚洲免费观看高清完整版在线观看熊 | 欧美日韩一区二| 性一交一乱一区二区洋洋av| 99精品热视频| 99pao成人国产永久免费视频| 中日韩男男gay无套| 99精品视频免费观看| 亚洲精品一二| 亚洲毛片一区| 日韩亚洲精品在线| 精品电影在线观看| 国内揄拍国内精品少妇国语| 国产亚洲高清视频| 国产一区二区高清不卡| 欧美人交a欧美精品| 欧美高清一区| 欧美精彩视频一区二区三区| 欧美激情在线免费观看| 欧美激情影音先锋| 欧美日韩亚洲综合在线| 欧美日韩视频在线观看一区二区三区| 久久精品视频播放| 久久精品国产第一区二区三区| 亚洲精品一区二区三区婷婷月| 亚洲综合国产激情另类一区| 亚洲午夜精品| 午夜精品久久久久久久99樱桃| 亚洲日本在线视频观看| 日韩网站在线观看| 亚洲国产高清高潮精品美女| 亚洲欧洲另类国产综合| 日韩视频精品在线| 亚洲视频电影在线| 亚洲欧美日产图| 久久激情网站| 午夜精品在线看| 亚洲第一综合天堂另类专| 亚洲影院污污.| 午夜综合激情| 亚洲日韩成人| 亚洲天堂视频在线观看| 欧美一级在线视频| 免费观看在线综合| 欧美三区美女| 欧美日韩一卡二卡| 国产精品网站视频| 在线观看日韩专区| aa成人免费视频| 欧美专区在线观看一区| 亚洲精品四区| 亚洲欧美色一区| 另类成人小视频在线| 久久久久久夜精品精品免费| 麻豆成人在线| 欧美视频在线观看免费| 国产自产2019最新不卡| 亚洲精品黄色| 欧美一区激情视频在线观看| 亚洲人午夜精品免费| 亚洲国产精品欧美一二99| 亚洲美女诱惑| 久久精品国产久精国产一老狼| 欧美自拍偷拍| 欧美精品三级在线观看| 国产精品任我爽爆在线播放| 有码中文亚洲精品| 亚洲视频香蕉人妖| 亚洲国产三级网| 午夜天堂精品久久久久| 欧美成人自拍| 国产日本精品| 亚洲理论电影网| 久久精品视频99| 亚洲性线免费观看视频成熟| 久久综合国产精品台湾中文娱乐网| 久久网站热最新地址| 欧美日韩一区二区三| 国产精品久久国产三级国电话系列 | 国外视频精品毛片| 99re热精品| 亚洲激情视频在线| 欧美一区二区观看视频| 欧美日韩亚洲网| 亚洲第一综合天堂另类专| 亚洲经典在线看| 久久激情视频久久| 亚洲欧美成人一区二区在线电影| 欧美一区二区免费观在线| 久久露脸国产精品| 国产精品久久毛片a| 亚洲欧洲日产国产综合网| 99国产一区二区三精品乱码| 亚洲国产日韩欧美一区二区三区| 亚洲美女在线一区| 久久综合狠狠综合久久综合88| 欧美人在线视频| 一区二区亚洲| 欧美一区观看| 欧美资源在线观看| 国产精品尤物福利片在线观看| 激情av一区二区| 午夜精品久久久| 午夜精彩视频在线观看不卡 | 欧美成人性生活| 国产一区二区高清视频| 亚洲欧美国产视频| 亚洲免费婷婷| 欧美日韩在线视频一区| 91久久久久| 亚洲精品免费在线观看| 免费成人av在线| 精品88久久久久88久久久| 欧美在线资源| 久久久久免费视频| 欧美日韩黄色一区二区| 尤物在线观看一区| 亚洲国产高清在线| 亚洲香蕉成视频在线观看| 欧美日韩国产成人在线| 91久久综合| 日韩特黄影片| 欧美精品在线免费| 亚洲人成亚洲人成在线观看| 亚洲精品小视频在线观看| 欧美高清视频www夜色资源网| 国产精品青草综合久久久久99| 亚洲第一精品福利| 91久久精品久久国产性色也91| 性欧美8khd高清极品| 国产欧美精品一区aⅴ影院| 亚洲欧美日韩系列| 久久精品视频在线播放| 激情久久一区| 亚洲激情中文1区| 欧美精品一区二区三| 亚洲精品免费看| 亚洲色图在线视频| 国产精品视频在线观看| 亚洲欧美日韩国产中文在线| 99热精品在线| 欧美日韩一区视频| 91久久精品美女| 99成人在线| 国产精品美女久久久久久2018| 亚洲三级免费电影| 一区二区三区国产在线观看| 欧美日韩在线播| 亚洲欧美日韩精品| 老司机午夜精品视频在线观看| 国产亚洲观看| 91久久久在线| 欧美日韩亚洲视频一区| 亚洲男女自偷自拍图片另类| 久久久伊人欧美| 亚洲精品一区二区三区蜜桃久| 亚洲国产欧美久久| 久久久精品一品道一区| 精品成人在线| 亚洲午夜精品17c| 国产亚洲a∨片在线观看| 亚洲精品乱码久久久久久蜜桃麻豆| 久久中文久久字幕| 91久久国产自产拍夜夜嗨| 亚洲影院在线| 国语自产精品视频在线看8查询8| 篠田优中文在线播放第一区| 久久午夜精品| 一区二区电影免费在线观看| 久久久久久91香蕉国产| 亚洲精品乱码久久久久久黑人| 亚洲精品中文字| 国产精品普通话对白| 亚洲日本免费| 国产精品一区二区久久精品| 亚洲私人黄色宅男| 免费中文字幕日韩欧美| 午夜久久tv| 精品不卡一区| 亚洲综合久久久久| 在线免费高清一区二区三区| 亚洲一区二区三区精品在线| 国产亚洲综合在线| 中文在线资源观看视频网站免费不卡| 欧美激情视频在线免费观看 欧美视频免费一 | 性欧美办公室18xxxxhd| 欧美激情亚洲一区| 小处雏高清一区二区三区| 欧美好吊妞视频| 欧美一区国产一区| 国产精品v日韩精品| 亚洲国产精品嫩草影院| 国产精品亚洲精品| 日韩亚洲欧美精品| 韩日精品在线| 欧美亚洲色图校园春色| 亚洲人在线视频| 国产精品狼人久久影院观看方式| 亚洲一区二区三区国产| 欧美日韩国产美女|