1 /*
2  * bebob_terratec.c - a part of driver for BeBoB based devices
3  *
4  * Copyright (c) 2013-2014 Takashi Sakamoto
5  *
6  * Licensed under the terms of the GNU General Public License, version 2.
7  */
8 
9 #include "./bebob.h"
10 
11 static const enum snd_bebob_clock_type phase88_rack_clk_src_types[] = {
12 	SND_BEBOB_CLOCK_TYPE_INTERNAL,
13 	SND_BEBOB_CLOCK_TYPE_EXTERNAL,	/* S/PDIF */
14 	SND_BEBOB_CLOCK_TYPE_EXTERNAL,	/* Word Clock */
15 };
16 static int
phase88_rack_clk_src_get(struct snd_bebob * bebob,unsigned int * id)17 phase88_rack_clk_src_get(struct snd_bebob *bebob, unsigned int *id)
18 {
19 	unsigned int enable_ext, enable_word;
20 	int err;
21 
22 	err = avc_audio_get_selector(bebob->unit, 0, 9, &enable_ext);
23 	if (err < 0)
24 		goto end;
25 	err = avc_audio_get_selector(bebob->unit, 0, 8, &enable_word);
26 	if (err < 0)
27 		goto end;
28 
29 	if (enable_ext == 0)
30 		*id = 0;
31 	else if (enable_word == 0)
32 		*id = 1;
33 	else
34 		*id = 2;
35 end:
36 	return err;
37 }
38 
39 static const struct snd_bebob_rate_spec phase_series_rate_spec = {
40 	.get	= &snd_bebob_stream_get_rate,
41 	.set	= &snd_bebob_stream_set_rate,
42 };
43 
44 /* PHASE 88 Rack FW */
45 static const struct snd_bebob_clock_spec phase88_rack_clk = {
46 	.num	= ARRAY_SIZE(phase88_rack_clk_src_types),
47 	.types	= phase88_rack_clk_src_types,
48 	.get	= &phase88_rack_clk_src_get,
49 };
50 const struct snd_bebob_spec phase88_rack_spec = {
51 	.clock	= &phase88_rack_clk,
52 	.rate	= &phase_series_rate_spec,
53 	.meter	= NULL
54 };
55