patch-2.2.12 linux/include/asm-ppc/pmu.h
Next file: linux/include/asm-ppc/processor.h
Previous file: linux/include/asm-ppc/ohare.h
Back to the patch index
Back to the overall index
- Lines: 92
- Date:
Wed Aug 25 17:29:49 1999
- Orig file:
v2.2.11/linux/include/asm-ppc/pmu.h
- Orig date:
Thu Apr 29 12:39:01 1999
diff -u --recursive --new-file v2.2.11/linux/include/asm-ppc/pmu.h linux/include/asm-ppc/pmu.h
@@ -33,20 +33,23 @@
#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_IRLED 0x04 /* IR led power (on wallstreet) ??? */
+#define PMU_POW_IRLED 0x04 /* IR led power (on wallstreet) */
/* Bits in PMU interrupt and interrupt mask bytes */
#define PMU_INT_ADB_AUTO 0x04 /* ADB autopoll, when PMU_INT_ADB */
#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
+#define PMU_INT_WAKEUP 0x40
#define PMU_INT_TICK 0x80 /* 1-second tick interrupt */
/* Kind of PMU (model) */
enum {
- PMU_UNKNOWN,
- PMU_OHARE_BASED,
- PMU_HEATHROW_BASED
+ PMU_UNKNOWN,
+ PMU_OHARE_BASED, /* 2400, 3400, 3500 (old G3 powerbook) */
+ PMU_HEATHROW_BASED, /* PowerBook G3 series */
+ PMU_PADDINGTON_BASED, /* 1999 PowerBook G3 */
};
/*
@@ -65,7 +68,7 @@
#ifdef __KERNEL__
-void find_via_pmu(void);
+int find_via_pmu(void);
void via_pmu_init(void);
int pmu_request(struct adb_request *req,
@@ -83,15 +86,49 @@
int pmu_present(void);
int pmu_get_model(void);
+#ifdef CONFIG_PMAC_PBOOK
/*
* Stuff for putting the powerbook to sleep and waking it again.
+ *
*/
-#include <linux/notifier.h>
+#include <linux/list.h>
-extern struct notifier_block *sleep_notifier_list;
+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_SOUND 90 /* Sound driver */
+#define SLEEP_LEVEL_MEDIABAY 80 /* Media bay driver */
+#define SLEEP_LEVEL_BLOCK 70 /* IDE, SCSI */
+#define SLEEP_LEVEL_NET 60 /* bmac */
+#define SLEEP_LEVEL_ADB 50 /* ADB */
+#define SLEEP_LEVEL_MISC 30 /* Anything */
+#define SLEEP_LEVEL_LAST 0 /* Anything */
+
+/* special register notifier functions */
+int pmu_register_sleep_notifier(struct pmu_sleep_notifier* notifier);
+int pmu_unregister_sleep_notifier(struct pmu_sleep_notifier* notifier);
+
+#endif /* CONFIG_PMAC_PBOOK */
-/* code values for calling sleep/wakeup handlers */
-#define PBOOK_SLEEP 1
-#define PBOOK_WAKE 2
#endif /* __KERNEL */
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)