Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
941a74ca
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
941a74ca
编写于
9月 15, 2014
作者:
T
Takashi Iwai
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ALSA: Update document about PCM nonatomic ops
Signed-off-by:
N
Takashi Iwai
<
tiwai@suse.de
>
上级
3b73cfe5
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
23 addition
and
5 deletion
+23
-5
Documentation/DocBook/writing-an-alsa-driver.tmpl
Documentation/DocBook/writing-an-alsa-driver.tmpl
+23
-5
未找到文件。
Documentation/DocBook/writing-an-alsa-driver.tmpl
浏览文件 @
941a74ca
...
@@ -2742,7 +2742,9 @@ struct _snd_pcm_runtime {
...
@@ -2742,7 +2742,9 @@ struct _snd_pcm_runtime {
<para>
<para>
Another note is that this callback is non-atomic
Another note is that this callback is non-atomic
(schedulable). This is important, because the
(schedulable) as default, i.e. when no
<structfield>
nonatomic
</structfield>
flag set.
This is important, because the
<structfield>
trigger
</structfield>
callback
<structfield>
trigger
</structfield>
callback
is atomic (non-schedulable). That is, mutexes or any
is atomic (non-schedulable). That is, mutexes or any
schedule-related functions are not available in
schedule-related functions are not available in
...
@@ -2900,8 +2902,9 @@ struct _snd_pcm_runtime {
...
@@ -2900,8 +2902,9 @@ struct _snd_pcm_runtime {
</para>
</para>
<para>
<para>
As mentioned, this callback is atomic. You cannot call
As mentioned, this callback is atomic as default unless
functions which may sleep.
<structfield>
nonatomic
</structfield>
flag set, and
you cannot call functions which may sleep.
The trigger callback should be as minimal as possible,
The trigger callback should be as minimal as possible,
just really triggering the DMA. The other stuff should be
just really triggering the DMA. The other stuff should be
initialized hw_params and prepare callbacks properly
initialized hw_params and prepare callbacks properly
...
@@ -2936,7 +2939,7 @@ struct _snd_pcm_runtime {
...
@@ -2936,7 +2939,7 @@ struct _snd_pcm_runtime {
</para>
</para>
<para>
<para>
This callback is also atomic.
This callback is also atomic
as default
.
</para>
</para>
</section>
</section>
...
@@ -2972,7 +2975,7 @@ struct _snd_pcm_runtime {
...
@@ -2972,7 +2975,7 @@ struct _snd_pcm_runtime {
is useful only for such a purpose.
is useful only for such a purpose.
</para>
</para>
<para>
<para>
This callback is atomic.
This callback is atomic
as default
.
</para>
</para>
</section>
</section>
...
@@ -3175,6 +3178,21 @@ struct _snd_pcm_runtime {
...
@@ -3175,6 +3178,21 @@ struct _snd_pcm_runtime {
called with local interrupts disabled.
called with local interrupts disabled.
</para>
</para>
<para>
The recent changes in PCM core code, however, allow all PCM
operations to be non-atomic. This assumes that the all caller
sides are in non-atomic contexts. For example, the function
<function>
snd_pcm_period_elapsed()
</function>
is called
typically from the interrupt handler. But, if you set up the
driver to use a threaded interrupt handler, this call can be in
non-atomic context, too. In such a case, you can set
<structfield>
nonatomic
</structfield>
filed of
<structname>
snd_pcm
</structname>
object after creating it.
When this flag is set, mutex and rwsem are used internally in
the PCM core instead of spin and rwlocks, so that you can call
all PCM functions safely in a non-atomic context.
</para>
</section>
</section>
<section
id=
"pcm-interface-constraints"
>
<section
id=
"pcm-interface-constraints"
>
<title>
Constraints
</title>
<title>
Constraints
</title>
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录