熱插拔操作

2021-10-16 10:12:23 字數 1231 閱讀 5181

熱插拔事件的實際控制是通過一套儲存於 kset_hotplug_ops 結構的方法完成.

struct kset_hotplug_ops ;

乙個指向這個結構的指標在 kset 結構的 hotplug_ops 成員中. 如果乙個給定的kobject 不包含在乙個 kset 中, 核心搜尋整個層次( 通過 parent 指標) 直到它發現乙個 kobject 確實有乙個 kset; 接著使用這個 kset 的熱插拔操作.

filter 熱插拔操作被呼叫無論何時核心在考慮為給定 kobject 產生乙個事件. 如果filter 返回 0, 事件沒有建立. 這個方法, 因此, 給 kset **乙個機會來決定哪個事件應當被傳遞給使用者空間以及哪個不.

作為乙個例子關於這個方法怎樣被使用, 考慮塊裝置子系統. 至少有 3 類 kobject 用在那裡, 表示磁碟, 分割槽, 和請求佇列. 使用者空間可能想對磁碟或分割槽的增加作出反應, 但是它正常地不關心請求佇列. 因此 filter 方法允許事件產生只給代表磁碟和分割槽的kobjects. 它看來如此:

static int block_hotplug_filter(struct kset *kset, struct kobject *kobj)

這裡, 乙個快速的在 kobject 型別上的測試是足以決定是否這個事件應當產生或者不.

當使用者空間熱插拔程式被呼叫, 它被傳遞給相關子系統的 name 作為它唯一的乙個引數. name 熱插拔方法負責提供這個名子. 它應當返回乙個簡單的適合傳遞給使用者空間的字串.

熱插拔指令碼的可能想知道的其他所有東東都在環境中傳遞. 最終的熱插拔方法( hotplug ) 給了乙個機會來在呼叫這個指令碼之前新增有用的環境變數. 再次, 這個方法的原型是:

int (*hotplug)(struct kset *kset, struct kobject *kobj, char **envp, int num_envp, char *buffer,

int buffer_size);

如常, kset 和 kobject 描述事件產生給的物件. envp 陣列是乙個地方來儲存額外的環境變數定義(以通常的 name=值 的格式); 它有 num_envp 個入口變數. 這些變數自身應當被編碼入緩衝, 緩衝是 buffer_size 位元組長. 如果你新增任何變數到 envp, 確信新增乙個 null 入口在你最後的新增項後面, 這樣核心知道結尾在**. 返回值正常應當是 0; 任何非零返回都終止熱插拔事件的產生.

熱插拔事件的產生(象在裝置模型中大部分工作)常常是由在匯流排驅動級的邏輯處理.

監視熱插拔事件

include include include include include include include include include include static int init hotplug sock void set receive buffersize setsockopt ho...

springboot進行熱插拔

在開發web程式過程中,如果是普通框架,在修改的時候還需要重新部署,這非常麻煩。因為有時候程式啟動的時間實在是讓我們咬牙切齒。幸好,springboot有了這樣乙個工具,它可以讓你在修改儲存的時候很快的進行熱插拔,不再浪費時間。你只需要新增以下依賴即可 org.springframework.boo...

T卡熱插拔

1 配置 gpio 管腳 gpio方向 debounce polarity sensitive level host1 cdpin eint16 16input pull up enable time 1ms lowlevel gpio16,eintmode inpullen inpullselhi...