2014/09/24

Android 無法辨識 USB 裝置 (adb失效, 也偵測不到android手機或平板)

如果你的電腦 Windows或Linux 無法辨識Android USB裝置
也就是 adb失效, 而且偵測不到android手機或平板

 
(引用自Android developer)

USB Vendor IDs

This table provides a reference to the vendor IDs needed in order to add USB device support.

CompanyUSB Vendor ID
Acer0502
ASUS0b05
Dell413c
Foxconn0489
Fujitsu04c5
Fujitsu Toshiba04c5
Garmin-Asus091e
Google18d1
Haier201E
Hisense109b
HTC0bb4
Huawei12d1
Intel8087
K-Touch24e3
KT Tech2116
Kyocera0482
Lenovo17ef
LG1004
Motorola22b8
MTK0e8d
NEC0409
Nook2080
Nvidia0955
OTGV2257
Pantech10a9
Pegatron1d4d
Philips0471
PMC-Sierra04da
Qualcomm05c6
SK Telesys1f53
Samsung04e8
Sharp04dd
Sony054c
Sony Ericsson0fce
Sony Mobile Communications0fce
Teleepoch2340
Toshiba0930
ZTE19d2

可能是因為你的裝置VID並不在Google Vendor群裡面,
那就來手動將VID加入你的電腦裡面吧

Windows:

1. 先找出VID (Windows可以看裝置管理員裡,該裝置的硬體識別碼)
2. 建立目錄 C:\Users\YOUR_NAME\.android
3. 進入目錄後建立文字檔 adb_usb.ini 內容直接填寫Android裝置的VID (ex. 0x5566)

Linux:

1. 先找出VID (Linux可以看/sys/bus/usb/devices/ 以下的目錄, 可以找出新出現的目錄, 再去看idVendor內容即為VID )
2. 建立目錄 /home/YOUR_NAME/.android
3. 進入目錄後建立文字檔 adb_usb.ini 內容直接填寫Android裝置的VID (ex. 0x5566)

參考:
1. 書劍長風: Android USB VID PID 及 ADB
2. phonesdevelopers: Android USB VID PID and ADB
3. developer.android: USB Vendor IDs

2014/09/23

轉錄介紹- 什麼是Android Wi-Fi Display(Miracast)

先說這篇是引用轉路文章 出處, 想要研究一下MiraCast

前言

2012年11月中旬,Google發布了Android 4.2。雖然它和Android 4.1同屬Jelly Bean系列,但卻添加了很多新的功能。其中,在顯示部分,Android 4.2在Project Butter基礎上再接再厲,新增了對Wi-Fi Display功能的支持。由此也導致整個顯示架構發生了較大的變化。

本文首先介紹Wi-Fi Display的背景知識,然後再結合代碼對Android 4.2中Wi-Fi Display的實現進行介紹。

背景知識介紹

Wi-Fi Display經常和Miracast聯繫在一起。實際上,Miracast是Wi-Fi聯盟(Wi-Fi Alliance)對支持Wi-Fi Display功能的設備的認證名稱。通過Miracast認證的設備將在最大程度內保持對Wi-Fi Display功能的支持和兼容。由此可知,Miracast考察的就是Wi-Fi Display(本文後續將不再區分Miracast和Wi-Fi Display)。而Wi-Fi Display的核心功能就是讓設備之間通過Wi-Fi無線網路來分享視音頻數據。以一個簡單的應用場景為例:有了Wi-Fi Display后,手機和電視機之間可以直接藉助Wi-Fi,而無需硬連線(如HDMI)就可將手機中的視頻投遞到TV上去顯示[①]。以目前智能設備的發展趨勢來看,Wi-Fi Display極有可能在較短時間內幫助我們真正實現多屏互動。

從技術角度來說,Wi-Fi Display並非另起爐灶,而是充分利用了現有的Wi-Fi技術。圖1所示為Wi-Fi Display中使用的其他Wi-Fi技術項。



圖1 Miracast的支撐體系結構

  • – Wi-Fi Direct,也就是Wi-Fi P2P。它支持在沒有AP(Access Point)的情況下,兩個Wi-Fi設備直連並通信。
  • – Wi-Fi Protected Setup:用於幫助用戶自動配置Wi-Fi網路、添加Wi-Fi設備等。
  • – 11n/WMM/WPA2:其中,11n就是802.11n協議,它將11a和11g提供的Wi-Fi傳輸速率從56Mbps提升到300甚至600Mbps。WMM是Wi-Fi Multimedia的縮寫,是一種針對實時視音頻數據的QoS服務。而WPA2意為Wi-Fi Protected Acess第二版,主要用來給傳輸的數據進行加密保護。

上述的Wi-Fi技術中,絕大部分功能由硬體廠商實現。而在Android中,對Miracast來說最重要的是兩個基礎技術:

  • Wi-Fi Direct:該功能由Android中的WifiP2pService來管理和控制。
  • Wi-Fi Multimedia:為了支持Miracast,Android 4.2對MultiMedia系統也進行了修改。

下邊我們對Miracast幾個重要知識點進行介紹,首先是拓撲結構和視音頻格式方面的內容。

Miracast一個重要功能就是支持Wi-Fi Direct。但它也考慮了無線網路環境中存在AP設備的情況下,設備之間的互聯問題。讀者可參考如圖2所示的四種拓撲結構。



圖2 Miracast的四種拓撲結構

圖2所示內容比較簡單,此處就不再詳述。另外,在Wi-Fi Display規範中,還存在著Source將Video和Audio內容分別傳送給不同Render Device的情況。感興趣的讀者可參考Wi-Fi Display技術規範。

另外,Miracast對所支持的視音頻格式也進行了規定,如表1所示。

表1  Miracast 視音頻格式支持

解析度17種 CEA格式,解析度從640*480到1920*1080,幀率從24到6029種VESA格式,解析度從800*600到1920*1200,幀率從30到6012種手持設備格式,解析度從640*360到960*540,幀率從30到60
視頻H.264高清
音頻必選:LPCM 16bits,48kHz採樣率,雙聲道可選:LPCM 16bits,44.1kHz採樣率,雙聲道Advanced Audio coding

Dolby Advanced Codec 3

最後,我們簡單介紹一下Miracast的大體工作流程。Miracast以session為單位來管理兩個設備之間的交互的工作,主要步驟包括(按順序):

  • Device Discovery:通過Wi-Fi P2P來查找附近的支持Wi-Fi P2P的設備。
  • Device Selection:當設備A發現設備B后,A設備需要提示用戶。用戶可根據需要選擇是否和設備B配對。
  • Connection Setup:Source和Display設備之間通過Wi-Fi P2P建立連接。根據Wi-Fi Direct技術規範,這個步驟包括建立一個Group Owner和一個Client。此後,這兩個設備將建立一個TCP連接,同時一個用於RTSP協議的埠將被創建用於後續的Session管理和控制工作。
  • Capability Negotiation:在正式傳輸視音頻數據前,Source和Display設備需要交換一些Miracast參數信息,例如雙方所支持的視音頻格式等。二者協商成功后,才能繼續後面的流程。
  • Session Establishment and streaming:上一步工作完成後,Source和Display設備將建立一個Miracast Session。而後就可以開始傳輸視音頻數據。Source端的視音頻數據將經由MPEG2TS編碼后通過RTP協議傳給Display設備。-Display設備將解碼收到的數據,並最終顯示出來。
  • User Input back channel setup:這是一個可選步驟。主要用於在傳輸過程中處理用戶發起的一些控制操作。這些控制數據將通過TCP在Source和Display設備之間傳遞。
  • Payload Control:傳輸過程中,設備可根據無線信號的強弱,甚至設備的電量狀況來動態調整傳輸數據和格式。可調整的內容包括壓縮率,視音頻格式,解析度等內容。
  • Session teardown:停止整個Session。

 

通過對上面背景知識的介紹,讀者可以發現:

  • Miracast本質就是一個基於Wi-Fi的網路應用。這個應用包括服務端和客戶端。
  • 服務端和客戶端必須支持RTP/RTSP等網路協議和相應的編解碼技術。

二 Android 4.2 Miracast功能實現介紹

Miracast的Android實現涉及到系統的多個模塊,包括:

  • MediaPlayerService及相關模塊:原因很明顯,因為Miracast本身就牽扯到RTP/RTSP及相應的編解碼技術。
  • SurfaceFlinger及相關模塊:SurfaceFlinger的作用是將各層UI數據混屏並投遞到顯示設備中去顯示。現在,SurfaceFlinger將支持多個顯示設備。而支持Miracast的遠端設備也做為一個獨立的顯示設備存在於系統中。
  • WindowManagerService及相關模塊:WindowManagerService用於管理系統中各個UI層的位置和屬性。由於並非所有的UI層都會通過Miracast投遞到遠端設備上。例如手機中的視頻可投遞到遠端設備上去顯示,但假如在播放過程中,突然彈出一個密碼輸入框(可能是某個後台應用程序發起的),則這個密碼輸入框就不能投遞到遠端設備上去顯示。所以,WindowManagerService也需要修改以適應Miracast的需要。
  • DisplayManagerService及相關模塊:DisplayManagerService服務是Android 4.2新增的,用於管理系統中所有的Display設備。

由於篇幅原因,本文將重點關注SurfaceFlinger和DisplayManagerService以及Miracast的動態工作流程。

2.1 SurfaceFlinger對Miracast的支持

相比前面的版本,Android 4.2中SurfaceFlinger的最大變化就是增加了一個名為DisplayDevice的抽象層。相關結構如圖3所示:



圖3 SurfaceFlinger家族類圖
由圖3可知:

  • Surface系統定義了一個DisplayType的枚舉,其中有代表手機屏幕的DISPLAY_PRIMARY和代表HDMI等外接設備的DISPLAY_EXTERNAL。比較有意思的是,作為Wi-Fi Display,它的設備類型是DISPLAY_VIRTUAL。android/frameworks/native$ services/surfaceflinger/DisplayDevice.h
    class DisplayDevice : public LightRefBase{public:    // region in layer-stack space    mutable Region dirtyRegion;    // region in screen space    mutable Region swapRegion;    // region in screen space    Region undefinedRegion;    enum DisplayType {        DISPLAY_ID_INVALID = -1,        DISPLAY_PRIMARY     = HWC_DISPLAY_PRIMARY,        DISPLAY_EXTERNAL    = HWC_DISPLAY_EXTERNAL,        DISPLAY_VIRTUAL     = HWC_DISPLAY_VIRTUAL,        NUM_BUILTIN_DISPLAY_TYPES = HWC_NUM_PHYSICAL_DISPLAY_TYPES,    };

    再來看SurfaceFlinger類,其內部有一個名為mDisplays的變數,它保存了系統中當前所有的顯示設備(DisplayDevice)。另外,SurfaceFlinger通過mCurrentState和mDrawingState來控制顯示層的狀態。其中,mDrawingState用來控制當前正在繪製的顯示層的狀態,mCurrentState表示當前所有顯示層的狀態。有這兩種State顯示層的原因是不論是Miracast還是HDMI設備,其在系統中存在的時間是不確定的。例如用戶可以隨時選擇連接一個Miracast顯示設備。為了不破壞當前正在顯示的內容,這個新顯示設備的一些信息將保存到CurrentState中。等到SurfaceFlinger下次混屏前再集中處理。

  • mCurrentState和mDrawingState的類型都是SurfaceFlinger的內部類State。由圖3可知,State首先通過layerSortedByZ變數保存了一個按Z軸排序的顯示層數組(在Android中,顯示層的基類是LayerBase),另外還通過displays變數保存了每個顯示層對應的DisplayDeviceState。
    class SurfaceFlinger : public BnSurfaceComposer,                       private IBinder::DeathRecipient,                       private HWComposer::EventHandler{public:    ......    // access must be protected by mStateLock    mutable Mutex mStateLock;    State mCurrentState;    volatile int32_t mTransactionFlags;    Condition mTransactionCV;    bool mTransactionPending;    bool mAnimTransactionPending;    Vector< sp > mLayersPendingRemoval;    SortedVector< wp > mGraphicBufferProducerList;    ...    // Can only accessed from the main thread, these members    // don't need synchronization    State mDrawingState;    bool mVisibleRegionsDirty;    bool mHwWorkListDirty;    bool mAnimCompositionPending;    // this may only be written from the main thread with mStateLock held    // it may be read from other threads with mStateLock held    DefaultKeyedVector< wp, sp > mDisplays;	....};
  • DisplayDeviceState的作用是保存對應顯示層的DisplayDevice的屬性以及一個ISurfaceTexure介面。這個介面最終將傳遞給DisplayDevice。
  • DisplayDevice代表顯示設備,它有兩個重要的變數,一個是mFrameBufferSurface和mNativeWindow。mFrameBufferSurace是FrameBufferSurface類型,當顯示設備不屬於VIRTUAL類型的話,則該變數不為空。對於Miracast來說,顯示數據是通過網路傳遞給真正的顯示設備的,所有在Source端的SurfaceFlinger來說,就不存在FrameBuffer。故當設備為VIRTUAL時,其對應的mFrameBufferSurface就為空。而ANativeWindow是Android顯示系統的老員工了。該結構體在多媒體的視頻I/O、OpenGL ES等地方用得較多。而在普通的UI繪製中,ISurfaceTexture介面用得較多。不過早在Android 2.3,Google開發人員就通過函數指針將ANativeWindow的各項操作和ISurfaceTexture介面統一起來。

作為VIRTUAL的Miracast設備是如何通過DisplayDevice這一層抽象來加入到Surface系統中來的呢?下面這段代碼對理解DisplayDevice的抽象作用極為重要。如圖4所示。



圖4 SurfaceFlinger代碼片段
(以下是我看到的程式碼, 似乎已更改過了)

void SurfaceFlinger::init() {   ......    // initialize our non-virtual displays    for (size_t i=0 ; iisConnected(i) || type==DisplayDevice::DISPLAY_PRIMARY) {            // All non-virtual displays are currently considered secure.            bool isSecure = true;            createBuiltinDisplayLocked(type);            wp token = mBuiltinDisplays[i];            sp bq = new BufferQueue(new GraphicBufferAlloc());            sp fbs = new FramebufferSurface(*mHwc, i, bq);            sp hw = new DisplayDevice(this,                    type, allocateHwcDisplayId(type), isSecure, token,                    fbs, bq,                    mEGLConfig);            if (i > DisplayDevice::DISPLAY_PRIMARY) {                // FIXME: currently we don't get blank/unblank requests                // for displays other than the main display, so we always                // assume a connected display is unblanked.                ALOGD("marking display %d as acquired/unblanked", i);                hw->acquireScreen();            }            mDisplays.add(token, hw);        }    } ...}

由圖4代碼可知:

  • 對於非Virtual設備,DisplayDevice的FrameBufferSurface不為空。而且SurfaceTextureClient的構造參數來自於FrameBufferSurface的getBufferQueue函數。
  • 如果是Virtual設備,SurfaceTextureClient直接使用了State信息中攜帶的surface變數。

憑著上面這兩點不同,我們可以推測出如圖5所示的DisplayDevice的作用



圖5 DisplayDevice的隔離示意圖
由圖5可知,SurfaceFlinger將遍歷系統中所有的DisplayDevice來完成各自的混屏工作。
最後再來看一下SurfaceFlinger中混屏操作的實現,代碼如圖6所示:



圖6 SurfaceFilnger的混屏操作

SurfaceFlinger.cpp

void SurfaceFlinger::doComposition() {    ATRACE_CALL();    const bool repaintEverything = android_atomic_and(0, &mRepaintEverything);    for (size_t dpy=0 ; dpy<mDisplays.size() ; dpy++) {        const sp& hw(mDisplays[dpy]);        if (hw->canDraw()) {            // transform the dirty region into this screen's coordinate space            const Region dirtyRegion(hw->getDirtyRegion(repaintEverything));            // repaint the framebuffer (if needed)            doDisplayComposition(hw, dirtyRegion);            hw->dirtyRegion.clear();            hw->flip(hw->swapRegion);            hw->swapRegion.clear();        }        // inform the h/w that we're done compositing        hw->compositionComplete();    }    postFramebuffer();}

2.2 Framework對Miracast的支持

為了徹底解決多顯示設備的問題,Android 4.2乾脆在Framework中新增了一個名為DisplayManagerService的服務,用來統一管理系統中的顯示設備。
DisplayManagerService和系統其它幾個服務都有交互。整體結構如圖7所示。

android/frameworks/base/services/java/com/android/server/display/DisplayManagerService.java



圖7 DisplayManagerService及相關類圖

由圖7可知:

  • DisplayManagerService主要實現了IDisplayManager介面。這個介面的大部分函數都和Wi-Fi Display操作相關。
  • 另外,DisplayManagerService和WindowManagerService交互緊密。因為WindowManagerService管理系統所有UI顯示,包括屬性,Z軸位置等等。而且,WindowManagerService是系統內部和SurfaceFlinger交互的重要通道。
  • DisplayManagerService通過mDisplayAdapters來和DisplayDevice交互。每一個DisplayDevice都對應有一個DisplayAdapter。
  • 系統定義了四種DisplayAdapter。HeadlessDisplayAdapter和OverlayDisplayAdapter針對的都是Fake設備。其中OverlayDisplay用於幫助開發者模擬多屏幕之用。LocalDisplayAdapter代表主屏幕,而WifiDisplayAdapter代表Wi-Fi Display。

2.3 Android中Miracast動態工作流程介紹

當用戶從Settings程序中選擇開啟Miracast並找到匹配的Device後[③],系統將通過WifiDisplayController的requestConnect函數向匹配設備發起連接。代碼如圖8所示:



圖8 requestConnect函數實現

圖8中,最終將調用connect函數去連接指定的設備。 connect函數比較中,其中最重要的是updateConnection函數,我們抽取其中部分代碼來看,如圖9所示:



圖9 updateConnection函數片段

在圖8所示的代碼中,系統創建了一個RemoteDisplay,並在這個Display上監聽(listen)。從註釋中可知,該RemoteDisplay就是和遠端Device交互的RTP/RTSP通道。而且,一旦有遠端Device連接上,還會通過onDisplayConnected返回一個Sur​​face對象。
根據前面對SurfaceFlinger的介紹,讀者可以猜測出Miracast的重頭好戲就在RemoteDisplay以及它返回的這個Surface上了。
確實如此,RemoteDisplay將調用MediaPlayerService的listenForRemoteDisplay函數,最終會得到一個Native的RemoteDisplay對象。相關類圖如圖10所示。



圖10 RemoteDisplay類圖

由圖10可知,RemoteDisplay有三個重要成員變量:
mLooper,指向一個ALooper對象。這表明RemoteDisplay是一個基於消息派發和處理的系統。
mNetSession指向一個ANetWorkSession對象。從它的API來看,ANetworkSession提供大部分的網絡操作。
mSource指向一個WifiDisplaySource對象。它從AHandler派生,故它就是mLooper中消息的處理者。注意,圖中的M1、M3、M5等都是Wi-Fi Display技術規範中指定的消息名。
RemoteDisplay構造函數中,WifiDisplaySource的start函數將被調用。如此,一個類型為kWhatStart的消息被加到消息隊列中。該消息最終被WifiDisplaySource處理,結果是一個RTSPServer被創建。代碼如圖11所示:



圖11 kWhatStart消息的處理結果

以後,客戶端發送的數據都將通過類型為kWhatRTSPNotify的消息加入到系統中來。而這個消息的處理核心在onReceiveClientData函數中,它囊括了設備之間網絡交互的所有細節。其核心代碼如圖12所示:



圖12 onReceiveClientData核心代碼示意

圖12的內容較多,建議讀者根據需要自行研究。
根據前面的背景知識介紹,設備之間的交互將由Session來管理。在代碼中,Session的概念由WifiSource的內部類PlaybackSession來表示。先來看和其相關的類圖結構,如圖13所示:



圖13 PlaybackSession及相關類圖

由圖13可知:
 PlaybackSession及其內部類Track都從AHandler派生。故它們的工作也依賴於消息循環和處理。 Track代表視頻流或音頻流。
Track內部通過mMediaPull變量指向一個MediaPull對象。而MediaPull對象則保存了一個MediaSource對象。在PlaybackSession中,此MediaSource的真正類型為SurfaceMediaSource。它表明該Media的源來自Surface。
 BufferQueue從ISurfaceTexure中派生,根據前面對SurfaceFlinger的介紹,它就是SurfaceFlinger代碼示例中代表虛擬設備的State的surface變量。
當雙方設備準備就緒後,MediaPull會通過kWhatPull消息處理不斷調用MediaSource的read函數。在SurfaceMediaSource實現的read函數中,來自SurfaceFlinger的混屏後的數據經由BufferQueue傳遞到MediaPull中。代碼如圖14所示:



圖14 MediaPull和SurfaceMediaSource的代碼示意

從圖13可知:
左圖中,MediaPull通過kWhatPull消息不斷調用MediaSource的read函數。
右圖中,SurfaceMediaSource的read函數由通過mBufferQueue來讀取數據。
那麼mBufferQueue的數據來自什麼地方呢?對,正是來自圖4的SurfaceFlinger。
當然,PlaybackSession拿到這些數據後還需要做編碼,然後才能發送給遠端設備。由於篇幅關係,本文就不再討論這些問題了。

三. 總結

本文對Miracast的背景知識以及Android系統中Miracast的實現進行了一番簡單介紹。從筆者個人角度來看,有以下幾個點值得感興趣的讀者註意:
一定要結合Wi-Fi的相關協議去理解Miracast。重點關注的協議包括Wi-Fi P2p和WMM。

 Android Miracast的實現中,需要重點理解SurfaceFlinger和RemoteDisplay模塊。這部分的實現不僅代碼量大,而且類之間,以及線程之間關係複雜。
其他需要注意的點就是DisplayManagerService及相關模塊。這部分內容在SDK中有相關API。應用開發者應關注這些新API是否能幫助自己開發出更有新意的應用程序。
另外,Android的進化速度非常快,尤其在幾個重要的功能點上。作者在此也希望國內的手機廠商或那些感興趣的移動互聯網廠商能真正投入力量做一些更有深度和價值的研發工作。

2014/09/18

卡關筆記 base_rules.mk:72: *** user tag detected on module.. 如何把 module正確編譯且產生出來

首先發生了error
編譯到一半就有訊息跳出並停止編譯
它跟我說我用了 user tag 所以STOP…

build/core/base_rules.mk:66: * build/core/base_rules.mk:67: * Module is attempting to use the 'user' tag.  This build/core/base_rules.mk:68: * used to cause the module to be installed automatically. build/core/base_rules.mk:69: * Now, the module must be listed in the PRODUCT_PACKAGES build/core/base_rules.mk:70: * section of a product makefile to have it installed. build/core/base_rules.mk:71: * build/core/base_rules.mk:72: *** user tag detected on module..  Stop. 

去看了一看我的 module’s Android.mk
如下

LOCAL_PATH := $(call my-dir)include $(CLEAR_VARS)LOCAL_MODULE := test_wifiLOCAL_SRC_FILES := test_wifi.shLOCAL_MODULE_SUFFIX := .shLOCAL_MODULE_CLASS := ETCLOCAL_MODULE_TAGS := userinclude $(BUILD_PREBUILT)

關鍵在 LOCAL_MODULE_TAGS

eng:
我還沒改之前為eng, 而eng表示系統會自動搬入 out/product/xxx/xxx (看你怎麼寫, 像此例是LOCAL_MODULE_CLASS := ETC 所以是system/etc)

user:
如果是 LOCAL_MODULE_TAGS := user 就上面的error message
可能有些地方不能隨意定義成user吧… 害我一開始還跟著error message去試著將module name加入 PRODUCT_PACKAGES定義裡
也沒用, 還是fail

optional:
可以改成 LOCAL_MODULE_TAGS := optional , 但必須說明是否搬入out目錄裡
怎麼說明呢?
去把該module name (此例為test_wifi)加入 PRODUCT_PACKAGES定義裡
可以寫在
1) /android/build/target/product/generic.mk 或附近的mk檔
2) 又或者, 其他可以定義 PRODUCT_PACKAGES += xxxxx 的makedile裡 (.mk檔) 必須看你的codebase什麼地方有PRODUCT_PACKAGES += xxxxx 就接著寫在下面吧

我後來處理的寫法

diff給你看

@@ -4,5 +4,5 @@ include $(CLEAR_VARS) LOCAL_MODULE := test_wifi LOCAL_SRC_FILES := test_wifi.sh LOCAL_MODULE_SUFFIX := .sh LOCAL_MODULE_CLASS := ETC-LOCAL_MODULE_TAGS := eng+LOCAL_MODULE_TAGS := eng optional include $(BUILD_PREBUILT)

PRODUCT_PACKAGES宣告

 PRODUCT_PACKAGES += TE_WGA+PRODUCT_PACKAGES += test_wifi

2014/09/15

測試802.11a, 802.11b, 802.11g, 802.11n, 802.11ac的研讀整理

工作上必須去量測DUT的Wifi訊號
而量測的工具是LitePoint IQ2010
看之前可以先讀這篇: 網路架構大概論6-看懂無線網路 802.11 b/g/n/ac 演進歷史 熟習WiFi故事前後關係

這是IEEE所定出來的規範,無線技術從802.11開始發展,再延伸出802.11b/g/n是縮寫各自都是代表不同的規範,但都是建構在802.11下開發出來的無線技術所以802.11b/802.11g/802.11n,載波頻段在2.4GHz,b/g/n技術稍微不同所以速率也是有所提升,以最高速度來說802.11n > 802.11g > 802.11b。

802.11ac是802.11a的進階版(增加頻寬,增加調變能力,etc),所以才叫做802.11ac而不叫做802.11c,而802.11a與802.11ac採使用的主要頻段是5GHz,其中802.11n也有5GHz的技術。802.11ac是目前base on 802.11延伸出的無線技術中,傳輸速度最快的。

比較夯的Protocol

802.11a (5GHz)
802.11b
802.11g
802.11n
802.11ac (關於測試的說明)

Modulation(調變)

  • OFDM- 802.11a, 802.11g, 802.11n, 802.11ac
    Orthogonal frequency-division multiplexing 正交分頻多工, OFDM 是一種資料編碼的技術,利用在不同頻段同時傳送資料以增加傳輸速率,其目的除了可以善加利用寶貴的頻譜外,更可以克服頻率選擇性殘衰頻道 (frequency selective fading channel)。OFDM符號的調變與解調是交由BPSK、QPSK、16-QAM或64-QAM等四種鍵控調變技術執行,並在搭配不同通道編碼率的情況下,提供八種不同的資料傳輸率
  • DSSS- Legacy, 802.11b, 802.11g
    direct-sequence spread spectrum 直接序列展頻, 在傳送端,直接用高碼率的展頻碼序列去擴充功能訊號的頻譜,在接收端,用相同的展頻碼序列將訊號解擴,把展寬的訊號還原到原始狀態。
  • FHSS- Legacy
    Frequency-hopping spread spectrum 跳頻展頻, 是展頻技術的一種;經由載波快速在不同頻率中切換,並在接收與發射端使用一種偽隨機(PseudoRandom)的過程。

頻寬(MHz)
頻寬有兩個涵義
一種是指頻率範圍(width of a frequency band) ,以Hz (Hertz)為單位 (也就是此處用法)
另一種則是我們熟悉的通訊線路的資料速率(data rate),可用bits per second來表示
另一個和頻寬有關的觀念是所謂的傳輸效率(throughput) ,代表實測的頻寬

  • HT20- 802.11a, 802.11b, 802.11g, 802.11n HT(High Throughput)20MHz
  • HT40- 802.11n, 802.11ac HT(High Throughput)40MHz
  • HT80- 802.11ac HT(High Throughput)80MHz
  • HT160- 802.11ac HT(High Throughput)160MHz

專有名詞

還滿多可以從這份文件Practical Manufacturing Testing of 802.11 OFDM Wireless Devices找到的

  • Constellation Diagram: 星座圖
    The Constellation Diagram is a representation of a signal modulated by a digital modulation scheme. The plots in Figure 6 show
    typical constellations for an OFDM signal. The green constellation points represent the information from the pilot subcarriers; the
    red constellation points, the data on the subcarriers. (From litepoint)
  • EVM :誤差向量幅度(Error Vector Magnitude)
    可以檢測出數位調變訊號的品質,並且找出射頻訊號失真的原因及可能發生失真的電路位置,包括:功率放大器的增益壓縮 (gain compression)、本地振盪貫穿 (LOfeedthrough)、IQ 增益不平衡 (gain imbalance)、載波頻率抵補 (carrier frequency offset)、相位雜訊(phase noise) 干擾及符號間干擾 (intersymbolinterference, ISI) 等,這是傳統射頻儀器或位元錯誤率 (bit error rate, BER) 量測儀器所無法測出的。
    針對調變過的訊號,EVM 將比較訊號預期與實際的相位/強度。如圖所示,將錯誤向量 |E| 除以強度向量 |V|,得出該值。
    (參考自:設定軟體定義架構的 WLAN 測試系統)
  • MCS:
    調變標準指標 Modulation and Coding Scheme, 透過index查表知道調變內容
    這裡有說明怎麼看MCS表,

    • MCS index 就是指速度的指標. 比方說我支持到 MCS7, 他支援到 MCS15 之類的
    • Spatial Stream 是指空間流或是空間串流, 要明白空間串流就要先明白空間分集. 假如在訊號的發送端有多個天線, 而每個天線的訊號都會透過不同的路徑到達接收端的天線, 這樣就構成了空間的分割或是分集. 如果天線不夠多支, 也就無法做到分集. 11n 的規範最多就是支援 4 支天線.
    • Modulation type 就是通訊原理裡面講的調變方法.
    • Coding rate N/M 是指傳送 M bit 時, 裡面有 N bit 是 data, 當然 M – N 就是 redundant 了. Redundant 不是沒有用, 反而可以防錯或是校正錯誤.
    • 20 MHz channel 或 40 MHz 是通道的頻寬
    • GI 的單位是時間, 所以可以猜到 I 表示 Interval. 對, GI 就是 Guard Interval. 在兩個 OFDM 的 symbol 之間的傳送間隔即為 GI. GI 愈短, 則傳輸速率愈高.
    • 在 4 根天線的狀況下, 距離不要太遠 (coding rate 高) 的話, 11n 可以達到 600 Mbps. 而一開始講到的 MCS7 和 MCS15, 其他的條件都是一樣的, 只差在空間串流的數目. 這點可以從天線的多寡很快判斷出來, 沒有兩根天線是不可能做 MCS15 的.

    http://mcsindex.com/

  • Frequency Error:
    就是量測出來的載波頻率與預期的頻率差異(A Frequency Error measures the difference (misalignment) between the carrier frequency generated by the reference oscillators at the transmitter and the expected carrier frequency.)
  • Spectrum Mask(Spectral Mask): 頻譜遮罩
    就是每個channel的訊號power強度分布圖, 不要超出範圍影響別的訊號 (A Spectral Mask describes the distribution of signal power across each channel.)
  • Spectral Flatness: 頻譜平坦性
    defined as the geometric mean(幾何平均數) of the power spectrum divided by the arithmetic mean(算術平均數) of the power spectrum.
  • Transmit Center Frequency Leakage: 傳遞中心頻率缺漏
    DC offset can affect certain transmitter implementations in the up-converter path, and usually causes carrier leakage. Such leakage manifests itself in a receiver as energy in the transmit center frequency, hence the name Transmit Center Frequency Leakage.

2014/09/11

shell script錯誤: Bad substitution

通常會造成 Bad substitution 錯誤
大部分是因為第一行的定義沒寫好.當然也可能是語法錯誤

我將第一行改寫為預設bash如下, 即可解決

#!/bin/bash

根據鳥哥說明:
可以檢查一下 /etc/shells 這個檔案,至少就有底下這幾個可以用的 shells:

/bin/sh (已經被 /bin/bash 所取代)/bin/bash (就是 Linux 預設的 shell)/bin/ksh (Kornshell 由 AT&T Bell lab. 發展出來的,相容於 bash)/bin/tcsh (整合 C Shell ,提供更多的功能)/bin/csh (已經被 /bin/tcsh 所取代)/bin/zsh (基於 ksh 發展出來的,功能更強大的 shell)

這個問題有點類似之前寫的一篇文章, 也說明了一下dash與bash的設定
UBUNTU- 執行SHELL SCRIPT 為什麼常發生 UNEXPECTED OPERATOR

2014/09/10

如何快速更新DNS對應的IP Address

有時候domain name server對應到的 IP address更動,

要等好長一段時間才會自動生效,

其實只要幾個步驟就可以很快完成新IP位址與網域的對應

Step1: 更新OpenDNS CacheCheck

前往 http://cachecheck.opendns.com/ 刷新
OpenDNS的有巨大的緩存,這是一個原因,OpenDNS的讓您的互聯網體驗更快。
隨著CacheCheck,你可以查閱一下OpenDNS的客戶看到,當他們請求域。
如果有什麼東西不對勁,你可以刷新的OpenDNS的緩存域。

Step2: 清除自己系統DNS快取

如果是使用 Windows 作業系統,請以管理員權限進入「附屬應用程式」的「命令提示字元」,或是直接在執行列輸入「cmd」,然後鍵入以下指令:
ipconfig /flushdns

如果你是使用 Mac OS X 的話,請進入終端機視窗,然後鍵入以下指令:
lookupd -flushcache (Mac OS Tiger 或更早前的版本)
dscacheutil -flushcache (Mac OS X 10.5 Leopard 以後的版本)

如果你是 Linux 的使用者,必須輸入以下指令重新啟動 nscd :
/etc/rc.d/init.d/nscd restart

如此一來就能手動清除系統的DNS快取資料,並重新從OpenDNS獲得新的紀錄,對於時常要搬移網站,或是設定對應新IP的使用者來說,會是個比較省時省力的作法,也不用為了等待DNS生效而耗費數個小時。
但順帶一提,這麼做並不能更新所有使用者的DNS記錄,其他人還是必須在變更生效後才能正確瀏覽你的網站。

2014/09/05

Android手機的Linux發生Kernel Panic ..

在作monkey測試的時候, 發生kernel panic
但是發生機率很低, 加上目前硬體還不穩定, 所以努力複現中…

關於Kernel Panic 稍微google了一下
第一. 可以先了解什麼是Linux kernel panic (參考1)
第二. 怎麼看LOG (參考2)

以下就是發生kernel panic的LOG,
隨意分析與註解一下

[38373.777729] Unable to handle kernel NULL pointer dereference at virtual address 00000000[38373.784640] Unable to handle kernel NULL pointer dereference at virtual address 00000224這個pgd is short for "page global directory", the kernel's name for the top level of a page table.[38373.784647] pgd = da350000[38373.784651] [00000224] *pgd=00000000下方數字5表示Oops的錯誤碼(詳情請trace code),#1表示这个错误发生一次.[38373.784661] Internal error: Oops: 5 [#1] PREEMPT SMP ARM[38373.784667] Modules linked in: wlan(O) [last unloaded: wlan][38373.784680] CPU: 0    Tainted: G        W  O  (3.4.0-g6e71111 #1)PC 或 EIP 會去指出發生錯誤的地方, 此處是PC指出所以是在contextidr_notifier的offset為0x10的位址發生了錯誤,此時用objdump -d,將該模組反組譯,觀察該位址應該就可以猜出來是怎麼一回事。[38373.784695] PC is at contextidr_notifier+0x10/0x40[38373.784704] LR is at notifier_call_chain+0x38/0x68[38373.784712] pc : []    lr : []    psr: 60000013[38373.784715] sp : cf6d7d08  ip : c0f29fd8  fp : cf6d7df4[38373.784720] r10: e9d8bdc0  r9 : ea0d8000  r8 : c0f2836c[38373.784727] r7 : e9402000  r6 : 00000002  r5 : 00000000  r4 : ffffffff[38373.784733] r3 : 00000000  r2 : e9402000  r1 : 00000002  r0 : c0f29fd8[38373.784741] Flags: nZCv  IRQs on  FIQs on  Mode SVC_32  ISA ARM  Segment user[38373.784747] Control: 10c5787d  Table: 2a0dc06a  DAC: 00000015[38373.784753] [38373.784755] PC: 0xc0114e78:[38373.784759] 4e78  ee0d4f30 f57ff06f e8bd8010 e92d4070 e2805e16 e1a04000 e1a00005 e1a06001[38373.784773] 4e98  eb202eea e59f3040 e1a01000 e1a00005 e593200c e594315c e0223003 e1b03423[38373.784788] 4eb8  13a03000 1584615c 15843158 eb202fd6 e1a0200d e2841f56 e3c23d7f e3c3303f[38373.784803] 4ed8  e5930014 e8bd4070 ea09ec62 c0f29fd8 e3510002 e92d4010 1a00000a e592300c[38373.784818] 4ef8  e5930224 e10f4000 f10c0080 ee1d3f30 e6ef3073 e1830400 ebffffd3 e121f004[38373.784832] 4f18  e3a00001 e8bd8010 e3a00000 e8bd8010 e92d4008 ee1d0f30 e3c000ff ebffffca[38373.784847] 4f38  f57ff04f e3a03000 ee083f13 f57ff04f f57ff06f e59f2014 e5922000 e3120008[38373.784861] 4f58  08bd8008 ee073f11 f57ff04f e8bd8008 c0f1e4d8 e92d4038 e1a0200d e3c23d7f[38373.784877] [38373.784878] LR: 0xc0922ea0:[38373.784881] 2ea0  e3c13dff e7951180 e3c3303f e2833103 e0832002 e7831180 e5943004 e5823004[38373.784896] 2ec0  ee072f3a f57ff04f ea000003 e1a00003 e1a01006 e1a0200c ebdfbc4d e3a00000[38373.784910] 2ee0  e8bd80f8 c0f531c8 e92d41f0 e1a06001 e590c000 e1a07002 e1a04003 e59d5018[38373.784925] 2f00  e3a00000 ea00000d e59c3000 e1a0000c e1a01006 e1a02007 e59c8004 e12fff33[38373.784939] 2f20  e3550000 15953000 12833001 15853000 e3100902 18bd81f0 e2444001 e1a0c008[38373.784953] 2f40  e3540000 135c0000 1affffee e8bd81f0 e92d40f7 e1a04003 e1a07000 e1a06001[38373.784967] 2f60  e1a05002 ebe368ed e59d3020 e1a01006 e1a02005 e2870004 e58d3000 e1a03004[38373.784982] 2f80  ebffffd8 e1a04000 ebe36ce1 e1a00004 e8bd80fe e3a03000 e92d4007 e58d3000[38373.784997] [38373.784998] SP: 0xcf6d7c88:[38373.785002] 7c88  c30e3570 c0f49cc0 38a5f3a8 c0191900 c0f2b1e8 c0114ef8 60000013 ffffffff[38373.785016] 7ca8  cf6d7cf4 c0f2836c ea0d8000 e9d8bdc0 cf6d7df4 c0921418 c0f29fd8 00000002[38373.785031] 7cc8  e9402000 00000000 ffffffff 00000000 00000002 e9402000 c0f2836c ea0d8000[38373.785045] 7ce8  e9d8bdc0 cf6d7df4 c0f29fd8 cf6d7d08 c0922f20 c0114ef8 60000013 ffffffff[38373.785059] 7d08  ffffffff c0922f20 ffffffff e9402000 00000002 c10f4824 e99dddc0 c0922f84[38373.785073] 7d28  00000000 00000002 e9402000 e940201c e8148e40 cf6d6000 00000000 c0922fa8[38373.785087] 7d48  00000000 00000002 e9402000 c0921858 00000000 c0f1fdc0 c0f12c70 c0f12c70[38373.785102] 7d68  1877c34f 00000000 c0f158c0 c091e47c c0f124d0 c0f158c0 97cd0c7b 000022e6[38373.785117] [38373.785119] IP: 0xc0f29f58:[38373.785122] 9f58  00000000 00000043 00000001 00000000 00000000 00000043 00000001 00010412[38373.785136] 9f78  00000000 00000000 00000000 0001941e 00000000 00000000 00000000 0001141e[38373.785150] 9f98  00000000 00000000 00000000 0001940e 00000000 0000045f 00000001 00000000[38373.785164] 9fb8  00000000 000007d3 00000041 00010442 00000002 c01147b8 c0f2ae34 00000000[38373.785178] 9fd8  c0114ee8 c0f2836c 00000000 00008c7b c0c1155f 00000000 00000000 00000000[38373.785192] 9ff8  c01152c0 00000000 c01157d8 00000000 c0115748 c01156a0 c0115868 c01152e0[38373.785206] a018  c01154d0 00000000 c011535c 00000000 00000000 00000000 00000000 00000000[38373.785219] a038  00000000 00000000 00000000 00000000 c0f28758 c0f41948 c01153e0 c0115afc[38373.785234] [38373.785236] FP: 0xcf6d7d74:[38373.785239] 7d74  c091e47c c0f124d0 c0f158c0 97cd0c7b 000022e6 00000001 c30e68c0 cf6d7de4[38373.785253] 7d94  c01ca574 00000000 00000000 00000005 97cc89aa 000022e6 e9d8bdc0 c30e68c0[38373.785267] 7db4  00000005 c30e68c0 c0f158c0 cf6d7de4 c01c2fd0 00000100 e9d8bdc0 00000000[38373.785281] 7dd4  c118c040 003a1c79 c118c040 0000006e 000003e8 eb3aaad0 cf6d7eb4 cf6d6000[38373.785295] 7df4  c091e47c c30e68c0 a0000013 c118c930 c118c930 003a1c79 c118c040 c01a5574[38373.785310] 7e14  e8148e40 ffffffff ffffffff 00000000 00000000 00000000 00000000 00000000[38373.785324] 7e34  271ae91c cf6d7e5c e749cc00 00000000 00000001 e749ccb8 c06f5244 eb3aaa00[38373.785338] 7e54  c0714558 e749cc00 00000000 e8148e40 c01c5e54 e749ccbc e749ccbc 0008a390[38373.785353] [38373.785355] R0: 0xc0f29f58:[38373.785359] 9f58  00000000 00000043 00000001 00000000 00000000 00000043 00000001 00010412[38373.785373] 9f78  00000000 00000000 00000000 0001941e 00000000 00000000 00000000 0001141e[38373.785386] 9f98  00000000 00000000 00000000 0001940e 00000000 0000045f 00000001 00000000[38373.785400] 9fb8  00000000 000007d3 00000041 00010442 00000002 c01147b8 c0f2ae34 00000000[38373.785414] 9fd8  c0114ee8 c0f2836c 00000000 00008c7b c0c1155f 00000000 00000000 00000000[38373.785428] 9ff8  c01152c0 00000000 c01157d8 00000000 c0115748 c01156a0 c0115868 c01152e0[38373.785442] a018  c01154d0 00000000 c011535c 00000000 00000000 00000000 00000000 00000000[38373.785456] a038  00000000 00000000 00000000 00000000 c0f28758 c0f41948 c01153e0 c0115afc[38373.785471] [38373.785472] R2: 0xe9401f80:[38373.785475] 1f80  0000c8c0 00000000 00000040 00000040 000aebea 2756ccf4 e9401f98 e9401f98[38373.785490] 1fa0  00100010 ffffffff 00000000 00000000 00000000 0000007f 00000000 0000001c[38373.785503] 1fc0  e9401fc0 e9401fc0 02a202a2 00000000 00000000 00000000 01140114 00010a69[38373.785517] 1fe0  0000bd4b 00000000 e9401ff0 e9401fec 0001f30a 00000004 00000000 00000000[38373.785531] 2000  00000008 005e925f 00000000 00000000 00000000 00000000 00000000 00000000[38373.785544] 2020  00000000 00000000 00000000 00000000 00000000 00000000 000000bd 00000000[38373.785558] 2040  00000004 00080080 00000000 00200020 e9402050 e9402050 e9402058 e9402058[38373.785572] 2060  00008000 00000000 00000000 02740274 e9402070 e9402070 00058180 00002715[38373.785587] [38373.785589] R7: 0xe9401f80:[38373.785592] 1f80  0000c8c0 00000000 00000040 00000040 000aebea 2756ccf4 e9401f98 e9401f98[38373.785606] 1fa0  00100010 ffffffff 00000000 00000000 00000000 0000007f 00000000 0000001c[38373.785620] 1fc0  e9401fc0 e9401fc0 02a202a2 00000000 00000000 00000000 01140114 00010a69[38373.785634] 1fe0  0000bd4b 00000000 e9401ff0 e9401fec 0001f30a 00000004 00000000 00000000[38373.785648] 2000  00000008 005e925f 00000000 00000000 00000000 00000000 00000000 00000000[38373.785661] 2020  00000000 00000000 00000000 00000000 00000000 00000000 000000bd 00000000[38373.785675] 2040  00000004 00080080 00000000 00200020 e9402050 e9402050 e9402058 e9402058[38373.785690] 2060  00008000 00000000 00000000 02740274 e9402070 e9402070 00058180 00002715[38373.785704] [38373.785706] R8: 0xc0f282ec:[38373.785709] 82ec  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38373.785723] 830c  00000000 00000000 636f6c00 6f646c61 6e69616d 00000000 00000000 00000000[38373.785737] 832c  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38373.785750] 834c  00000000 00000000 00000000 c0f4cd68 00008001 c0c0cfda 00000000 c01013e4[38373.785764] 836c  c01010fc 00000000 00000000 c0101048 00000000 00000000 000000ff 20000000[38373.785779] 838c  c0101a98 00000000 c0101a80 00000000 c0101a68 00000000 c01030cc 00000000[38373.785792] 83ac  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38373.785806] 83cc  c01025a4 00000001 c010259c 00000001 c0102590 00000001 c0102584 00000001[38373.785820] [38373.785822] R9: 0xea0d7f80:[38373.785825] 7f80  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38373.785839] 7fa0  00000000 00000000 00000000 00000000 00000000 00000000 2b9b9811 2b9b9c11[38373.785853] 7fc0  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38373.785866] 7fe0  00000000 00000000 00000000 00000000 00000000 00000000 2def6821 2def6c21[38373.785880] 8000  e869f738 ea1f5c24 00000000 c0112dbc c024760c b6f6c000 bf000000 00000000[38373.785895] 8020  b284b000 ea0dc000 0000000d 00000001 00000167 d199d199 00000000 a578a578[38373.785909] 8040  ea0d8040 ea0d8040 ea0d8048 ea0d8048 00000aaa 0000d3ac 00007f0d 00000000[38373.785923] 8060  00000000 00006ed7 00000d82 00000022 00005f04 00000000 00000047 b6f6b000[38373.785937] [38373.785939] R10: 0xe9d8bd40:[38373.785943] bd40  00000000 eb3d79c0 eb218448 e9d8c208 00000000 e9d8bd54 e9d8bd54 00000000[38373.785957] bd60  00000000 00000000 00000001 00000000 e9d8bd70 e9d8bd70 00000000 e9d8bd7c[38373.785971] bd80  e9d8bd7c 00000000 00000000 00000000 00000000 00000000 00000020 00000000[38373.785984] bda0  0000c350 0000c350 00000000 00000000 00000000 00000001 00000000 00000000[38373.785998] bdc0  00000000 e9402000 00000002 00000040 00000000 00000000 00000001 00000001[38373.786012] bde0  0000006f 0000006f 0000006f 00000000 c0a0af78 00000000 00001dc4 000899bc[38373.786026] be00  00000001 00000000 00000000 c30e6d8c c30e6d8c 00000001 97cd0c7b 000022e6[38373.786040] be20  342ca642 0000000e 15dabd8e 00002688 342ca642 0000000e 0000e830 00000000[38373.786057] Process FastMixer (pid: 21242, stack limit = 0xcf6d62f0)[38373.786063] Stack: (0xcf6d7d08 to 0xcf6d8000)[38373.786070] 7d00:                   ffffffff c0922f20 ffffffff e9402000 00000002 c10f4824[38373.786079] 7d20: e99dddc0 c0922f84 00000000 00000002 e9402000 e940201c e8148e40 cf6d6000[38373.786087] 7d40: 00000000 c0922fa8 00000000 00000002 e9402000 c0921858 00000000 c0f1fdc0[38373.786095] 7d60: c0f12c70 c0f12c70 1877c34f 00000000 c0f158c0 c091e47c c0f124d0 c0f158c0[38373.786103] 7d80: 97cd0c7b 000022e6 00000001 c30e68c0 cf6d7de4 c01ca574 00000000 00000000[38373.786111] 7da0: 00000005 97cc89aa 000022e6 e9d8bdc0 c30e68c0 00000005 c30e68c0 c0f158c0[38373.786119] 7dc0: cf6d7de4 c01c2fd0 00000100 e9d8bdc0 00000000 c118c040 003a1c79 c118c040[38373.786128] 7de0: 0000006e 000003e8 eb3aaad0 cf6d7eb4 cf6d6000 c091e47c c30e68c0 a0000013[38373.786136] 7e00: c118c930 c118c930 003a1c79 c118c040 c01a5574 e8148e40 ffffffff ffffffff[38373.786144] 7e20: 00000000 00000000 00000000 00000000 00000000 271ae91c cf6d7e5c e749cc00[38373.786152] 7e40: 00000000 00000001 e749ccb8 c06f5244 eb3aaa00 c0714558 e749cc00 00000000[38373.786160] 7e60: e8148e40 c01c5e54 e749ccbc e749ccbc 0008a390 e749cc00 eb3aaa00 00000000[38373.786168] 7e80: 000000f0 00000020 00000000 eb3aaad0 00000000 c06f6de4 eb3aaa00 60000193[38373.786176] 7ea0: ec3c0e40 c11dc388 b72316c8 00000000 b722662c 00000000 ec2a1260 00000003[38373.786184] 7ec0: eb3aaa00 00000000 400c4150 00000020 cf6d6000 b5839a4c ea241ce0 c06f6fb4[38373.786193] 7ee0: c06f5520 b72316c8 b5839a4c c06f35ec e752f0c0 00000000 b72316c8 000000f0[38373.786201] 7f00: 00000000 e752f0c0 00000020 400c4150 00000020 c026c644 ea53bb00 c026d184[38373.786209] 7f20: cf6d7f44 00000000 00000001 c034ab38 00000000 cf6d7f58 cf6d7f90 00000000[38373.786218] 7f40: 00000000 00000001 00000000 ebb1b190 ea53bb00 cf6d7f3c 00000008 b7252c28[38373.786226] 7f60: e752f0c0 00000000 e752f0c0 b5839a4c 400c4150 00000020 cf6d6000 00000000[38373.786235] 7f80: b722662c c026d220 00000020 00000001 b7252c28 000003c0 b7221160 00000036[38373.786243] 7fa0: c01062e4 c0106160 b7252c28 000003c0 00000020 400c4150 b5839a4c b5839a40[38373.786252] 7fc0: b7252c28 000003c0 b7221160 00000036 b72211c4 b587a298 b587a268 b722662c[38373.786260] 7fe0: 000003c0 b5839a30 b6f83f87 b6f776f8 800e0010 00000020 00000000 00000000開始Backtrace的地方,這是oops kernel panic log 的精華。它表示回溯信息,也告訴調試者在oops出錯之前,模塊調用了那些函數。當然,在本實例中,可以看到模塊調用了contextidr_notifier後就出錯了,顯然錯誤就在contextidr_notifier中了[38373.786278] [] (contextidr_notifier+0x10/0x40) from [] (notifier_call_chain+0x38/0x68)[38373.786292] [] (notifier_call_chain+0x38/0x68) from [] (__atomic_notifier_call_chain+0x34/0x44)[38373.786304] [] (__atomic_notifier_call_chain+0x34/0x44) from [] (atomic_notifier_call_chain+0x14/0x18)[38373.786317] [] (atomic_notifier_call_chain+0x14/0x18) from [] (__switch_to+0x34/0x5c)[38373.786327] Code: e3510002 e92d4010 1a00000a e592300c (e5930224) [38373.786386] ---[ end trace f3db8a93ae8449a4 ]---[38373.786393] panic: rere = 0x46544443[38373.786422] Kernel panic - not syncing: Fatal exception以下好像是直接繼續另一個panic ...[38374.899743] pgd = c0004000[38374.902434] [00000000] *pgd=00000000[38374.905999] Internal error: Oops: 5 [#2] PREEMPT SMP ARM[38374.911283] Modules linked in: wlan(O) [last unloaded: wlan][38374.916934] CPU: 3    Tainted: G      D W  O  (3.4.0-g6e71111 #1)[38374.923021] PC is at strcmp+0x8/0x3c[38374.926576] LR is at msm_pm_get_sleep_mode_value+0x40/0x70[38374.932048] pc : []    lr : []    psr: 20000093[38374.932062] sp : ec89be70  ip : c60f3fc0  fp : 00000000[38374.943493] r10: 00000000  r9 : c11693d8  r8 : c0f1f008[38374.948703] r7 : 00000001  r6 : c11093d8  r5 : 00b00160  r4 : 0016002c[38374.955211] r3 : 00000000  r2 : 00000000  r1 : 00000000  r0 : c11093d8[38374.961727] Flags: nzCv  IRQs off  FIQs on  Mode SVC_32  ISA ARM  Segment kernel[38374.969103] Control: 10c5787d  Table: 29d8406a  DAC: 00000015[38374.974824] [38374.974830] PC: 0xc039890c:[38374.979074] 890c  c0a33072 e3a03000 e7d12003 e3520000 e7c02003 e2833001 1afffffa e12fff1e[38374.987236] 892c  e3a03000 ea000004 e5d1c000 e35c0000 e7c0c003 e2833001 12811001 e1530002[38374.995394] 894c  1afffff8 e12fff1e e1a0c000 e1a0200c e28cc001 e5d23000 e3530000 1afffffa[38375.003554] 896c  e7d1c003 e35c0000 e7c2c003 e2833001 1afffffa e12fff1e e3a03000 e7d02003[38375.011713] 898c  e7d1c003 e152000c 0a000002 2a000006 e3e00000 e12fff1e e3520000 e2833001[38375.019872] 89ac  1afffff5 e1a00002 e12fff1e e3a00001 e12fff1e e92d4010 e3a03000 ea000009[38375.028032] 89cc  e7d0c003 e7d14003 e15c0004 0a000002 2a000008 e3e00000 e8bd8010 e35c0000[38375.036192] 89ec  e2833001 0a000001 e1530002 1afffff3 e3a00000 e8bd8010 e3a00001 e8bd8010[38375.044358] [38375.044364] LR: 0xc017a91c:[38375.048605] a91c  e1a00006 e0823005 e5931004 eb087815 e3500000 028d3028 00835005 05150028[38375.056767] a93c  0a000003 e2844001 e3540005 1afffff1 e3e00015 e28dd028 e8bd8070 c0a07890[38375.064926] a95c  e92d4070 e1a06000 e59fe05c e24dd020 e3a04000 e1a0c00d e8be000f e8ac000f[38375.073084] a97c  e89e000f e88c000f e1a05184 e28d2000 e1a00006 e0823005 e5931004 eb0877f9[38375.081244] a99c  e3500000 028d3020 00835005 05150020 0a000003 e2844001 e3540004 1afffff1[38375.089406] a9bc  e3e00015 e28dd020 e8bd8070 c0a078b8 e59f3040 e1a00002 e92d4030 e24dd014[38375.097565] a9dc  e1a0100d e1a05002 e58d300c eb00e471 e2504000 da000004 e1a00005 e59f1018[38375.105724] a9fc  e3a02a01 e2844001 eb08794f e1a00004 e28dd014 e8bd8030 c0f42d98 c0d02180[38375.113887] [38375.113894] SP: 0xec89bdf0:[38375.118138] bdf0  00000000 00000003 00000001 00000000 ec89be2c c039898c 20000093 ffffffff[38375.126297] be10  ec89be5c c0f1f008 c11693d8 00000000 00000000 c0921418 c11093d8 00000000[38375.134456] be30  00000000 00000000 0016002c 00b00160 c11093d8 00000001 c0f1f008 c11693d8[38375.142616] be50  00000000 00000000 c60f3fc0 ec89be70 c017a99c c039898c 20000093 ffffffff[38375.150776] be70  00860000 c0896c84 2c000000 ec00bea4 00115238 00000000 00000000 00000015[38375.158937] be90  0000406a 10c5787d 00000000 00f00000 002c0000 00160003 ea006fc0 c1f193d8[38375.167096] beb0  00160001 c000f008 c11193d8 00000000 00000060 c010aa64 00000001 00000003[38375.175256] bed0  c0f28850 c08dc8a8 00000000 00000003 00000001 00000000 00000003 c0f1f008[38375.183416] [38375.183423] IP: 0xc60f3f40:[38375.187668] 3f40  01ffaaff c011cbe8 38a4f3f4 c5bde01c 02ffaaff c0115ed0 2107f3f5 fa00241c[38375.195830] 3f60  05ffaaff c0114e78 5a1ef3f6 00651916 01ffaaff c01160e0 efb1f3f7 fa002c04[38375.203988] 3f80  01ffaaff c011cbe8 38a4f3f8 c5bde01c 02ffaaff c0115f10 2107f3f9 fa003004[38375.212147] 3fa0  02ffaaff c01164f8 5a00f3fa fa892f00 c0bd8880 c0f18878 00b10040 c0a58874[38375.220307] 3fc0  e8ff80f8 c011e4a4 c10f4c5c 00115238 02ffaaff c0115f44 210ff3fd fa113000[38375.228468] 3fe0  05ffaaff c0114e78 5a1ef3fe 00000016 01ffaaff c01158e0 efb0f3ff fa002828[38375.236627] 4000  01ffaaff c01004a8 38a4f400 fa00300c 02ffaaff c0161de8 2107f401 c5a4c030[38375.244787] 4020  02ffaaff c011c92c 5a1ef402 c5bf4000 02ffaaff c0115914 efb0f403 fa002828[38375.252950] [38375.252957] R0: 0xc1109358:[38375.257201] 9358  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.265359] 9378  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.273520] 9398  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.281680] 93b8  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.289838] 93d8  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.297999] 93f8  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.306158] 9418  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.314318] 9438  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.322481] [38375.322487] R6: 0xc1109358:[38375.326731] 9358  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.334892] 9378  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.343049] 9398  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.351210] 93b8  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.359371] 93d8  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.367531] 93f8  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.375689] 9418  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.383849] 9438  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.392011] [38375.392017] R8: 0xc0f1ef88:[38375.396261] ef88  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.404423] efa8  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.412581] efc8  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.420741] efe8  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.428901] f008  00000009 0000000f 0000000f 00000009 00000000 ec827b80 ec827c00 ec827c80[38375.437061] f028  ec827d00 ec827d80 ec827e00 00000001 00000000 00005e37 c0c3b0cd c0c3b0e2[38375.445221] f048  c0c3b0ee c0c3b0fd c0c3b108 c0c3b113 c0c3b123 c0c3b12e c0c3b135 c0c3b141[38375.453381] f068  c0c3b149 c0c3b154 c0c3b162 c0c3b16d c0c3b17e c0c3b18f 00000000 000003e8[38375.461543] [38375.461549] R9: 0xc1169358:[38375.465793] 9358  00000000 00000000 c011a7b4 00000000 00000000 c011a674 00000000 00000000[38375.473954] 9378  00000000 00000000 00000000 00000000 c0119c80 c011a578 c0119b18 00000000[38375.482113] 9398  00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000[38375.490274] 93b8  00000000 00000000 00000000 eca01990 ec411b80 20010000 00000001 ec0dd510[38375.498432] 93d8  00000000 ec9b66d0 174a174a 00000000 00000001 00000000 c5a2c380 c0176204[38375.506592] 93f8  00000000 fa00a664 00000000 ff81ff81 00000000 ec0e1bd0 ec0e1cc0 c0f341a0[38375.514752] 9418  c1e24a7c 0000000f ec8f8800 00000400 c1169428 c1169428 c017997c 825b825b[38375.522911] 9438  21532153 00000000 00030003 c1169444 c1169444 00000000 00020002 c1169454[38375.531083] Process swapper/3 (pid: 0, stack limit = 0xec89a2f0)[38375.537070] Stack: (0xec89be70 to 0xec89c000)[38375.541414] be60:                                     00860000 c0896c84 2c000000 ec00bea4[38375.549577] be80: 00115238 00000000 00000000 00000015 0000406a 10c5787d 00000000 00f00000[38375.557737] bea0: 002c0000 00160003 ea006fc0 c1f193d8 00160001 c000f008 c11193d8 00000000[38375.565897] bec0: 00000060 c010aa64 00000001 00000003 c0f28850 c08dc8a8 00000000 00000003[38375.574056] bee0: 00000001 00000000 00000003 c0f1f008 00000000 c017764c 976277bc 000022e6[38375.582216] bf00: 00000001 fffffff0 00000003 512f06f1 ec803180 c0178094 c1169488 eb9c62e0[38375.590376] bf20: 00000001 fffffff0 00000002 512f06f1 ec803180 c017b9b0 00790e3e eb9c62e0[38375.598535] bf40: 00000001 000008b6 00000003 00000ea6 002207cc 00000003 00000000 000008b6[38375.606698] bf60: 69367f90 00000003 c1169488 9704ae5e 000022e6 c31008a8 512f06f1 00000003[38375.614858] bf80: 00000000 c017bbbc 9704ae5e 000022e6 00000003 c31008a8 c10bd168 c31008a8[38375.623017] bfa0: c0f42f68 00000003 00000003 c0645bb8 c0645ba4 c0645fa4 c31008a8 c10bd168[38375.631177] bfc0: 00000003 c064616c 00000000 ec89a000 c10f4748 c0f286d0 c10f4a14 0000406a[38375.639336] bfe0: 00000000 c0106fa8 51000400 00000015 10c0387d 0090bf34 00000000 00000000[38375.641526] SMP: failed to stop secondary CPUs[38375.651948] [] (strcmp+0x8/0x3c) from [] (msm_pm_get_sleep_mode_value+0x40/0x70)[38375.661047] [] (msm_pm_get_sleep_mode_value+0x40/0x70) from [] (0xf00000)[38375.669542] Code: 1afffffa e12fff1e e3a03000 e7d02003 (e7d1c003) [38375.675650] CPU3: stopping[38375.678327] [] (unwind_backtrace+0x0/0x11c) from [] (handle_IPI+0x11c/0x1fc)[38375.687089] [] (handle_IPI+0x11c/0x1fc) from [] (gic_handle_irq+0x100/0x10c)[38375.695855] [] (gic_handle_irq+0x100/0x10c) from [] (__irq_svc+0x40/0x70)[38375.704343] Exception stack(0xec89bc80 to 0xec89bcc8)[38375.709387] bc80: c10f49e0 00000000 00020002 00010000 ec89be28 ec84f6c0 ec89a2f0 00000001[38375.717547] bca0: 00000005 00000028 00000005 00000000 00000000 ec89bcc8 c0109d40 c0920e9c[38375.725697] bcc0: 60000113 ffffffff[38375.729189] [] (__irq_svc+0x40/0x70) from [] (_raw_spin_unlock_irq+0x28/0x50)[38375.738050] [] (_raw_spin_unlock_irq+0x28/0x50) from [] (die+0x15c/0x1e0)[38375.746568] [] (die+0x15c/0x1e0) from [] (__do_kernel_fault.part.12+0x54/0x74)[38375.755500] [] (__do_kernel_fault.part.12+0x54/0x74) from [] (do_page_fault+0x394/0x3e8)[38375.765300] [] (do_page_fault+0x394/0x3e8) from [] (do_DataAbort+0x180/0x1ac)[38375.774153] [] (do_DataAbort+0x180/0x1ac) from [] (__dabt_svc+0x38/0x60)[38375.782555] Exception stack(0xec89be28 to 0xec89be70)[38375.787597] be20:                   c11093d8 00000000 00000000 00000000 0016002c 00b00160[38375.795758] be40: c11093d8 00000001 c0f1f008 c11693d8 00000000 00000000 c60f3fc0 ec89be70[38375.803913] be60: c017a99c c039898c 20000093 ffffffff[38375.808970] [] (__dabt_svc+0x38/0x60) from [] (strcmp+0x8/0x3c)[38375.816609] [] (strcmp+0x8/0x3c) from [] (msm_pm_get_sleep_mode_value+0x40/0x70)[38375.825715] [] (msm_pm_get_sleep_mode_value+0x40/0x70) from [] (0xf00000)[38377.501904] wcnss crash shutdown 0[38377.504277] Rebooting in 5 seconds..[38382.509218] Going down for restart now

REFERENCE:
kernel panic之後怎麼辦?