Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
7a92d803
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
7a92d803
编写于
15年前
作者:
L
Len Brown
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'battery' into release
上级
b4549a24
bc76f90b
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
20 addition
and
0 deletion
+20
-0
drivers/acpi/battery.c
drivers/acpi/battery.c
+20
-0
未找到文件。
drivers/acpi/battery.c
浏览文件 @
7a92d803
...
...
@@ -31,6 +31,7 @@
#include <linux/types.h>
#include <linux/jiffies.h>
#include <linux/async.h>
#include <linux/dmi.h>
#ifdef CONFIG_ACPI_PROCFS_POWER
#include <linux/proc_fs.h>
...
...
@@ -87,6 +88,10 @@ static const struct acpi_device_id battery_device_ids[] = {
MODULE_DEVICE_TABLE
(
acpi
,
battery_device_ids
);
/* For buggy DSDTs that report negative 16-bit values for either charging
* or discharging current and/or report 0 as 65536 due to bad math.
*/
#define QUIRK_SIGNED16_CURRENT 0x0001
struct
acpi_battery
{
struct
mutex
lock
;
...
...
@@ -114,6 +119,7 @@ struct acpi_battery {
int
state
;
int
power_unit
;
u8
alarm_present
;
long
quirks
;
};
#define to_acpi_battery(x) container_of(x, struct acpi_battery, bat);
...
...
@@ -392,6 +398,11 @@ static int acpi_battery_get_state(struct acpi_battery *battery)
state_offsets
,
ARRAY_SIZE
(
state_offsets
));
battery
->
update_time
=
jiffies
;
kfree
(
buffer
.
pointer
);
if
((
battery
->
quirks
&
QUIRK_SIGNED16_CURRENT
)
&&
battery
->
rate_now
!=
-
1
)
battery
->
rate_now
=
abs
((
s16
)
battery
->
rate_now
);
return
result
;
}
...
...
@@ -497,6 +508,14 @@ static void sysfs_remove_battery(struct acpi_battery *battery)
}
#endif
static
void
acpi_battery_quirks
(
struct
acpi_battery
*
battery
)
{
battery
->
quirks
=
0
;
if
(
dmi_name_in_vendors
(
"Acer"
)
&&
battery
->
power_unit
)
{
battery
->
quirks
|=
QUIRK_SIGNED16_CURRENT
;
}
}
static
int
acpi_battery_update
(
struct
acpi_battery
*
battery
)
{
int
result
,
old_present
=
acpi_battery_present
(
battery
);
...
...
@@ -515,6 +534,7 @@ static int acpi_battery_update(struct acpi_battery *battery)
result
=
acpi_battery_get_info
(
battery
);
if
(
result
)
return
result
;
acpi_battery_quirks
(
battery
);
acpi_battery_init_alarm
(
battery
);
}
#ifdef CONFIG_ACPI_SYSFS_POWER
...
...
This diff is collapsed.
Click to expand it.
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录