Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
70f7922c
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
70f7922c
编写于
9月 04, 2018
作者:
T
Takashi Iwai
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'topic/pcm-indirect-fixes' into for-next
Signed-off-by:
N
Takashi Iwai
<
tiwai@suse.de
>
上级
b917d58d
d873d5ea
变更
7
显示空白变更内容
内联
并排
Showing
7 changed file
with
30 addition
and
43 deletion
+30
-43
sound/core/rawmidi.c
sound/core/rawmidi.c
+2
-2
sound/hda/ext/hdac_ext_stream.c
sound/hda/ext/hdac_ext_stream.c
+7
-15
sound/mips/hal2.c
sound/mips/hal2.c
+5
-8
sound/pci/cs46xx/cs46xx_lib.c
sound/pci/cs46xx/cs46xx_lib.c
+4
-2
sound/pci/emu10k1/emupcm.c
sound/pci/emu10k1/emupcm.c
+2
-1
sound/pci/hda/hda_codec.c
sound/pci/hda/hda_codec.c
+2
-1
sound/pci/rme32.c
sound/pci/rme32.c
+8
-14
未找到文件。
sound/core/rawmidi.c
浏览文件 @
70f7922c
...
@@ -129,7 +129,7 @@ static int snd_rawmidi_runtime_create(struct snd_rawmidi_substream *substream)
...
@@ -129,7 +129,7 @@ static int snd_rawmidi_runtime_create(struct snd_rawmidi_substream *substream)
runtime
->
avail
=
0
;
runtime
->
avail
=
0
;
else
else
runtime
->
avail
=
runtime
->
buffer_size
;
runtime
->
avail
=
runtime
->
buffer_size
;
runtime
->
buffer
=
kv
m
alloc
(
runtime
->
buffer_size
,
GFP_KERNEL
);
runtime
->
buffer
=
kv
z
alloc
(
runtime
->
buffer_size
,
GFP_KERNEL
);
if
(
!
runtime
->
buffer
)
{
if
(
!
runtime
->
buffer
)
{
kfree
(
runtime
);
kfree
(
runtime
);
return
-
ENOMEM
;
return
-
ENOMEM
;
...
@@ -655,7 +655,7 @@ static int resize_runtime_buffer(struct snd_rawmidi_runtime *runtime,
...
@@ -655,7 +655,7 @@ static int resize_runtime_buffer(struct snd_rawmidi_runtime *runtime,
if
(
params
->
avail_min
<
1
||
params
->
avail_min
>
params
->
buffer_size
)
if
(
params
->
avail_min
<
1
||
params
->
avail_min
>
params
->
buffer_size
)
return
-
EINVAL
;
return
-
EINVAL
;
if
(
params
->
buffer_size
!=
runtime
->
buffer_size
)
{
if
(
params
->
buffer_size
!=
runtime
->
buffer_size
)
{
newbuf
=
kv
m
alloc
(
params
->
buffer_size
,
GFP_KERNEL
);
newbuf
=
kv
z
alloc
(
params
->
buffer_size
,
GFP_KERNEL
);
if
(
!
newbuf
)
if
(
!
newbuf
)
return
-
ENOMEM
;
return
-
ENOMEM
;
spin_lock_irq
(
&
runtime
->
lock
);
spin_lock_irq
(
&
runtime
->
lock
);
...
...
sound/hda/ext/hdac_ext_stream.c
浏览文件 @
70f7922c
...
@@ -146,7 +146,8 @@ EXPORT_SYMBOL_GPL(snd_hdac_ext_stream_decouple);
...
@@ -146,7 +146,8 @@ EXPORT_SYMBOL_GPL(snd_hdac_ext_stream_decouple);
*/
*/
void
snd_hdac_ext_link_stream_start
(
struct
hdac_ext_stream
*
stream
)
void
snd_hdac_ext_link_stream_start
(
struct
hdac_ext_stream
*
stream
)
{
{
snd_hdac_updatel
(
stream
->
pplc_addr
,
AZX_REG_PPLCCTL
,
0
,
AZX_PPLCCTL_RUN
);
snd_hdac_updatel
(
stream
->
pplc_addr
,
AZX_REG_PPLCCTL
,
AZX_PPLCCTL_RUN
,
AZX_PPLCCTL_RUN
);
}
}
EXPORT_SYMBOL_GPL
(
snd_hdac_ext_link_stream_start
);
EXPORT_SYMBOL_GPL
(
snd_hdac_ext_link_stream_start
);
...
@@ -171,7 +172,8 @@ void snd_hdac_ext_link_stream_reset(struct hdac_ext_stream *stream)
...
@@ -171,7 +172,8 @@ void snd_hdac_ext_link_stream_reset(struct hdac_ext_stream *stream)
snd_hdac_ext_link_stream_clear
(
stream
);
snd_hdac_ext_link_stream_clear
(
stream
);
snd_hdac_updatel
(
stream
->
pplc_addr
,
AZX_REG_PPLCCTL
,
0
,
AZX_PPLCCTL_STRST
);
snd_hdac_updatel
(
stream
->
pplc_addr
,
AZX_REG_PPLCCTL
,
AZX_PPLCCTL_STRST
,
AZX_PPLCCTL_STRST
);
udelay
(
3
);
udelay
(
3
);
timeout
=
50
;
timeout
=
50
;
do
{
do
{
...
@@ -242,7 +244,7 @@ EXPORT_SYMBOL_GPL(snd_hdac_ext_link_set_stream_id);
...
@@ -242,7 +244,7 @@ EXPORT_SYMBOL_GPL(snd_hdac_ext_link_set_stream_id);
void
snd_hdac_ext_link_clear_stream_id
(
struct
hdac_ext_link
*
link
,
void
snd_hdac_ext_link_clear_stream_id
(
struct
hdac_ext_link
*
link
,
int
stream
)
int
stream
)
{
{
snd_hdac_updatew
(
link
->
ml_addr
,
AZX_REG_ML_LOSIDV
,
0
,
(
1
<<
stream
)
);
snd_hdac_updatew
(
link
->
ml_addr
,
AZX_REG_ML_LOSIDV
,
(
1
<<
stream
),
0
);
}
}
EXPORT_SYMBOL_GPL
(
snd_hdac_ext_link_clear_stream_id
);
EXPORT_SYMBOL_GPL
(
snd_hdac_ext_link_clear_stream_id
);
...
@@ -415,7 +417,6 @@ void snd_hdac_ext_stream_spbcap_enable(struct hdac_bus *bus,
...
@@ -415,7 +417,6 @@ void snd_hdac_ext_stream_spbcap_enable(struct hdac_bus *bus,
bool
enable
,
int
index
)
bool
enable
,
int
index
)
{
{
u32
mask
=
0
;
u32
mask
=
0
;
u32
register_mask
=
0
;
if
(
!
bus
->
spbcap
)
{
if
(
!
bus
->
spbcap
)
{
dev_err
(
bus
->
dev
,
"Address of SPB capability is NULL
\n
"
);
dev_err
(
bus
->
dev
,
"Address of SPB capability is NULL
\n
"
);
...
@@ -424,12 +425,8 @@ void snd_hdac_ext_stream_spbcap_enable(struct hdac_bus *bus,
...
@@ -424,12 +425,8 @@ void snd_hdac_ext_stream_spbcap_enable(struct hdac_bus *bus,
mask
|=
(
1
<<
index
);
mask
|=
(
1
<<
index
);
register_mask
=
readl
(
bus
->
spbcap
+
AZX_REG_SPB_SPBFCCTL
);
mask
|=
register_mask
;
if
(
enable
)
if
(
enable
)
snd_hdac_updatel
(
bus
->
spbcap
,
AZX_REG_SPB_SPBFCCTL
,
0
,
mask
);
snd_hdac_updatel
(
bus
->
spbcap
,
AZX_REG_SPB_SPBFCCTL
,
mask
,
mask
);
else
else
snd_hdac_updatel
(
bus
->
spbcap
,
AZX_REG_SPB_SPBFCCTL
,
mask
,
0
);
snd_hdac_updatel
(
bus
->
spbcap
,
AZX_REG_SPB_SPBFCCTL
,
mask
,
0
);
}
}
...
@@ -503,7 +500,6 @@ void snd_hdac_ext_stream_drsm_enable(struct hdac_bus *bus,
...
@@ -503,7 +500,6 @@ void snd_hdac_ext_stream_drsm_enable(struct hdac_bus *bus,
bool
enable
,
int
index
)
bool
enable
,
int
index
)
{
{
u32
mask
=
0
;
u32
mask
=
0
;
u32
register_mask
=
0
;
if
(
!
bus
->
drsmcap
)
{
if
(
!
bus
->
drsmcap
)
{
dev_err
(
bus
->
dev
,
"Address of DRSM capability is NULL
\n
"
);
dev_err
(
bus
->
dev
,
"Address of DRSM capability is NULL
\n
"
);
...
@@ -512,12 +508,8 @@ void snd_hdac_ext_stream_drsm_enable(struct hdac_bus *bus,
...
@@ -512,12 +508,8 @@ void snd_hdac_ext_stream_drsm_enable(struct hdac_bus *bus,
mask
|=
(
1
<<
index
);
mask
|=
(
1
<<
index
);
register_mask
=
readl
(
bus
->
drsmcap
+
AZX_REG_SPB_SPBFCCTL
);
mask
|=
register_mask
;
if
(
enable
)
if
(
enable
)
snd_hdac_updatel
(
bus
->
drsmcap
,
AZX_REG_DRSM_CTL
,
0
,
mask
);
snd_hdac_updatel
(
bus
->
drsmcap
,
AZX_REG_DRSM_CTL
,
mask
,
mask
);
else
else
snd_hdac_updatel
(
bus
->
drsmcap
,
AZX_REG_DRSM_CTL
,
mask
,
0
);
snd_hdac_updatel
(
bus
->
drsmcap
,
AZX_REG_DRSM_CTL
,
mask
,
0
);
}
}
...
...
sound/mips/hal2.c
浏览文件 @
70f7922c
...
@@ -500,7 +500,8 @@ static const struct snd_pcm_hardware hal2_pcm_hw = {
...
@@ -500,7 +500,8 @@ static const struct snd_pcm_hardware hal2_pcm_hw = {
.
info
=
(
SNDRV_PCM_INFO_MMAP
|
.
info
=
(
SNDRV_PCM_INFO_MMAP
|
SNDRV_PCM_INFO_MMAP_VALID
|
SNDRV_PCM_INFO_MMAP_VALID
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_BLOCK_TRANSFER
),
SNDRV_PCM_INFO_BLOCK_TRANSFER
|
SNDRV_PCM_INFO_SYNC_APPLPTR
),
.
formats
=
SNDRV_PCM_FMTBIT_S16_BE
,
.
formats
=
SNDRV_PCM_FMTBIT_S16_BE
,
.
rates
=
SNDRV_PCM_RATE_8000_48000
,
.
rates
=
SNDRV_PCM_RATE_8000_48000
,
.
rate_min
=
8000
,
.
rate_min
=
8000
,
...
@@ -563,6 +564,8 @@ static int hal2_playback_prepare(struct snd_pcm_substream *substream)
...
@@ -563,6 +564,8 @@ static int hal2_playback_prepare(struct snd_pcm_substream *substream)
dac
->
sample_rate
=
hal2_compute_rate
(
dac
,
runtime
->
rate
);
dac
->
sample_rate
=
hal2_compute_rate
(
dac
,
runtime
->
rate
);
memset
(
&
dac
->
pcm_indirect
,
0
,
sizeof
(
dac
->
pcm_indirect
));
memset
(
&
dac
->
pcm_indirect
,
0
,
sizeof
(
dac
->
pcm_indirect
));
dac
->
pcm_indirect
.
hw_buffer_size
=
H2_BUF_SIZE
;
dac
->
pcm_indirect
.
hw_buffer_size
=
H2_BUF_SIZE
;
dac
->
pcm_indirect
.
hw_queue_size
=
H2_BUF_SIZE
/
2
;
dac
->
pcm_indirect
.
hw_io
=
dac
->
buffer_dma
;
dac
->
pcm_indirect
.
sw_buffer_size
=
snd_pcm_lib_buffer_bytes
(
substream
);
dac
->
pcm_indirect
.
sw_buffer_size
=
snd_pcm_lib_buffer_bytes
(
substream
);
dac
->
substream
=
substream
;
dac
->
substream
=
substream
;
hal2_setup_dac
(
hal2
);
hal2_setup_dac
(
hal2
);
...
@@ -575,9 +578,6 @@ static int hal2_playback_trigger(struct snd_pcm_substream *substream, int cmd)
...
@@ -575,9 +578,6 @@ static int hal2_playback_trigger(struct snd_pcm_substream *substream, int cmd)
switch
(
cmd
)
{
switch
(
cmd
)
{
case
SNDRV_PCM_TRIGGER_START
:
case
SNDRV_PCM_TRIGGER_START
:
hal2
->
dac
.
pcm_indirect
.
hw_io
=
hal2
->
dac
.
buffer_dma
;
hal2
->
dac
.
pcm_indirect
.
hw_data
=
0
;
substream
->
ops
->
ack
(
substream
);
hal2_start_dac
(
hal2
);
hal2_start_dac
(
hal2
);
break
;
break
;
case
SNDRV_PCM_TRIGGER_STOP
:
case
SNDRV_PCM_TRIGGER_STOP
:
...
@@ -615,7 +615,6 @@ static int hal2_playback_ack(struct snd_pcm_substream *substream)
...
@@ -615,7 +615,6 @@ static int hal2_playback_ack(struct snd_pcm_substream *substream)
struct
snd_hal2
*
hal2
=
snd_pcm_substream_chip
(
substream
);
struct
snd_hal2
*
hal2
=
snd_pcm_substream_chip
(
substream
);
struct
hal2_codec
*
dac
=
&
hal2
->
dac
;
struct
hal2_codec
*
dac
=
&
hal2
->
dac
;
dac
->
pcm_indirect
.
hw_queue_size
=
H2_BUF_SIZE
/
2
;
return
snd_pcm_indirect_playback_transfer
(
substream
,
return
snd_pcm_indirect_playback_transfer
(
substream
,
&
dac
->
pcm_indirect
,
&
dac
->
pcm_indirect
,
hal2_playback_transfer
);
hal2_playback_transfer
);
...
@@ -655,6 +654,7 @@ static int hal2_capture_prepare(struct snd_pcm_substream *substream)
...
@@ -655,6 +654,7 @@ static int hal2_capture_prepare(struct snd_pcm_substream *substream)
memset
(
&
adc
->
pcm_indirect
,
0
,
sizeof
(
adc
->
pcm_indirect
));
memset
(
&
adc
->
pcm_indirect
,
0
,
sizeof
(
adc
->
pcm_indirect
));
adc
->
pcm_indirect
.
hw_buffer_size
=
H2_BUF_SIZE
;
adc
->
pcm_indirect
.
hw_buffer_size
=
H2_BUF_SIZE
;
adc
->
pcm_indirect
.
hw_queue_size
=
H2_BUF_SIZE
/
2
;
adc
->
pcm_indirect
.
hw_queue_size
=
H2_BUF_SIZE
/
2
;
adc
->
pcm_indirect
.
hw_io
=
adc
->
buffer_dma
;
adc
->
pcm_indirect
.
sw_buffer_size
=
snd_pcm_lib_buffer_bytes
(
substream
);
adc
->
pcm_indirect
.
sw_buffer_size
=
snd_pcm_lib_buffer_bytes
(
substream
);
adc
->
substream
=
substream
;
adc
->
substream
=
substream
;
hal2_setup_adc
(
hal2
);
hal2_setup_adc
(
hal2
);
...
@@ -667,9 +667,6 @@ static int hal2_capture_trigger(struct snd_pcm_substream *substream, int cmd)
...
@@ -667,9 +667,6 @@ static int hal2_capture_trigger(struct snd_pcm_substream *substream, int cmd)
switch
(
cmd
)
{
switch
(
cmd
)
{
case
SNDRV_PCM_TRIGGER_START
:
case
SNDRV_PCM_TRIGGER_START
:
hal2
->
adc
.
pcm_indirect
.
hw_io
=
hal2
->
adc
.
buffer_dma
;
hal2
->
adc
.
pcm_indirect
.
hw_data
=
0
;
printk
(
KERN_DEBUG
"buffer_dma %x
\n
"
,
hal2
->
adc
.
buffer_dma
);
hal2_start_adc
(
hal2
);
hal2_start_adc
(
hal2
);
break
;
break
;
case
SNDRV_PCM_TRIGGER_STOP
:
case
SNDRV_PCM_TRIGGER_STOP
:
...
...
sound/pci/cs46xx/cs46xx_lib.c
浏览文件 @
70f7922c
...
@@ -1443,7 +1443,8 @@ static const struct snd_pcm_hardware snd_cs46xx_playback =
...
@@ -1443,7 +1443,8 @@ static const struct snd_pcm_hardware snd_cs46xx_playback =
.
info
=
(
SNDRV_PCM_INFO_MMAP
|
.
info
=
(
SNDRV_PCM_INFO_MMAP
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_BLOCK_TRANSFER
/*|*/
SNDRV_PCM_INFO_BLOCK_TRANSFER
/*|*/
/*SNDRV_PCM_INFO_RESUME*/
),
/*SNDRV_PCM_INFO_RESUME*/
|
SNDRV_PCM_INFO_SYNC_APPLPTR
),
.
formats
=
(
SNDRV_PCM_FMTBIT_S8
|
SNDRV_PCM_FMTBIT_U8
|
.
formats
=
(
SNDRV_PCM_FMTBIT_S8
|
SNDRV_PCM_FMTBIT_U8
|
SNDRV_PCM_FMTBIT_S16_LE
|
SNDRV_PCM_FMTBIT_S16_BE
|
SNDRV_PCM_FMTBIT_S16_LE
|
SNDRV_PCM_FMTBIT_S16_BE
|
SNDRV_PCM_FMTBIT_U16_LE
|
SNDRV_PCM_FMTBIT_U16_BE
),
SNDRV_PCM_FMTBIT_U16_LE
|
SNDRV_PCM_FMTBIT_U16_BE
),
...
@@ -1465,7 +1466,8 @@ static const struct snd_pcm_hardware snd_cs46xx_capture =
...
@@ -1465,7 +1466,8 @@ static const struct snd_pcm_hardware snd_cs46xx_capture =
.
info
=
(
SNDRV_PCM_INFO_MMAP
|
.
info
=
(
SNDRV_PCM_INFO_MMAP
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_BLOCK_TRANSFER
/*|*/
SNDRV_PCM_INFO_BLOCK_TRANSFER
/*|*/
/*SNDRV_PCM_INFO_RESUME*/
),
/*SNDRV_PCM_INFO_RESUME*/
|
SNDRV_PCM_INFO_SYNC_APPLPTR
),
.
formats
=
SNDRV_PCM_FMTBIT_S16_LE
,
.
formats
=
SNDRV_PCM_FMTBIT_S16_LE
,
.
rates
=
SNDRV_PCM_RATE_CONTINUOUS
|
SNDRV_PCM_RATE_8000_48000
,
.
rates
=
SNDRV_PCM_RATE_CONTINUOUS
|
SNDRV_PCM_RATE_8000_48000
,
.
rate_min
=
5500
,
.
rate_min
=
5500
,
...
...
sound/pci/emu10k1/emupcm.c
浏览文件 @
70f7922c
...
@@ -1753,7 +1753,8 @@ static const struct snd_pcm_hardware snd_emu10k1_fx8010_playback =
...
@@ -1753,7 +1753,8 @@ static const struct snd_pcm_hardware snd_emu10k1_fx8010_playback =
{
{
.
info
=
(
SNDRV_PCM_INFO_MMAP
|
SNDRV_PCM_INFO_INTERLEAVED
|
.
info
=
(
SNDRV_PCM_INFO_MMAP
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_RESUME
|
SNDRV_PCM_INFO_RESUME
|
/* SNDRV_PCM_INFO_MMAP_VALID | */
SNDRV_PCM_INFO_PAUSE
),
/* SNDRV_PCM_INFO_MMAP_VALID | */
SNDRV_PCM_INFO_PAUSE
|
SNDRV_PCM_INFO_SYNC_APPLPTR
),
.
formats
=
SNDRV_PCM_FMTBIT_U8
|
SNDRV_PCM_FMTBIT_S16_LE
,
.
formats
=
SNDRV_PCM_FMTBIT_U8
|
SNDRV_PCM_FMTBIT_S16_LE
,
.
rates
=
SNDRV_PCM_RATE_48000
,
.
rates
=
SNDRV_PCM_RATE_48000
,
.
rate_min
=
48000
,
.
rate_min
=
48000
,
...
...
sound/pci/hda/hda_codec.c
浏览文件 @
70f7922c
...
@@ -3935,6 +3935,7 @@ void snd_hda_bus_reset_codecs(struct hda_bus *bus)
...
@@ -3935,6 +3935,7 @@ void snd_hda_bus_reset_codecs(struct hda_bus *bus)
list_for_each_codec
(
codec
,
bus
)
{
list_for_each_codec
(
codec
,
bus
)
{
/* FIXME: maybe a better way needed for forced reset */
/* FIXME: maybe a better way needed for forced reset */
if
(
current_work
()
!=
&
codec
->
jackpoll_work
.
work
)
cancel_delayed_work_sync
(
&
codec
->
jackpoll_work
);
cancel_delayed_work_sync
(
&
codec
->
jackpoll_work
);
#ifdef CONFIG_PM
#ifdef CONFIG_PM
if
(
hda_codec_is_power_on
(
codec
))
{
if
(
hda_codec_is_power_on
(
codec
))
{
...
...
sound/pci/rme32.c
浏览文件 @
70f7922c
...
@@ -319,7 +319,8 @@ static const struct snd_pcm_hardware snd_rme32_spdif_info = {
...
@@ -319,7 +319,8 @@ static const struct snd_pcm_hardware snd_rme32_spdif_info = {
SNDRV_PCM_INFO_MMAP_VALID
|
SNDRV_PCM_INFO_MMAP_VALID
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_PAUSE
|
SNDRV_PCM_INFO_PAUSE
|
SNDRV_PCM_INFO_SYNC_START
),
SNDRV_PCM_INFO_SYNC_START
|
SNDRV_PCM_INFO_SYNC_APPLPTR
),
.
formats
=
(
SNDRV_PCM_FMTBIT_S16_LE
|
.
formats
=
(
SNDRV_PCM_FMTBIT_S16_LE
|
SNDRV_PCM_FMTBIT_S32_LE
),
SNDRV_PCM_FMTBIT_S32_LE
),
.
rates
=
(
SNDRV_PCM_RATE_32000
|
.
rates
=
(
SNDRV_PCM_RATE_32000
|
...
@@ -346,7 +347,8 @@ static const struct snd_pcm_hardware snd_rme32_adat_info =
...
@@ -346,7 +347,8 @@ static const struct snd_pcm_hardware snd_rme32_adat_info =
SNDRV_PCM_INFO_MMAP_VALID
|
SNDRV_PCM_INFO_MMAP_VALID
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_PAUSE
|
SNDRV_PCM_INFO_PAUSE
|
SNDRV_PCM_INFO_SYNC_START
),
SNDRV_PCM_INFO_SYNC_START
|
SNDRV_PCM_INFO_SYNC_APPLPTR
),
.
formats
=
SNDRV_PCM_FMTBIT_S16_LE
,
.
formats
=
SNDRV_PCM_FMTBIT_S16_LE
,
.
rates
=
(
SNDRV_PCM_RATE_44100
|
.
rates
=
(
SNDRV_PCM_RATE_44100
|
SNDRV_PCM_RATE_48000
),
SNDRV_PCM_RATE_48000
),
...
@@ -370,7 +372,8 @@ static const struct snd_pcm_hardware snd_rme32_spdif_fd_info = {
...
@@ -370,7 +372,8 @@ static const struct snd_pcm_hardware snd_rme32_spdif_fd_info = {
SNDRV_PCM_INFO_MMAP_VALID
|
SNDRV_PCM_INFO_MMAP_VALID
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_PAUSE
|
SNDRV_PCM_INFO_PAUSE
|
SNDRV_PCM_INFO_SYNC_START
),
SNDRV_PCM_INFO_SYNC_START
|
SNDRV_PCM_INFO_SYNC_APPLPTR
),
.
formats
=
(
SNDRV_PCM_FMTBIT_S16_LE
|
.
formats
=
(
SNDRV_PCM_FMTBIT_S16_LE
|
SNDRV_PCM_FMTBIT_S32_LE
),
SNDRV_PCM_FMTBIT_S32_LE
),
.
rates
=
(
SNDRV_PCM_RATE_32000
|
.
rates
=
(
SNDRV_PCM_RATE_32000
|
...
@@ -397,7 +400,8 @@ static const struct snd_pcm_hardware snd_rme32_adat_fd_info =
...
@@ -397,7 +400,8 @@ static const struct snd_pcm_hardware snd_rme32_adat_fd_info =
SNDRV_PCM_INFO_MMAP_VALID
|
SNDRV_PCM_INFO_MMAP_VALID
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_INTERLEAVED
|
SNDRV_PCM_INFO_PAUSE
|
SNDRV_PCM_INFO_PAUSE
|
SNDRV_PCM_INFO_SYNC_START
),
SNDRV_PCM_INFO_SYNC_START
|
SNDRV_PCM_INFO_SYNC_APPLPTR
),
.
formats
=
SNDRV_PCM_FMTBIT_S16_LE
,
.
formats
=
SNDRV_PCM_FMTBIT_S16_LE
,
.
rates
=
(
SNDRV_PCM_RATE_44100
|
.
rates
=
(
SNDRV_PCM_RATE_44100
|
SNDRV_PCM_RATE_48000
),
SNDRV_PCM_RATE_48000
),
...
@@ -1104,16 +1108,6 @@ snd_rme32_pcm_trigger(struct snd_pcm_substream *substream, int cmd)
...
@@ -1104,16 +1108,6 @@ snd_rme32_pcm_trigger(struct snd_pcm_substream *substream, int cmd)
snd_pcm_trigger_done
(
s
,
substream
);
snd_pcm_trigger_done
(
s
,
substream
);
}
}
/* prefill playback buffer */
if
(
cmd
==
SNDRV_PCM_TRIGGER_START
&&
rme32
->
fullduplex_mode
)
{
snd_pcm_group_for_each_entry
(
s
,
substream
)
{
if
(
s
==
rme32
->
playback_substream
)
{
s
->
ops
->
ack
(
s
);
break
;
}
}
}
switch
(
cmd
)
{
switch
(
cmd
)
{
case
SNDRV_PCM_TRIGGER_START
:
case
SNDRV_PCM_TRIGGER_START
:
if
(
rme32
->
running
&&
!
RME32_ISWORKING
(
rme32
))
if
(
rme32
->
running
&&
!
RME32_ISWORKING
(
rme32
))
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录