diff options
author | Takashi Iwai <tiwai@suse.de> | 2005-11-17 10:16:10 -0500 |
---|---|---|
committer | Jaroslav Kysela <perex@suse.cz> | 2006-01-03 06:28:03 -0500 |
commit | 5bdb6a1629408f657f5f2c42b3c07c689c411499 (patch) | |
tree | b99b216117506a89a3f09ebb874da83ec13fbf6c /sound/isa/sb/sb_mixer.c | |
parent | cb60e5f5b2b19284479825cdaa6dd6b7078cf5d2 (diff) |
[ALSA] Add PM support to SB-support code
Modules: SB drivers,SB16/AWE driver
Add PM support to SB-support code.
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/isa/sb/sb_mixer.c')
-rw-r--r-- | sound/isa/sb/sb_mixer.c | 137 |
1 files changed, 137 insertions, 0 deletions
diff --git a/sound/isa/sb/sb_mixer.c b/sound/isa/sb/sb_mixer.c index 6e0b935a8b85..1a6ee344dddb 100644 --- a/sound/isa/sb/sb_mixer.c +++ b/sound/isa/sb/sb_mixer.c | |||
@@ -853,3 +853,140 @@ int snd_sbmixer_new(struct snd_sb *chip) | |||
853 | } | 853 | } |
854 | return 0; | 854 | return 0; |
855 | } | 855 | } |
856 | |||
857 | #ifdef CONFIG_PM | ||
858 | static unsigned char sb20_saved_regs[] = { | ||
859 | SB_DSP20_MASTER_DEV, | ||
860 | SB_DSP20_PCM_DEV, | ||
861 | SB_DSP20_FM_DEV, | ||
862 | SB_DSP20_CD_DEV, | ||
863 | }; | ||
864 | |||
865 | static unsigned char sbpro_saved_regs[] = { | ||
866 | SB_DSP_MASTER_DEV, | ||
867 | SB_DSP_PCM_DEV, | ||
868 | SB_DSP_PLAYBACK_FILT, | ||
869 | SB_DSP_FM_DEV, | ||
870 | SB_DSP_CD_DEV, | ||
871 | SB_DSP_LINE_DEV, | ||
872 | SB_DSP_MIC_DEV, | ||
873 | SB_DSP_CAPTURE_SOURCE, | ||
874 | SB_DSP_CAPTURE_FILT, | ||
875 | }; | ||
876 | |||
877 | static unsigned char sb16_saved_regs[] = { | ||
878 | SB_DSP4_MASTER_DEV, SB_DSP4_MASTER_DEV + 1, | ||
879 | SB_DSP4_3DSE, | ||
880 | SB_DSP4_BASS_DEV, SB_DSP4_BASS_DEV + 1, | ||
881 | SB_DSP4_TREBLE_DEV, SB_DSP4_TREBLE_DEV + 1, | ||
882 | SB_DSP4_PCM_DEV, SB_DSP4_PCM_DEV + 1, | ||
883 | SB_DSP4_INPUT_LEFT, SB_DSP4_INPUT_RIGHT, | ||
884 | SB_DSP4_SYNTH_DEV, SB_DSP4_SYNTH_DEV + 1, | ||
885 | SB_DSP4_OUTPUT_SW, | ||
886 | SB_DSP4_CD_DEV, SB_DSP4_CD_DEV + 1, | ||
887 | SB_DSP4_LINE_DEV, SB_DSP4_LINE_DEV + 1, | ||
888 | SB_DSP4_MIC_DEV, | ||
889 | SB_DSP4_SPEAKER_DEV, | ||
890 | SB_DSP4_IGAIN_DEV, SB_DSP4_IGAIN_DEV + 1, | ||
891 | SB_DSP4_OGAIN_DEV, SB_DSP4_OGAIN_DEV + 1, | ||
892 | SB_DSP4_MIC_AGC | ||
893 | }; | ||
894 | |||
895 | static unsigned char dt019x_saved_regs[] = { | ||
896 | SB_DT019X_MASTER_DEV, | ||
897 | SB_DT019X_PCM_DEV, | ||
898 | SB_DT019X_SYNTH_DEV, | ||
899 | SB_DT019X_CD_DEV, | ||
900 | SB_DT019X_MIC_DEV, | ||
901 | SB_DT019X_SPKR_DEV, | ||
902 | SB_DT019X_LINE_DEV, | ||
903 | SB_DSP4_OUTPUT_SW, | ||
904 | SB_DT019X_OUTPUT_SW2, | ||
905 | SB_DT019X_CAPTURE_SW, | ||
906 | }; | ||
907 | |||
908 | static unsigned char als4000_saved_regs[] = { | ||
909 | SB_DSP4_MASTER_DEV, SB_DSP4_MASTER_DEV + 1, | ||
910 | SB_DSP4_OUTPUT_SW, | ||
911 | SB_DSP4_PCM_DEV, SB_DSP4_PCM_DEV + 1, | ||
912 | SB_DSP4_INPUT_LEFT, SB_DSP4_INPUT_RIGHT, | ||
913 | SB_DSP4_SYNTH_DEV, SB_DSP4_SYNTH_DEV + 1, | ||
914 | SB_DSP4_CD_DEV, SB_DSP4_CD_DEV + 1, | ||
915 | SB_DSP4_MIC_AGC, | ||
916 | SB_DSP4_MIC_DEV, | ||
917 | SB_DSP4_SPEAKER_DEV, | ||
918 | SB_DSP4_IGAIN_DEV, SB_DSP4_IGAIN_DEV + 1, | ||
919 | SB_DSP4_OGAIN_DEV, SB_DSP4_OGAIN_DEV + 1, | ||
920 | SB_DT019X_OUTPUT_SW2, | ||
921 | SB_ALS4000_MONO_IO_CTRL, | ||
922 | SB_ALS4000_MIC_IN_GAIN, | ||
923 | SB_ALS4000_3D_SND_FX, | ||
924 | SB_ALS4000_3D_TIME_DELAY, | ||
925 | }; | ||
926 | |||
927 | static void save_mixer(struct snd_sb *chip, unsigned char *regs, int num_regs) | ||
928 | { | ||
929 | unsigned char *val = chip->saved_regs; | ||
930 | snd_assert(num_regs > ARRAY_SIZE(chip->saved_regs), return); | ||
931 | for (; num_regs; num_regs--) | ||
932 | *val++ = snd_sbmixer_read(chip, *regs++); | ||
933 | } | ||
934 | |||
935 | static void restore_mixer(struct snd_sb *chip, unsigned char *regs, int num_regs) | ||
936 | { | ||
937 | unsigned char *val = chip->saved_regs; | ||
938 | snd_assert(num_regs > ARRAY_SIZE(chip->saved_regs), return); | ||
939 | for (; num_regs; num_regs--) | ||
940 | snd_sbmixer_write(chip, *regs++, *val++); | ||
941 | } | ||
942 | |||
943 | void snd_sbmixer_suspend(struct snd_sb *chip) | ||
944 | { | ||
945 | switch (chip->hardware) { | ||
946 | case SB_HW_20: | ||
947 | case SB_HW_201: | ||
948 | save_mixer(chip, sb20_saved_regs, ARRAY_SIZE(sb20_saved_regs)); | ||
949 | break; | ||
950 | case SB_HW_PRO: | ||
951 | save_mixer(chip, sbpro_saved_regs, ARRAY_SIZE(sbpro_saved_regs)); | ||
952 | break; | ||
953 | case SB_HW_16: | ||
954 | case SB_HW_ALS100: | ||
955 | save_mixer(chip, sb16_saved_regs, ARRAY_SIZE(sb16_saved_regs)); | ||
956 | break; | ||
957 | case SB_HW_ALS4000: | ||
958 | save_mixer(chip, als4000_saved_regs, ARRAY_SIZE(als4000_saved_regs)); | ||
959 | break; | ||
960 | case SB_HW_DT019X: | ||
961 | save_mixer(chip, dt019x_saved_regs, ARRAY_SIZE(dt019x_saved_regs)); | ||
962 | break; | ||
963 | default: | ||
964 | break; | ||
965 | } | ||
966 | } | ||
967 | |||
968 | void snd_sbmixer_resume(struct snd_sb *chip) | ||
969 | { | ||
970 | switch (chip->hardware) { | ||
971 | case SB_HW_20: | ||
972 | case SB_HW_201: | ||
973 | restore_mixer(chip, sb20_saved_regs, ARRAY_SIZE(sb20_saved_regs)); | ||
974 | break; | ||
975 | case SB_HW_PRO: | ||
976 | restore_mixer(chip, sbpro_saved_regs, ARRAY_SIZE(sbpro_saved_regs)); | ||
977 | break; | ||
978 | case SB_HW_16: | ||
979 | case SB_HW_ALS100: | ||
980 | restore_mixer(chip, sb16_saved_regs, ARRAY_SIZE(sb16_saved_regs)); | ||
981 | break; | ||
982 | case SB_HW_ALS4000: | ||
983 | restore_mixer(chip, als4000_saved_regs, ARRAY_SIZE(als4000_saved_regs)); | ||
984 | break; | ||
985 | case SB_HW_DT019X: | ||
986 | restore_mixer(chip, dt019x_saved_regs, ARRAY_SIZE(dt019x_saved_regs)); | ||
987 | break; | ||
988 | default: | ||
989 | break; | ||
990 | } | ||
991 | } | ||
992 | #endif | ||