linux-2.6.33/sub_preempt_count()
をテンプレートにして作成
[
トップ
] [
新規
|
一覧
|
検索
|
最終更新
|
ヘルプ
|
ログイン
]
開始行:
*参照元 [#v74e2b41]
#backlinks
*説明 [#z24fbecd]
-パス: 複数あり
--プリエンプションのデバッグが有効: [[linux-2.6.33/kernel...
--プリエンプションのデバッグが無効: [[linux-2.6.33/includ...
-プリエンプションカウントから指定された値を減算する。
**引数 [#u9047e01]
-int val
--プリエンプションカウントから減算する値。
**返り値 [#hedb6c2f]
-なし
**参考 [#i688edaa]
*実装 [#w1ae4717]
**プリエンプションのデバッグが有効: kernel/sched.c [#zb5f...
-プリエンプションのデバッグが有効の場合、こちらが実行される
void __kprobes sub_preempt_count(int val)
{
-kprobes の対象
--[[linux-2.6.33/__kprobes]]
#ifdef CONFIG_DEBUG_PREEMPT
-
--[[linux-2.6.33/CONFIG_DEBUG_PREEMPT]]
/*
* Underflow?
*/
if (DEBUG_LOCKS_WARN_ON(val > preempt_count()))
return;
-
--[[linux-2.6.33/DEBUG_LOCKS_WARN_ON()]]
-
--[[linux-2.6.33/preempt_count()]]
/*
* Is the spinlock portion underflowing?
*/
if (DEBUG_LOCKS_WARN_ON((val < PREEMPT_MASK) &&
!(preempt_count() & PREEMPT_MASK)))
return;
-
--[[linux-2.6.33/PREEMPT_MASK]]
#endif
if (preempt_count() == val)
trace_preempt_on(CALLER_ADDR0, get_parent_ip(CALLER_AD...
-
--[[linux-2.6.33/trace_preempt_on()]]
-
--[[linux-2.6.33/CALLER_ADDR0]]
-
--[[linux-2.6.33/get_parent_ip()]]
-
--[[linux-2.6.33/CALLER_ADDR1]]
preempt_count() -= val;
}
EXPORT_SYMBOL(sub_preempt_count);
-特にライセンスを区別せずシンボルを公開する。
--[[linux-2.6.33/EXPORT_SYMBOL()]]
**プリエンプションのデバッグが無効: include/linux/preempt...
#if defined(CONFIG_DEBUG_PREEMPT) || defined(CONFIG_PREE...
-プリエンプションのデバッグが有効、
あるいはプリエンプションの追跡が有効の場合
--[[linux-2.6.33/CONFIG_DEBUG_PREEMPT]]
--[[linux-2.6.33/CONFIG_PREEMPT_TRACER]]
extern void sub_preempt_count(int val);
-前章(kernel/sched.c)を見てください。
(略)
#else
-プリエンプションのデバッグが無効かつ、
あるいはプリエンプションの追跡が無効の場合
# define sub_preempt_count(val) do { preempt_count() -= ...
-プリエンプションカウントから指定された値を減算する。
--[[linux-2.6.33/preempt_count()]]
(略)
#endif
*コメント [#h975707a]
終了行:
*参照元 [#v74e2b41]
#backlinks
*説明 [#z24fbecd]
-パス: 複数あり
--プリエンプションのデバッグが有効: [[linux-2.6.33/kernel...
--プリエンプションのデバッグが無効: [[linux-2.6.33/includ...
-プリエンプションカウントから指定された値を減算する。
**引数 [#u9047e01]
-int val
--プリエンプションカウントから減算する値。
**返り値 [#hedb6c2f]
-なし
**参考 [#i688edaa]
*実装 [#w1ae4717]
**プリエンプションのデバッグが有効: kernel/sched.c [#zb5f...
-プリエンプションのデバッグが有効の場合、こちらが実行される
void __kprobes sub_preempt_count(int val)
{
-kprobes の対象
--[[linux-2.6.33/__kprobes]]
#ifdef CONFIG_DEBUG_PREEMPT
-
--[[linux-2.6.33/CONFIG_DEBUG_PREEMPT]]
/*
* Underflow?
*/
if (DEBUG_LOCKS_WARN_ON(val > preempt_count()))
return;
-
--[[linux-2.6.33/DEBUG_LOCKS_WARN_ON()]]
-
--[[linux-2.6.33/preempt_count()]]
/*
* Is the spinlock portion underflowing?
*/
if (DEBUG_LOCKS_WARN_ON((val < PREEMPT_MASK) &&
!(preempt_count() & PREEMPT_MASK)))
return;
-
--[[linux-2.6.33/PREEMPT_MASK]]
#endif
if (preempt_count() == val)
trace_preempt_on(CALLER_ADDR0, get_parent_ip(CALLER_AD...
-
--[[linux-2.6.33/trace_preempt_on()]]
-
--[[linux-2.6.33/CALLER_ADDR0]]
-
--[[linux-2.6.33/get_parent_ip()]]
-
--[[linux-2.6.33/CALLER_ADDR1]]
preempt_count() -= val;
}
EXPORT_SYMBOL(sub_preempt_count);
-特にライセンスを区別せずシンボルを公開する。
--[[linux-2.6.33/EXPORT_SYMBOL()]]
**プリエンプションのデバッグが無効: include/linux/preempt...
#if defined(CONFIG_DEBUG_PREEMPT) || defined(CONFIG_PREE...
-プリエンプションのデバッグが有効、
あるいはプリエンプションの追跡が有効の場合
--[[linux-2.6.33/CONFIG_DEBUG_PREEMPT]]
--[[linux-2.6.33/CONFIG_PREEMPT_TRACER]]
extern void sub_preempt_count(int val);
-前章(kernel/sched.c)を見てください。
(略)
#else
-プリエンプションのデバッグが無効かつ、
あるいはプリエンプションの追跡が無効の場合
# define sub_preempt_count(val) do { preempt_count() -= ...
-プリエンプションカウントから指定された値を減算する。
--[[linux-2.6.33/preempt_count()]]
(略)
#endif
*コメント [#h975707a]
ページ名: