Android5.0L下因sensorservice crash導致systemserver重啟的另外一種情境分析,android5.0

來源:互聯網
上載者:User

Android5.0L下因sensorservice crash導致systemserver重啟的另外一種情境分析,android5.0

一、出問題的情境

1、Sensorservice線程正在處理compass sensor事件的過程中,檢查了一次buffer的指標的有效性,並在稍後會傳遞到AKM擷取資料的函數介面中使用

2、Sensorservice線程所在進程的負責跨進程通訊的Binder線程在sensorservice線程檢查buffer指標之後沒有真正使用之前,

收到了disable compass sensor的請求,從log中可以看到compass  sensor先是被disable,disable的同時會free上面sensorservice檢查過並正在使用的buffer指標,同時置空buffer指標

3、緊接著sensorservice線程繼續執行AKM擷取資料的函數介面,並使用到了已經被disable置空的buffer指標,然後產生異常


二、具體log和代碼

Disable compass sensor並free buffer的代碼:

Free buffer 3ms之後sensorservice馬上因為訪問null 指標異常的log:

 傳遞buffer指標並使用的代碼:

   使用buffer指標產生異常的地方log:

著作權聲明:本文為博主原創文章,未經博主允許不得轉載。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.