亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? pmu.h

?? umon bootloader source code, support mips cpu.
?? H
字號:
/*
 * Definitions for talking to the PMU.  The PMU is a microcontroller
 * which controls battery charging and system power on PowerBook 3400
 * and 2400 models as well as the RTC and various other things.
 *
 * Copyright (C) 1998 Paul Mackerras.
 */

#include <linux/config.h>

#define PMU_DRIVER_VERSION	2

/*
 * PMU commands
 */
#define PMU_POWER_CTRL0		0x10	/* control power of some devices */
#define PMU_POWER_CTRL		0x11	/* control power of some devices */
#define PMU_ADB_CMD		0x20	/* send ADB packet */
#define PMU_ADB_POLL_OFF	0x21	/* disable ADB auto-poll */
#define PMU_WRITE_NVRAM		0x33	/* write non-volatile RAM */
#define PMU_READ_NVRAM		0x3b	/* read non-volatile RAM */
#define PMU_SET_RTC		0x30	/* set real-time clock */
#define PMU_READ_RTC		0x38	/* read real-time clock */
#define PMU_SET_VOLBUTTON	0x40	/* set volume up/down position */
#define PMU_BACKLIGHT_BRIGHT	0x41	/* set backlight brightness */
#define PMU_GET_VOLBUTTON	0x48	/* get volume up/down position */
#define PMU_PCEJECT		0x4c	/* eject PC-card from slot */
#define PMU_BATTERY_STATE	0x6b	/* report battery state etc. */
#define PMU_SMART_BATTERY_STATE	0x6f	/* report battery state (new way) */
#define PMU_SET_INTR_MASK	0x70	/* set PMU interrupt mask */
#define PMU_INT_ACK		0x78	/* read interrupt bits */
#define PMU_SHUTDOWN		0x7e	/* turn power off */
#define PMU_CPU_SPEED		0x7d	/* control CPU speed on some models */
#define PMU_SLEEP		0x7f	/* put CPU to sleep */
#define PMU_POWER_EVENTS	0x8f	/* Send power-event commands to PMU */
#define PMU_I2C_CMD		0x9a	/* I2C operations */
#define PMU_RESET		0xd0	/* reset CPU */
#define PMU_GET_BRIGHTBUTTON	0xd9	/* report brightness up/down pos */
#define PMU_GET_COVER		0xdc	/* report cover open/closed */
#define PMU_SYSTEM_READY	0xdf	/* tell PMU we are awake */
#define PMU_GET_VERSION		0xea	/* read the PMU version */

/* Bits to use with the PMU_POWER_CTRL0 command */
#define PMU_POW0_ON		0x80	/* OR this to power ON the device */
#define PMU_POW0_OFF		0x00	/* leave bit 7 to 0 to power it OFF */
#define PMU_POW0_HARD_DRIVE	0x04	/* Hard drive power (on wallstreet/lombard ?) */

/* Bits to use with the PMU_POWER_CTRL command */
#define PMU_POW_ON		0x80	/* OR this to power ON the device */
#define PMU_POW_OFF		0x00	/* leave bit 7 to 0 to power it OFF */
#define PMU_POW_BACKLIGHT	0x01	/* backlight power */
#define PMU_POW_CHARGER		0x02	/* battery charger power */
#define PMU_POW_IRLED		0x04	/* IR led power (on wallstreet) */
#define PMU_POW_MEDIABAY	0x08	/* media bay power (wallstreet/lombard ?) */

/* Bits in PMU interrupt and interrupt mask bytes */
#define PMU_INT_PCEJECT		0x04	/* PC-card eject buttons */
#define PMU_INT_SNDBRT		0x08	/* sound/brightness up/down buttons */
#define PMU_INT_ADB		0x10	/* ADB autopoll or reply data */
#define PMU_INT_BATTERY		0x20	/* Battery state change */
#define PMU_INT_ENVIRONMENT	0x40	/* Environment interrupts */
#define PMU_INT_TICK		0x80	/* 1-second tick interrupt */

/* Other bits in PMU interrupt valid when PMU_INT_ADB is set */
#define PMU_INT_ADB_AUTO	0x04	/* ADB autopoll, when PMU_INT_ADB */
#define PMU_INT_WAITING_CHARGER	0x01	/* ??? */
#define PMU_INT_AUTO_SRQ_POLL	0x02	/* ??? */

/* Bits in the environement message (either obtained via PMU_GET_COVER,
 * or via PMU_INT_ENVIRONMENT on core99 */
#define PMU_ENV_LID_CLOSED	0x01	/* The lid is closed */

/* I2C related definitions */
#define PMU_I2C_MODE_SIMPLE	0
#define PMU_I2C_MODE_STDSUB	1
#define PMU_I2C_MODE_COMBINED	2

#define PMU_I2C_BUS_STATUS	0
#define PMU_I2C_BUS_SYSCLK	1
#define PMU_I2C_BUS_POWER	2

#define PMU_I2C_STATUS_OK	0
#define PMU_I2C_STATUS_DATAREAD	1
#define PMU_I2C_STATUS_BUSY	0xfe


/* Kind of PMU (model) */
enum {
	PMU_UNKNOWN,
	PMU_OHARE_BASED,	/* 2400, 3400, 3500 (old G3 powerbook) */
	PMU_HEATHROW_BASED,	/* PowerBook G3 series */
	PMU_PADDINGTON_BASED,	/* 1999 PowerBook G3 */
	PMU_KEYLARGO_BASED,	/* Core99 motherboard (PMU99) */
	PMU_68K_V1,		/* 68K PMU, version 1 */
	PMU_68K_V2, 		/* 68K PMU, version 2 */
};

/* PMU PMU_POWER_EVENTS commands */
enum {
	PMU_PWR_GET_POWERUP_EVENTS	= 0x00,
	PMU_PWR_SET_POWERUP_EVENTS	= 0x01,
	PMU_PWR_CLR_POWERUP_EVENTS	= 0x02,
	PMU_PWR_GET_WAKEUP_EVENTS	= 0x03,
	PMU_PWR_SET_WAKEUP_EVENTS	= 0x04,
	PMU_PWR_CLR_WAKEUP_EVENTS	= 0x05,
};

/* Power events wakeup bits */
enum {
	PMU_PWR_WAKEUP_KEY		= 0x01,	/* Wake on key press */
	PMU_PWR_WAKEUP_AC_INSERT	= 0x02, /* Wake on AC adapter plug */
	PMU_PWR_WAKEUP_AC_CHANGE	= 0x04,
	PMU_PWR_WAKEUP_LID_OPEN		= 0x08,
	PMU_PWR_WAKEUP_RING		= 0x10,
};
	
/*
 * Ioctl commands for the /dev/pmu device
 */
#include <linux/ioctl.h>

/* no param */
#define PMU_IOC_SLEEP		_IO('B', 0)
/* out param: u32*	backlight value: 0 to 15 */
#define PMU_IOC_GET_BACKLIGHT	_IOR('B', 1, size_t)
/* in param: u32	backlight value: 0 to 15 */
#define PMU_IOC_SET_BACKLIGHT	_IOW('B', 2, size_t)
/* out param: u32*	PMU model */
#define PMU_IOC_GET_MODEL	_IOR('B', 3, size_t)
/* out param: u32*	has_adb: 0 or 1 */
#define PMU_IOC_HAS_ADB		_IOR('B', 4, size_t) 
/* out param: u32*	can_sleep: 0 or 1 */
#define PMU_IOC_CAN_SLEEP	_IOR('B', 5, size_t) 
/* no param, but historically was _IOR('B', 6, 0), meaning 4 bytes */
#define PMU_IOC_GRAB_BACKLIGHT	_IOR('B', 6, size_t) 

#ifdef __KERNEL__

extern int find_via_pmu(void);

extern int pmu_request(struct adb_request *req,
		void (*done)(struct adb_request *), int nbytes, ...);

extern void pmu_poll(void);
extern void pmu_poll_adb(void); /* For use by xmon */
extern void pmu_wait_complete(struct adb_request *req);

/* For use before switching interrupts off for a long time;
 * warning: not stackable
 */
extern void pmu_suspend(void);
extern void pmu_resume(void);

extern void pmu_enable_irled(int on);

extern void pmu_restart(void);
extern void pmu_shutdown(void);
extern void pmu_unlock(void);

extern int pmu_present(void);
extern int pmu_get_model(void);

extern int pmu_i2c_combined_read(int bus, int addr, int subaddr,  u8* data, int len);
extern int pmu_i2c_stdsub_write(int bus, int addr, int subaddr,  u8* data, int len);
extern int pmu_i2c_simple_read(int bus, int addr,  u8* data, int len);
extern int pmu_i2c_simple_write(int bus, int addr,  u8* data, int len);


#ifdef CONFIG_PMAC_PBOOK
/*
 * Stuff for putting the powerbook to sleep and waking it again.
 *
 */
#include <linux/list.h>

struct pmu_sleep_notifier
{
	int (*notifier_call)(struct pmu_sleep_notifier *self, int when);
	int priority;
	struct list_head list;
};

/* Code values for calling sleep/wakeup handlers
 *
 * Note: If a sleep request got cancelled, all drivers will get
 * the PBOOK_SLEEP_REJECT, even those who didn't get the PBOOK_SLEEP_REQUEST.
 */
#define PBOOK_SLEEP_REQUEST	1
#define PBOOK_SLEEP_NOW		2
#define PBOOK_SLEEP_REJECT	3
#define PBOOK_WAKE		4

/* Result codes returned by the notifiers */
#define PBOOK_SLEEP_OK		0
#define PBOOK_SLEEP_REFUSE	-1

/* priority levels in notifiers */
#define SLEEP_LEVEL_VIDEO	100	/* Video driver (first wake) */
#define SLEEP_LEVEL_MEDIABAY	90	/* Media bay driver */
#define SLEEP_LEVEL_BLOCK	80	/* IDE, SCSI */
#define SLEEP_LEVEL_NET		70	/* bmac, gmac */
#define SLEEP_LEVEL_MISC	60	/* Anything else */
#define SLEEP_LEVEL_USERLAND	55	/* Reserved for apm_emu */
#define SLEEP_LEVEL_ADB		50	/* ADB (async) */
#define SLEEP_LEVEL_SOUND	40	/* Sound driver (blocking) */

/* special register notifier functions */
int pmu_register_sleep_notifier(struct pmu_sleep_notifier* notifier);
int pmu_unregister_sleep_notifier(struct pmu_sleep_notifier* notifier);

#define PMU_MAX_BATTERIES	2

/* values for pmu_power_flags */
#define PMU_PWR_AC_PRESENT	0x00000001

/* values for pmu_battery_info.flags */
#define PMU_BATT_PRESENT	0x00000001
#define PMU_BATT_CHARGING	0x00000002
#define PMU_BATT_TYPE_MASK	0x000000f0
#define PMU_BATT_TYPE_SMART	0x00000010 /* Smart battery */
#define PMU_BATT_TYPE_HOOPER	0x00000020 /* 3400/3500 */
#define PMU_BATT_TYPE_COMET	0x00000030 /* 2400 */

struct pmu_battery_info
{
	unsigned int	flags;
	unsigned int	charge;		/* current charge */
	unsigned int	max_charge;	/* maximum charge */
	signed int	amperage;	/* current, positive if charging */
	unsigned int	voltage;	/* voltage */
	unsigned int	time_remaining;	/* remaining time */
};

extern int pmu_battery_count;
extern struct pmu_battery_info pmu_batteries[PMU_MAX_BATTERIES];
extern unsigned int pmu_power_flags;

#endif /* CONFIG_PMAC_PBOOK */

#endif	/* __KERNEL__ */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩高清不卡一区二区三区| 中文字幕一区二区在线观看| 国产成人亚洲精品狼色在线| 亚洲丝袜另类动漫二区| 欧美一区二区精美| 99re成人精品视频| 国产美女精品人人做人人爽| 性久久久久久久| 亚洲欧美日韩电影| 国产欧美一区二区精品性色| 在线播放欧美女士性生活| 99国产精品久久久久久久久久久 | 日韩av午夜在线观看| 中文字幕亚洲电影| 日本一区二区三区四区在线视频| 欧美高清视频在线高清观看mv色露露十八| 不卡电影免费在线播放一区| 国产综合色在线视频区| 日韩av高清在线观看| 亚洲成a人在线观看| 亚洲色图欧美激情| 国产精品久久久久久亚洲毛片| 精品久久99ma| 日韩视频永久免费| 91精品国产免费久久综合| 在线观看日韩av先锋影音电影院| 99久久精品免费精品国产| 国产盗摄视频一区二区三区| 国产在线不卡一区| 久久精品国产澳门| 五月天精品一区二区三区| 亚洲一区二区三区美女| 亚洲乱码日产精品bd| 亚洲欧美日韩一区二区 | 精品国产一区二区三区不卡| 3atv在线一区二区三区| 欧美久久一二区| 欧美一区二区三区小说| 欧美一区二区三区电影| 欧美草草影院在线视频| 日韩欧美国产综合在线一区二区三区| 777xxx欧美| 日韩一区二区电影在线| 日韩欧美在线综合网| 日韩欧美中文字幕一区| 欧美精品一区男女天堂| 久久精品亚洲一区二区三区浴池 | 国产一区二区三区四| 国产九色精品成人porny| 国产剧情一区二区| 成人免费看黄yyy456| va亚洲va日韩不卡在线观看| 94-欧美-setu| 欧美日韩午夜在线| 91精品欧美久久久久久动漫| 欧美一级午夜免费电影| 亚洲精品在线电影| 国产精品嫩草影院av蜜臀| 日韩毛片精品高清免费| 亚洲一区二区av在线| 青青国产91久久久久久| 极品瑜伽女神91| 成人av免费在线观看| 欧美特级限制片免费在线观看| 欧美日韩一区不卡| 精品久久久久久久久久久久久久久久久 | 成人激情动漫在线观看| 色婷婷精品久久二区二区蜜臀av | 欧美日韩一区二区在线观看视频| 777亚洲妇女| 26uuu国产一区二区三区| 国产精品乱人伦| 亚洲成a天堂v人片| 国产传媒一区在线| 欧美色精品天天在线观看视频| 91精品国产免费久久综合| 中文字幕精品一区| 亚洲成人综合网站| 国产成人午夜精品影院观看视频 | 国产精品剧情在线亚洲| 亚洲在线观看免费| 国产一区在线精品| 欧美亚洲动漫另类| 精品国产髙清在线看国产毛片| 中文字幕一区不卡| 久久成人久久爱| 在线精品观看国产| 久久精品视频一区二区三区| 一区二区免费在线| 丰满亚洲少妇av| 日韩一级免费观看| 亚洲精品视频自拍| 丰满岳乱妇一区二区三区| 制服丝袜日韩国产| 亚洲欧美日韩国产一区二区三区 | 亚洲综合一区在线| 国产毛片一区二区| 欧美一级精品在线| 亚洲国产精品欧美一二99| 成人免费毛片片v| 欧美成人精品福利| 午夜不卡在线视频| 色www精品视频在线观看| 久久久99精品免费观看不卡| 天天操天天综合网| 日本韩国欧美一区二区三区| 国产视频911| 精品一区二区三区免费毛片爱 | 国产欧美视频一区二区| 人人精品人人爱| 欧美亚洲一区二区三区四区| 国产精品久久久久影院色老大| 久久精品国产77777蜜臀| 欧美日韩成人一区| 亚洲精品免费一二三区| 成人一区在线观看| 久久久久久久电影| 国产精品资源网站| 久久久国际精品| 国产一区二区精品久久99| 日韩欧美亚洲国产精品字幕久久久| 一区二区三区日韩欧美精品| 91麻豆免费观看| 亚洲色图欧美激情| 97aⅴ精品视频一二三区| 国产精品入口麻豆原神| 国产激情精品久久久第一区二区 | 亚洲色欲色欲www在线观看| 丁香啪啪综合成人亚洲小说| 国产亚洲欧美日韩日本| 国产一区二区三区四| 久久久亚洲午夜电影| 国产一区二区视频在线| 国产亚洲欧美在线| 成人丝袜18视频在线观看| 欧美激情一区二区三区蜜桃视频| 国产白丝网站精品污在线入口| 久久亚洲影视婷婷| 国产精品影视网| 国产偷国产偷亚洲高清人白洁| 国产精品亚洲а∨天堂免在线| 久久久美女毛片| 国产iv一区二区三区| 国产精品久久久久影院| 色偷偷一区二区三区| 亚洲国产精品久久久男人的天堂| 欧美视频在线播放| 日韩av一区二区三区四区| 26uuu欧美| 成人免费观看男女羞羞视频| 综合网在线视频| 欧美视频中文字幕| 另类小说图片综合网| 久久网站热最新地址| 国产91精品精华液一区二区三区| 亚洲欧洲日本在线| 欧美性xxxxx极品少妇| 日本欧美肥老太交大片| 2024国产精品视频| 99国产精品国产精品毛片| 亚洲国产乱码最新视频| 精品粉嫩aⅴ一区二区三区四区 | 欧美一区二区性放荡片| 国产美女视频91| 一区二区三区四区视频精品免费 | 久久综合av免费| 94-欧美-setu| 日本伊人午夜精品| 欧美激情综合在线| 欧美日韩中文字幕一区二区| 激情综合网最新| 亚洲欧美综合网| 91精品在线观看入口| 成人一区二区三区在线观看| 亚洲午夜电影网| 欧美激情在线观看视频免费| 欧美揉bbbbb揉bbbbb| 国产精品一区二区你懂的| 一区二区日韩av| 久久精品一区二区三区不卡牛牛| 91蝌蚪porny成人天涯| 久久精品国产久精国产| 亚洲同性同志一二三专区| 欧美一区二区免费| 色综合婷婷久久| 国产一区二区免费在线| 午夜精品久久久久久久蜜桃app| 国产欧美日韩三级| 在线综合+亚洲+欧美中文字幕| 成人av在线资源网| 经典三级一区二区| 亚洲国产成人av网| 亚洲欧洲精品一区二区三区不卡| 欧美一区二区三区影视| 在线区一区二视频| 粉嫩av一区二区三区在线播放| 日韩精品1区2区3区| 亚洲美女一区二区三区| 精品国产污污免费网站入口| 在线这里只有精品|