Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
408e03f8
Commit
408e03f8
authored
Feb 08, 2002
by
Dave Jones
Committed by
Linus Torvalds
Feb 08, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] Power management support for opl3sa2 driver
parent
5ef8de79
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
106 additions
and
1 deletion
+106
-1
drivers/sound/opl3sa2.c
drivers/sound/opl3sa2.c
+106
-1
No files found.
drivers/sound/opl3sa2.c
View file @
408e03f8
...
...
@@ -55,6 +55,7 @@
* sb_card.c and awe_wave.c. (Dec 12, 2000)
* Scott Murray Some small cleanups to the init code output.
* (Jan 7, 2001)
* Zwane Mwaikambo Added PM support. (Dec 4 2001)
*
*/
...
...
@@ -62,13 +63,14 @@
#include <linux/init.h>
#include <linux/module.h>
#include <linux/isapnp.h>
#include <linux/pm.h>
#include "sound_config.h"
#include "ad1848.h"
#include "mpu401.h"
/* Useful control port indexes: */
#define OPL3SA2_PM 0x01
#define OPL3SA2_SYS_CTRL 0x02
#define OPL3SA2_IRQ_CONFIG 0x03
#define OPL3SA2_DMA_CONFIG 0x06
...
...
@@ -86,6 +88,11 @@
#define DEFAULT_MIC 50
#define DEFAULT_TIMBRE 0
/* Power saving modes */
#define OPL3SA2_PM_MODE1 0x05
#define OPL3SA2_PM_MODE2 0x04
#define OPL3SA2_PM_MODE3 0x03
/* For checking against what the card returns: */
#define VERSION_UNKNOWN 0
#define VERSION_YMF711 1
...
...
@@ -121,6 +128,10 @@ static int opl3sa2_mixer[OPL3SA2_CARDS_MAX] = { -1 };
typedef
struct
opl3sa2_mixerdata_tag
{
unsigned
short
cfg_port
;
unsigned
short
padding
;
unsigned
char
reg
;
unsigned
int
in_suspend
;
struct
pm_dev
*
pmdev
;
unsigned
int
card
;
unsigned
int
volume_l
;
unsigned
int
volume_r
;
unsigned
int
mic
;
...
...
@@ -328,6 +339,20 @@ static void opl3sa2_mixer_reset(opl3sa2_mixerdata* devc, int card)
}
static
void
opl3sa2_mixer_restore
(
opl3sa2_mixerdata
*
devc
,
int
card
)
{
if
(
devc
)
{
opl3sa2_set_volume
(
devc
,
devc
->
volume_l
,
devc
->
volume_r
);
opl3sa2_set_mic
(
devc
,
devc
->
mic
);
if
(
chipset
[
card
]
==
CHIPSET_OPL3SA3
)
{
opl3sa3_set_bass
(
devc
,
devc
->
bass_l
,
devc
->
bass_r
);
opl3sa3_set_treble
(
devc
,
devc
->
treble_l
,
devc
->
treble_r
);
}
}
}
static
inline
void
arg_to_vol_mono
(
unsigned
int
vol
,
int
*
value
)
{
int
left
;
...
...
@@ -892,6 +917,77 @@ static int __init opl3sa2_isapnp_probe(struct address_info* hw_cfg,
/* End of component functions */
/* Power Management support functions */
static
int
opl3sa2_suspend
(
struct
pm_dev
*
pdev
,
unsigned
char
pm_mode
)
{
unsigned
long
flags
;
opl3sa2_mixerdata
*
p
;
if
(
!
pdev
)
return
-
EINVAL
;
save_flags
(
flags
);
cli
();
p
=
(
opl3sa2_mixerdata
*
)
pdev
->
data
;
p
->
in_suspend
=
1
;
switch
(
pm_mode
)
{
case
1
:
pm_mode
=
OPL3SA2_PM_MODE1
;
break
;
case
2
:
pm_mode
=
OPL3SA2_PM_MODE2
;
break
;
case
3
:
pm_mode
=
OPL3SA2_PM_MODE3
;
break
;
default:
pm_mode
=
OPL3SA2_PM_MODE3
;
break
;
}
/* its supposed to automute before suspending, so we wont bother */
opl3sa2_read
(
p
->
cfg_port
,
OPL3SA2_PM
,
&
p
->
reg
);
opl3sa2_write
(
p
->
cfg_port
,
OPL3SA2_PM
,
p
->
reg
|
pm_mode
);
restore_flags
(
flags
);
return
0
;
}
static
int
opl3sa2_resume
(
struct
pm_dev
*
pdev
)
{
unsigned
long
flags
;
opl3sa2_mixerdata
*
p
;
if
(
!
pdev
)
return
-
EINVAL
;
p
=
(
opl3sa2_mixerdata
*
)
pdev
->
data
;
save_flags
(
flags
);
cli
();
/* I don't think this is necessary */
opl3sa2_write
(
p
->
cfg_port
,
OPL3SA2_PM
,
p
->
reg
);
opl3sa2_mixer_restore
(
p
,
p
->
card
);
p
->
in_suspend
=
0
;
restore_flags
(
flags
);
return
0
;
}
static
int
opl3sa2_pm_callback
(
struct
pm_dev
*
pdev
,
pm_request_t
rqst
,
void
*
data
)
{
unsigned
char
mode
=
(
unsigned
char
)
data
;
switch
(
rqst
)
{
case
PM_SUSPEND
:
return
opl3sa2_suspend
(
pdev
,
mode
);
case
PM_RESUME
:
return
opl3sa2_resume
(
pdev
);
}
return
0
;
}
/*
* Install OPL3-SA2 based card(s).
...
...
@@ -989,6 +1085,12 @@ static int __init init_opl3sa2(void)
attach_opl3sa2_mss
(
&
cfg_mss
[
card
]);
attach_opl3sa2_mixer
(
&
cfg
[
card
],
card
);
opl3sa2_data
[
card
].
card
=
card
;
/* register our power management capabilities */
opl3sa2_data
[
card
].
pmdev
=
pm_register
(
PM_ISA_DEV
,
card
,
opl3sa2_pm_callback
);
if
(
opl3sa2_data
[
card
].
pmdev
)
opl3sa2_data
[
card
].
pmdev
->
data
=
&
opl3sa2_data
[
card
];
/*
* Set the Yamaha 3D enhancement mode (aka Ymersion) if asked to and
* it's supported.
...
...
@@ -1033,6 +1135,9 @@ static void __exit cleanup_opl3sa2(void)
int
card
;
for
(
card
=
0
;
card
<
opl3sa2_cards_num
;
card
++
)
{
if
(
opl3sa2_data
[
card
].
pmdev
)
pm_unregister
(
opl3sa2_data
[
card
].
pmdev
);
if
(
cfg_mpu
[
card
].
slots
[
1
]
!=
-
1
)
{
unload_opl3sa2_mpu
(
&
cfg_mpu
[
card
]);
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment