blob: a47ee1b70d2086b76bf41852650dc236fc483e38 [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
Linus Torvalds1da177e2005-04-16 15:20:36 -070011#include <linux/device.h>
12#include <asm/semaphore.h>
13
Adrian Bunkf67d1152006-01-19 17:30:17 +010014#include "../base.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070015#include "power.h"
16
17#define to_dev(node) container_of(node, struct device, kobj.entry)
18
Linus Torvalds1da177e2005-04-16 15:20:36 -070019
Linus Torvalds1da177e2005-04-16 15:20:36 -070020/**
21 * We handle system devices differently - we suspend and shut them
22 * down last and resume them first. That way, we don't do anything stupid like
23 * shutting down the interrupt controller before any devices..
24 *
25 * Note that there are not different stages for power management calls -
26 * they only get one called once when interrupts are disabled.
27 */
28
Linus Torvalds1da177e2005-04-16 15:20:36 -070029
30/**
31 * device_shutdown - call ->shutdown() on each device to shutdown.
32 */
33void device_shutdown(void)
34{
Michael Richardson9c08a932006-01-09 01:04:51 -080035 struct device * dev, *devn;
Linus Torvalds1da177e2005-04-16 15:20:36 -070036
Greg Kroah-Hartman823bccf2007-04-13 13:15:19 -070037 list_for_each_entry_safe_reverse(dev, devn, &devices_subsys.list,
David Brownell82428b62005-05-09 08:07:00 -070038 kobj.entry) {
Russell King594c8282006-01-05 14:29:51 +000039 if (dev->bus && dev->bus->shutdown) {
40 dev_dbg(dev, "shutdown\n");
41 dev->bus->shutdown(dev);
42 } else if (dev->driver && dev->driver->shutdown) {
David Brownell82428b62005-05-09 08:07:00 -070043 dev_dbg(dev, "shutdown\n");
Linus Torvalds1da177e2005-04-16 15:20:36 -070044 dev->driver->shutdown(dev);
David Brownell82428b62005-05-09 08:07:00 -070045 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070046 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070047
48 sysdev_shutdown();
49}
50