blob: 8826a5b6673eb9e4dfae4bb0d0b53126b77e4119 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * shutdown.c - power management functions for the device tree.
3 *
4 * Copyright (c) 2002-3 Patrick Mochel
5 * 2002-3 Open Source Development Lab
6 *
7 * This file is released under the GPLv2
8 *
9 */
10
11#include <linux/config.h>
12#include <linux/device.h>
13#include <asm/semaphore.h>
14
Adrian Bunkf67d1152006-01-19 17:30:17 +010015#include "../base.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070016#include "power.h"
17
18#define to_dev(node) container_of(node, struct device, kobj.entry)
19
20extern struct subsystem devices_subsys;
21
22
Linus Torvalds1da177e2005-04-16 15:20:36 -070023/**
24 * We handle system devices differently - we suspend and shut them
25 * down last and resume them first. That way, we don't do anything stupid like
26 * shutting down the interrupt controller before any devices..
27 *
28 * Note that there are not different stages for power management calls -
29 * they only get one called once when interrupts are disabled.
30 */
31
Linus Torvalds1da177e2005-04-16 15:20:36 -070032
33/**
34 * device_shutdown - call ->shutdown() on each device to shutdown.
35 */
36void device_shutdown(void)
37{
Michael Richardson9c08a932006-01-09 01:04:51 -080038 struct device * dev, *devn;
Linus Torvalds1da177e2005-04-16 15:20:36 -070039
40 down_write(&devices_subsys.rwsem);
Michael Richardson9c08a932006-01-09 01:04:51 -080041 list_for_each_entry_safe_reverse(dev, devn, &devices_subsys.kset.list,
David Brownell82428b62005-05-09 08:07:00 -070042 kobj.entry) {
Russell King594c8282006-01-05 14:29:51 +000043 if (dev->bus && dev->bus->shutdown) {
44 dev_dbg(dev, "shutdown\n");
45 dev->bus->shutdown(dev);
46 } else if (dev->driver && dev->driver->shutdown) {
David Brownell82428b62005-05-09 08:07:00 -070047 dev_dbg(dev, "shutdown\n");
Linus Torvalds1da177e2005-04-16 15:20:36 -070048 dev->driver->shutdown(dev);
David Brownell82428b62005-05-09 08:07:00 -070049 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070050 }
51 up_write(&devices_subsys.rwsem);
52
53 sysdev_shutdown();
54}
55