blob: 7fa37e15f1961b8c6b48834bc4886c403bcb568c [file] [log] [blame]
Liam Girdwood0ca06a02005-07-29 16:13:36 +02001/*
2 * Linux driver model AC97 bus interface
3 *
4 * Author: Nicolas Pitre
5 * Created: Jan 14, 2005
6 * Copyright: (C) MontaVista Software Inc.
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 */
13
Jaroslav Kysela5049c352005-08-22 12:19:14 +020014#include <linux/module.h>
Liam Girdwood0ca06a02005-07-29 16:13:36 +020015#include <linux/init.h>
16#include <linux/device.h>
17#include <linux/string.h>
18
19/*
Nicolas Pitre3a91e952005-09-16 18:46:36 +020020 * Let drivers decide whether they want to support given codec from their
Takashi Iwaiee423812005-11-17 14:21:36 +010021 * probe method. Drivers have direct access to the struct snd_ac97 structure and may
Nicolas Pitre3a91e952005-09-16 18:46:36 +020022 * decide based on the id field amongst other things.
Liam Girdwood0ca06a02005-07-29 16:13:36 +020023 */
24static int ac97_bus_match(struct device *dev, struct device_driver *drv)
25{
Nicolas Pitre3a91e952005-09-16 18:46:36 +020026 return 1;
Liam Girdwood0ca06a02005-07-29 16:13:36 +020027}
28
Martin Langer66e27782007-02-05 13:02:35 +010029#ifdef CONFIG_PM
Liam Girdwood0ca06a02005-07-29 16:13:36 +020030static int ac97_bus_suspend(struct device *dev, pm_message_t state)
31{
32 int ret = 0;
33
Nicolas Pitre90b66e82005-09-16 18:50:53 +020034 if (dev->driver && dev->driver->suspend)
Russell King9480e302005-10-28 09:52:56 -070035 ret = dev->driver->suspend(dev, state);
36
Liam Girdwood0ca06a02005-07-29 16:13:36 +020037 return ret;
38}
39
40static int ac97_bus_resume(struct device *dev)
41{
42 int ret = 0;
43
Nicolas Pitre90b66e82005-09-16 18:50:53 +020044 if (dev->driver && dev->driver->resume)
Russell King9480e302005-10-28 09:52:56 -070045 ret = dev->driver->resume(dev);
46
Liam Girdwood0ca06a02005-07-29 16:13:36 +020047 return ret;
48}
Martin Langer66e27782007-02-05 13:02:35 +010049#endif /* CONFIG_PM */
Liam Girdwood0ca06a02005-07-29 16:13:36 +020050
51struct bus_type ac97_bus_type = {
52 .name = "ac97",
53 .match = ac97_bus_match,
Martin Langer66e27782007-02-05 13:02:35 +010054#ifdef CONFIG_PM
Liam Girdwood0ca06a02005-07-29 16:13:36 +020055 .suspend = ac97_bus_suspend,
56 .resume = ac97_bus_resume,
Martin Langer66e27782007-02-05 13:02:35 +010057#endif /* CONFIG_PM */
Liam Girdwood0ca06a02005-07-29 16:13:36 +020058};
59
60static int __init ac97_bus_init(void)
61{
62 return bus_register(&ac97_bus_type);
63}
64
65subsys_initcall(ac97_bus_init);
66
67static void __exit ac97_bus_exit(void)
68{
69 bus_unregister(&ac97_bus_type);
70}
71
72module_exit(ac97_bus_exit);
73
74EXPORT_SYMBOL(ac97_bus_type);
75
76MODULE_LICENSE("GPL");