⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 main.c.bak

📁 电源管理代码 基于linux2.6.10!apm方式的电源管理!很好的资料!做arm平台使用
💻 BAK
字号:
/* * kernel/power/main.c - PM subsystem core functionality. * * Copyright (c) 2003 Patrick Mochel * Copyright (c) 2003 Open Source Development Lab *  * This file is released under the GPLv2 * */#include <linux/suspend.h>#include <linux/kobject.h>#include <linux/string.h>#include <linux/delay.h>#include <linux/errno.h>#include <linux/init.h>#include <linux/pm.h>#include <linux/kernel.h>   // For pr_debug#include "power.h"//#include <asm/arch/fpow.h>//#include <linux/fiona_power.h>DECLARE_MUTEX(pm_sem);struct pm_ops * pm_ops = NULL;suspend_disk_method_t pm_disk_mode = PM_DISK_SHUTDOWN;/** *	pm_set_ops - Set the global power method table.  *	@ops:	Pointer to ops structure. */void pm_set_ops(struct pm_ops * ops){	down(&pm_sem);	pm_ops = ops;	up(&pm_sem);}/** *	suspend_prepare - Do prep work before entering low-power state. *	@state:		State we're entering. * *	This is common code that is called for each state that we're  *	entering. Allocate a console, stop all processes, then make sure *	the platform can enter the requested state. */#ifdef CONFIG_ARCH_LAB126static unsigned long suspend_time_delta = 0, suspend_time_total = 0; unsigned long get_suspend_time(void){	return suspend_time_total;}#endifstatic int suspend_prepare(suspend_state_t state){	int error = 0;	if (!pm_ops || !pm_ops->enter)		return -EPERM;#ifndef FPOW_DO_PROCESS_SUSPEND_RESUME	pm_prepare_console();	if (freeze_processes()) {		error = -EAGAIN;		goto Thaw;	}#endif#ifdef CONFIG_ARCH_LAB126	suspend_time_delta = get_seconds();#endif	if (pm_ops->prepare) {		if ((error = pm_ops->prepare(state))) {			goto Thaw;	}    }	if ((error = device_suspend(state)))		goto Finish;	return 0; Finish:	if (pm_ops->finish)		pm_ops->finish(state); Thaw:#ifndef FPOW_DO_PROCESS_SUSPEND_RESUME	thaw_processes();	pm_restore_console();#endif#ifdef CONFIG_ARCH_LAB126	suspend_time_total += get_seconds() - suspend_time_delta;	suspend_time_delta = 0;#endif	return error;}static int suspend_enter(u32 state){	int error = 0;	unsigned long flags;	local_irq_save(flags);	if ((error = device_power_down(state)))		goto Done;	error = pm_ops->enter(state);	device_power_up(); Done:	local_irq_restore(flags);	return error;}/** *	suspend_finish - Do final work before exiting suspend sequence. *	@state:		State we're coming out of. * *	Call platform code to clean up, restart processes, and free the  *	console that we've allocated. */static void suspend_finish(suspend_state_t state){	device_resume();#ifdef CONFIG_ARCH_LAB126	suspend_time_total += get_seconds() - suspend_time_delta;	suspend_time_delta = 0;#endif	if (pm_ops && pm_ops->finish)		pm_ops->finish(state);#ifndef FPOW_DO_PROCESS_SUSPEND_RESUME	thaw_processes();	pm_restore_console();#endif}char * pm_states[] = {	[PM_SUSPEND_STANDBY]	= "standby",	[PM_SUSPEND_MEM]	= "mem",	[PM_SUSPEND_DISK]	= "disk",	NULL,};/** *	enter_state - Do common work of entering low-power state. *	@state:		pm_state structure for state we're entering. * *	Make sure we're the only ones trying to enter a sleep state. Fail *	if someone has beat us to it, since we don't want anything weird to *	happen when we wake up. *	Then, do the setup for suspend, enter the state, and cleaup (after *	we've woken up). */static int enter_state(suspend_state_t state){	int error;	if (down_trylock(&pm_sem))		return -EBUSY;	/* Suspend is hard to get right on SMP. */	if (num_online_cpus() != 1) {		error = -EPERM;		goto Unlock;	}	if (state == PM_SUSPEND_DISK) {		error = pm_suspend_disk();		goto Unlock;	}//	powdebug("PM: Preparing system for suspend\n");	if ((error = suspend_prepare(state)))		goto Unlock;	powdebug("PM: Entering state.\n");	error = suspend_enter(state);	powdebug("PM: Finishing up.\n");	suspend_finish(state); Unlock:	up(&pm_sem);	return error;}/* * This is main interface to the outside world. It needs to be * called from process context. */int software_suspend(void){	return enter_state(PM_SUSPEND_DISK);}#ifdef CONFIG_PM/****************************************************************** * *  Main FPOW entry point for Fiona Sleep support code * ******************************************************************/int fiona_suspend_system(void){	return enter_state(PM_SUSPEND_MEM);}#endif  // CONFIG_FIONA_PM/** *	pm_suspend - Externally visible function for suspending system. *	@state:		Enumarted value of state to enter. * *	Determine whether or not value is within range, get state  *	structure, and enter (above). */int pm_suspend(suspend_state_t state){	if (state > PM_SUSPEND_ON && state < PM_SUSPEND_MAX)		return enter_state(state);	return -EINVAL;}decl_subsys(power,NULL,NULL);/** *	state - control system power state. * *	show() returns what states are supported, which is hard-coded to *	'standby' (Power-On Suspend), 'mem' (Suspend-to-RAM), and *	'disk' (Suspend-to-Disk). * *	store() accepts one of those strings, translates it into the  *	proper enumerated value, and initiates a suspend transition. */static ssize_t state_show(struct subsystem * subsys, char * buf){	int i;	char * s = buf;	for (i = 0; i < PM_SUSPEND_MAX; i++) {		if (pm_states[i])			s += sprintf(s,"%s ",pm_states[i]);	}	s += sprintf(s,"\n");	return (s - buf);}static ssize_t state_store(struct subsystem * subsys, const char * buf, size_t n){	suspend_state_t state = PM_SUSPEND_STANDBY;	char ** s;	char *p;	int error;	int len;	p = memchr(buf, '\n', n);	len = p ? p - buf : n;	for (s = &pm_states[state]; state < PM_SUSPEND_MAX; s++, state++) {		if (*s && !strncmp(buf, *s, len))			break;	}	if (*s)		error = enter_state(state);	else		error = -EINVAL;	return error ? error : n;}power_attr(state);static struct attribute * g[] = {	&state_attr.attr,	NULL,};static struct attribute_group attr_group = {	.attrs = g,};static int __init pm_init(void){	int error = subsystem_register(&power_subsys);	if (!error)		error = sysfs_create_group(&power_subsys.kset.kobj,&attr_group);	return error;}core_initcall(pm_init);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -