diff options
author | Daniel Mack <daniel@caiaq.de> | 2010-05-31 07:35:41 -0400 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2010-05-31 12:17:22 -0400 |
commit | 65f25da44b51f55e3a74301c25f29263be2bf1ba (patch) | |
tree | 5a2e91b0af5a0000b6c404f625b3933dd81aaae3 /sound/usb/mixer.c | |
parent | 79f920fbff566ffc9de44111eb1456a3cef310f0 (diff) |
ALSA: usb-audio: unify constants from specification
Move more definitions from private enums to appropriate header files.
Signed-off-by: Daniel Mack <daniel@caiaq.de>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/usb/mixer.c')
-rw-r--r-- | sound/usb/mixer.c | 99 |
1 files changed, 33 insertions, 66 deletions
diff --git a/sound/usb/mixer.c b/sound/usb/mixer.c index 9149a84c716f..24428198ae1b 100644 --- a/sound/usb/mixer.c +++ b/sound/usb/mixer.c | |||
@@ -78,39 +78,6 @@ enum { | |||
78 | USB_MIXER_U16, | 78 | USB_MIXER_U16, |
79 | }; | 79 | }; |
80 | 80 | ||
81 | enum { | ||
82 | USB_PROC_UPDOWN = 1, | ||
83 | USB_PROC_UPDOWN_SWITCH = 1, | ||
84 | USB_PROC_UPDOWN_MODE_SEL = 2, | ||
85 | |||
86 | USB_PROC_PROLOGIC = 2, | ||
87 | USB_PROC_PROLOGIC_SWITCH = 1, | ||
88 | USB_PROC_PROLOGIC_MODE_SEL = 2, | ||
89 | |||
90 | USB_PROC_3DENH = 3, | ||
91 | USB_PROC_3DENH_SWITCH = 1, | ||
92 | USB_PROC_3DENH_SPACE = 2, | ||
93 | |||
94 | USB_PROC_REVERB = 4, | ||
95 | USB_PROC_REVERB_SWITCH = 1, | ||
96 | USB_PROC_REVERB_LEVEL = 2, | ||
97 | USB_PROC_REVERB_TIME = 3, | ||
98 | USB_PROC_REVERB_DELAY = 4, | ||
99 | |||
100 | USB_PROC_CHORUS = 5, | ||
101 | USB_PROC_CHORUS_SWITCH = 1, | ||
102 | USB_PROC_CHORUS_LEVEL = 2, | ||
103 | USB_PROC_CHORUS_RATE = 3, | ||
104 | USB_PROC_CHORUS_DEPTH = 4, | ||
105 | |||
106 | USB_PROC_DCR = 6, | ||
107 | USB_PROC_DCR_SWITCH = 1, | ||
108 | USB_PROC_DCR_RATIO = 2, | ||
109 | USB_PROC_DCR_MAX_AMP = 3, | ||
110 | USB_PROC_DCR_THRESHOLD = 4, | ||
111 | USB_PROC_DCR_ATTACK = 5, | ||
112 | USB_PROC_DCR_RELEASE = 6, | ||
113 | }; | ||
114 | 81 | ||
115 | /*E-mu 0202(0404) eXtension Unit(XU) control*/ | 82 | /*E-mu 0202(0404) eXtension Unit(XU) control*/ |
116 | enum { | 83 | enum { |
@@ -980,7 +947,7 @@ static void build_feature_ctl(struct mixer_build *state, void *raw_desc, | |||
980 | 947 | ||
981 | control++; /* change from zero-based to 1-based value */ | 948 | control++; /* change from zero-based to 1-based value */ |
982 | 949 | ||
983 | if (control == UAC_GRAPHIC_EQUALIZER_CONTROL) { | 950 | if (control == UAC_FU_GRAPHIC_EQUALIZER) { |
984 | /* FIXME: not supported yet */ | 951 | /* FIXME: not supported yet */ |
985 | return; | 952 | return; |
986 | } | 953 | } |
@@ -1036,8 +1003,8 @@ static void build_feature_ctl(struct mixer_build *state, void *raw_desc, | |||
1036 | kctl->id.name, sizeof(kctl->id.name)); | 1003 | kctl->id.name, sizeof(kctl->id.name)); |
1037 | 1004 | ||
1038 | switch (control) { | 1005 | switch (control) { |
1039 | case UAC_MUTE_CONTROL: | 1006 | case UAC_FU_MUTE: |
1040 | case UAC_VOLUME_CONTROL: | 1007 | case UAC_FU_VOLUME: |
1041 | /* determine the control name. the rule is: | 1008 | /* determine the control name. the rule is: |
1042 | * - if a name id is given in descriptor, use it. | 1009 | * - if a name id is given in descriptor, use it. |
1043 | * - if the connected input can be determined, then use the name | 1010 | * - if the connected input can be determined, then use the name |
@@ -1064,9 +1031,9 @@ static void build_feature_ctl(struct mixer_build *state, void *raw_desc, | |||
1064 | len = append_ctl_name(kctl, " Playback"); | 1031 | len = append_ctl_name(kctl, " Playback"); |
1065 | } | 1032 | } |
1066 | } | 1033 | } |
1067 | append_ctl_name(kctl, control == UAC_MUTE_CONTROL ? | 1034 | append_ctl_name(kctl, control == UAC_FU_MUTE ? |
1068 | " Switch" : " Volume"); | 1035 | " Switch" : " Volume"); |
1069 | if (control == UAC_VOLUME_CONTROL) { | 1036 | if (control == UAC_FU_VOLUME) { |
1070 | kctl->tlv.c = mixer_vol_tlv; | 1037 | kctl->tlv.c = mixer_vol_tlv; |
1071 | kctl->vd[0].access |= | 1038 | kctl->vd[0].access |= |
1072 | SNDRV_CTL_ELEM_ACCESS_TLV_READ | | 1039 | SNDRV_CTL_ELEM_ACCESS_TLV_READ | |
@@ -1165,7 +1132,7 @@ static int parse_audio_feature_unit(struct mixer_build *state, int unitid, void | |||
1165 | snd_printk(KERN_INFO | 1132 | snd_printk(KERN_INFO |
1166 | "usbmixer: master volume quirk for PCM2702 chip\n"); | 1133 | "usbmixer: master volume quirk for PCM2702 chip\n"); |
1167 | /* disable non-functional volume control */ | 1134 | /* disable non-functional volume control */ |
1168 | master_bits &= ~UAC_FU_VOLUME; | 1135 | master_bits &= ~UAC_CONTROL_BIT(UAC_FU_VOLUME); |
1169 | break; | 1136 | break; |
1170 | } | 1137 | } |
1171 | if (channels > 0) | 1138 | if (channels > 0) |
@@ -1410,51 +1377,51 @@ struct procunit_info { | |||
1410 | }; | 1377 | }; |
1411 | 1378 | ||
1412 | static struct procunit_value_info updown_proc_info[] = { | 1379 | static struct procunit_value_info updown_proc_info[] = { |
1413 | { USB_PROC_UPDOWN_SWITCH, "Switch", USB_MIXER_BOOLEAN }, | 1380 | { UAC_UD_ENABLE, "Switch", USB_MIXER_BOOLEAN }, |
1414 | { USB_PROC_UPDOWN_MODE_SEL, "Mode Select", USB_MIXER_U8, 1 }, | 1381 | { UAC_UD_MODE_SELECT, "Mode Select", USB_MIXER_U8, 1 }, |
1415 | { 0 } | 1382 | { 0 } |
1416 | }; | 1383 | }; |
1417 | static struct procunit_value_info prologic_proc_info[] = { | 1384 | static struct procunit_value_info prologic_proc_info[] = { |
1418 | { USB_PROC_PROLOGIC_SWITCH, "Switch", USB_MIXER_BOOLEAN }, | 1385 | { UAC_DP_ENABLE, "Switch", USB_MIXER_BOOLEAN }, |
1419 | { USB_PROC_PROLOGIC_MODE_SEL, "Mode Select", USB_MIXER_U8, 1 }, | 1386 | { UAC_DP_MODE_SELECT, "Mode Select", USB_MIXER_U8, 1 }, |
1420 | { 0 } | 1387 | { 0 } |
1421 | }; | 1388 | }; |
1422 | static struct procunit_value_info threed_enh_proc_info[] = { | 1389 | static struct procunit_value_info threed_enh_proc_info[] = { |
1423 | { USB_PROC_3DENH_SWITCH, "Switch", USB_MIXER_BOOLEAN }, | 1390 | { UAC_3D_ENABLE, "Switch", USB_MIXER_BOOLEAN }, |
1424 | { USB_PROC_3DENH_SPACE, "Spaciousness", USB_MIXER_U8 }, | 1391 | { UAC_3D_SPACE, "Spaciousness", USB_MIXER_U8 }, |
1425 | { 0 } | 1392 | { 0 } |
1426 | }; | 1393 | }; |
1427 | static struct procunit_value_info reverb_proc_info[] = { | 1394 | static struct procunit_value_info reverb_proc_info[] = { |
1428 | { USB_PROC_REVERB_SWITCH, "Switch", USB_MIXER_BOOLEAN }, | 1395 | { UAC_REVERB_ENABLE, "Switch", USB_MIXER_BOOLEAN }, |
1429 | { USB_PROC_REVERB_LEVEL, "Level", USB_MIXER_U8 }, | 1396 | { UAC_REVERB_LEVEL, "Level", USB_MIXER_U8 }, |
1430 | { USB_PROC_REVERB_TIME, "Time", USB_MIXER_U16 }, | 1397 | { UAC_REVERB_TIME, "Time", USB_MIXER_U16 }, |
1431 | { USB_PROC_REVERB_DELAY, "Delay", USB_MIXER_U8 }, | 1398 | { UAC_REVERB_FEEDBACK, "Feedback", USB_MIXER_U8 }, |
1432 | { 0 } | 1399 | { 0 } |
1433 | }; | 1400 | }; |
1434 | static struct procunit_value_info chorus_proc_info[] = { | 1401 | static struct procunit_value_info chorus_proc_info[] = { |
1435 | { USB_PROC_CHORUS_SWITCH, "Switch", USB_MIXER_BOOLEAN }, | 1402 | { UAC_CHORUS_ENABLE, "Switch", USB_MIXER_BOOLEAN }, |
1436 | { USB_PROC_CHORUS_LEVEL, "Level", USB_MIXER_U8 }, | 1403 | { UAC_CHORUS_LEVEL, "Level", USB_MIXER_U8 }, |
1437 | { USB_PROC_CHORUS_RATE, "Rate", USB_MIXER_U16 }, | 1404 | { UAC_CHORUS_RATE, "Rate", USB_MIXER_U16 }, |
1438 | { USB_PROC_CHORUS_DEPTH, "Depth", USB_MIXER_U16 }, | 1405 | { UAC_CHORUS_DEPTH, "Depth", USB_MIXER_U16 }, |
1439 | { 0 } | 1406 | { 0 } |
1440 | }; | 1407 | }; |
1441 | static struct procunit_value_info dcr_proc_info[] = { | 1408 | static struct procunit_value_info dcr_proc_info[] = { |
1442 | { USB_PROC_DCR_SWITCH, "Switch", USB_MIXER_BOOLEAN }, | 1409 | { UAC_DCR_ENABLE, "Switch", USB_MIXER_BOOLEAN }, |
1443 | { USB_PROC_DCR_RATIO, "Ratio", USB_MIXER_U16 }, | 1410 | { UAC_DCR_RATE, "Ratio", USB_MIXER_U16 }, |
1444 | { USB_PROC_DCR_MAX_AMP, "Max Amp", USB_MIXER_S16 }, | 1411 | { UAC_DCR_MAXAMPL, "Max Amp", USB_MIXER_S16 }, |
1445 | { USB_PROC_DCR_THRESHOLD, "Threshold", USB_MIXER_S16 }, | 1412 | { UAC_DCR_THRESHOLD, "Threshold", USB_MIXER_S16 }, |
1446 | { USB_PROC_DCR_ATTACK, "Attack Time", USB_MIXER_U16 }, | 1413 | { UAC_DCR_ATTACK_TIME, "Attack Time", USB_MIXER_U16 }, |
1447 | { USB_PROC_DCR_RELEASE, "Release Time", USB_MIXER_U16 }, | 1414 | { UAC_DCR_RELEASE_TIME, "Release Time", USB_MIXER_U16 }, |
1448 | { 0 } | 1415 | { 0 } |
1449 | }; | 1416 | }; |
1450 | 1417 | ||
1451 | static struct procunit_info procunits[] = { | 1418 | static struct procunit_info procunits[] = { |
1452 | { USB_PROC_UPDOWN, "Up Down", updown_proc_info }, | 1419 | { UAC_PROCESS_UP_DOWNMIX, "Up Down", updown_proc_info }, |
1453 | { USB_PROC_PROLOGIC, "Dolby Prologic", prologic_proc_info }, | 1420 | { UAC_PROCESS_DOLBY_PROLOGIC, "Dolby Prologic", prologic_proc_info }, |
1454 | { USB_PROC_3DENH, "3D Stereo Extender", threed_enh_proc_info }, | 1421 | { UAC_PROCESS_STEREO_EXTENDER, "3D Stereo Extender", threed_enh_proc_info }, |
1455 | { USB_PROC_REVERB, "Reverb", reverb_proc_info }, | 1422 | { UAC_PROCESS_REVERB, "Reverb", reverb_proc_info }, |
1456 | { USB_PROC_CHORUS, "Chorus", chorus_proc_info }, | 1423 | { UAC_PROCESS_CHORUS, "Chorus", chorus_proc_info }, |
1457 | { USB_PROC_DCR, "DCR", dcr_proc_info }, | 1424 | { UAC_PROCESS_DYN_RANGE_COMP, "DCR", dcr_proc_info }, |
1458 | { 0 }, | 1425 | { 0 }, |
1459 | }; | 1426 | }; |
1460 | /* | 1427 | /* |
@@ -1542,7 +1509,7 @@ static int build_audio_procunit(struct mixer_build *state, int unitid, void *raw | |||
1542 | cval->channels = 1; | 1509 | cval->channels = 1; |
1543 | 1510 | ||
1544 | /* get min/max values */ | 1511 | /* get min/max values */ |
1545 | if (type == USB_PROC_UPDOWN && cval->control == USB_PROC_UPDOWN_MODE_SEL) { | 1512 | if (type == UAC_PROCESS_UP_DOWNMIX && cval->control == UAC_UD_MODE_SELECT) { |
1546 | __u8 *control_spec = uac_processing_unit_specific(desc, state->mixer->protocol); | 1513 | __u8 *control_spec = uac_processing_unit_specific(desc, state->mixer->protocol); |
1547 | /* FIXME: hard-coded */ | 1514 | /* FIXME: hard-coded */ |
1548 | cval->min = 1; | 1515 | cval->min = 1; |