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
nexedi
linux
Commits
fee807e8
Commit
fee807e8
authored
Oct 15, 2009
by
Len Brown
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'eeepc-laptop' into release
parents
f63a9048
b56ab33d
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
10 deletions
+21
-10
drivers/platform/x86/eeepc-laptop.c
drivers/platform/x86/eeepc-laptop.c
+21
-10
No files found.
drivers/platform/x86/eeepc-laptop.c
View file @
fee807e8
...
@@ -150,6 +150,8 @@ struct eeepc_hotk {
...
@@ -150,6 +150,8 @@ struct eeepc_hotk {
/* The actual device the driver binds to */
/* The actual device the driver binds to */
static
struct
eeepc_hotk
*
ehotk
;
static
struct
eeepc_hotk
*
ehotk
;
static
void
eeepc_rfkill_hotplug
(
bool
real
);
/* Platform device/driver */
/* Platform device/driver */
static
int
eeepc_hotk_thaw
(
struct
device
*
device
);
static
int
eeepc_hotk_thaw
(
struct
device
*
device
);
static
int
eeepc_hotk_restore
(
struct
device
*
device
);
static
int
eeepc_hotk_restore
(
struct
device
*
device
);
...
@@ -343,14 +345,23 @@ static bool eeepc_wlan_rfkill_blocked(void)
...
@@ -343,14 +345,23 @@ static bool eeepc_wlan_rfkill_blocked(void)
static
int
eeepc_rfkill_set
(
void
*
data
,
bool
blocked
)
static
int
eeepc_rfkill_set
(
void
*
data
,
bool
blocked
)
{
{
unsigned
long
asl
=
(
unsigned
long
)
data
;
unsigned
long
asl
=
(
unsigned
long
)
data
;
return
set_acpi
(
asl
,
!
blocked
);
int
ret
;
if
(
asl
!=
CM_ASL_WLAN
)
return
set_acpi
(
asl
,
!
blocked
);
/* hack to avoid panic with rt2860sta */
if
(
blocked
)
eeepc_rfkill_hotplug
(
false
);
ret
=
set_acpi
(
asl
,
!
blocked
);
return
ret
;
}
}
static
const
struct
rfkill_ops
eeepc_rfkill_ops
=
{
static
const
struct
rfkill_ops
eeepc_rfkill_ops
=
{
.
set_block
=
eeepc_rfkill_set
,
.
set_block
=
eeepc_rfkill_set
,
};
};
static
void
__init
eeepc_enable_camera
(
void
)
static
void
__
dev
init
eeepc_enable_camera
(
void
)
{
{
/*
/*
* If the following call to set_acpi() fails, it's because there's no
* If the following call to set_acpi() fails, it's because there's no
...
@@ -643,13 +654,13 @@ static int eeepc_get_adapter_status(struct hotplug_slot *hotplug_slot,
...
@@ -643,13 +654,13 @@ static int eeepc_get_adapter_status(struct hotplug_slot *hotplug_slot,
return
0
;
return
0
;
}
}
static
void
eeepc_rfkill_hotplug
(
void
)
static
void
eeepc_rfkill_hotplug
(
bool
real
)
{
{
struct
pci_dev
*
dev
;
struct
pci_dev
*
dev
;
struct
pci_bus
*
bus
;
struct
pci_bus
*
bus
;
bool
blocked
=
eeepc_wlan_rfkill_blocked
()
;
bool
blocked
=
real
?
eeepc_wlan_rfkill_blocked
()
:
true
;
if
(
ehotk
->
wlan_rfkill
)
if
(
real
&&
ehotk
->
wlan_rfkill
)
rfkill_set_sw_state
(
ehotk
->
wlan_rfkill
,
blocked
);
rfkill_set_sw_state
(
ehotk
->
wlan_rfkill
,
blocked
);
mutex_lock
(
&
ehotk
->
hotplug_lock
);
mutex_lock
(
&
ehotk
->
hotplug_lock
);
...
@@ -692,7 +703,7 @@ static void eeepc_rfkill_notify(acpi_handle handle, u32 event, void *data)
...
@@ -692,7 +703,7 @@ static void eeepc_rfkill_notify(acpi_handle handle, u32 event, void *data)
if
(
event
!=
ACPI_NOTIFY_BUS_CHECK
)
if
(
event
!=
ACPI_NOTIFY_BUS_CHECK
)
return
;
return
;
eeepc_rfkill_hotplug
();
eeepc_rfkill_hotplug
(
true
);
}
}
static
void
eeepc_hotk_notify
(
struct
acpi_device
*
device
,
u32
event
)
static
void
eeepc_hotk_notify
(
struct
acpi_device
*
device
,
u32
event
)
...
@@ -850,7 +861,7 @@ static int eeepc_hotk_restore(struct device *device)
...
@@ -850,7 +861,7 @@ static int eeepc_hotk_restore(struct device *device)
{
{
/* Refresh both wlan rfkill state and pci hotplug */
/* Refresh both wlan rfkill state and pci hotplug */
if
(
ehotk
->
wlan_rfkill
)
if
(
ehotk
->
wlan_rfkill
)
eeepc_rfkill_hotplug
();
eeepc_rfkill_hotplug
(
true
);
if
(
ehotk
->
bluetooth_rfkill
)
if
(
ehotk
->
bluetooth_rfkill
)
rfkill_set_sw_state
(
ehotk
->
bluetooth_rfkill
,
rfkill_set_sw_state
(
ehotk
->
bluetooth_rfkill
,
...
@@ -993,7 +1004,7 @@ static void eeepc_rfkill_exit(void)
...
@@ -993,7 +1004,7 @@ static void eeepc_rfkill_exit(void)
* Refresh pci hotplug in case the rfkill state was changed after
* Refresh pci hotplug in case the rfkill state was changed after
* eeepc_unregister_rfkill_notifier()
* eeepc_unregister_rfkill_notifier()
*/
*/
eeepc_rfkill_hotplug
();
eeepc_rfkill_hotplug
(
true
);
if
(
ehotk
->
hotplug_slot
)
if
(
ehotk
->
hotplug_slot
)
pci_hp_deregister
(
ehotk
->
hotplug_slot
);
pci_hp_deregister
(
ehotk
->
hotplug_slot
);
...
@@ -1109,7 +1120,7 @@ static int eeepc_rfkill_init(struct device *dev)
...
@@ -1109,7 +1120,7 @@ static int eeepc_rfkill_init(struct device *dev)
* Refresh pci hotplug in case the rfkill state was changed during
* Refresh pci hotplug in case the rfkill state was changed during
* setup.
* setup.
*/
*/
eeepc_rfkill_hotplug
();
eeepc_rfkill_hotplug
(
true
);
exit:
exit:
if
(
result
&&
result
!=
-
ENODEV
)
if
(
result
&&
result
!=
-
ENODEV
)
...
@@ -1189,7 +1200,7 @@ static int eeepc_input_init(struct device *dev)
...
@@ -1189,7 +1200,7 @@ static int eeepc_input_init(struct device *dev)
return
0
;
return
0
;
}
}
static
int
eeepc_hotk_add
(
struct
acpi_device
*
device
)
static
int
__devinit
eeepc_hotk_add
(
struct
acpi_device
*
device
)
{
{
struct
device
*
dev
;
struct
device
*
dev
;
int
result
;
int
result
;
...
...
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