fixup: module.h (max1749.c)
[linux-2.6.git] / drivers / misc / max1749.c
1 /*
2  * drivers/misc/max1749.c
3  *
4  * Driver for MAX1749, vibrator motor driver.
5  *
6  * Copyright (c) 2011, NVIDIA Corporation.
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  * This program is distributed in the hope that it will be useful, but WITHOUT
14  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
15  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
16  * more details.
17  *
18  * You should have received a copy of the GNU General Public License along
19  * with this program; if not, write to the Free Software Foundation, Inc.,
20  * 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
21  */
22
23 #include <linux/module.h>
24 #include <linux/regulator/consumer.h>
25 #include <linux/kernel.h>
26 #include <linux/platform_device.h>
27 #include <linux/err.h>
28 #include <linux/hrtimer.h>
29 #include <linux/delay.h>
30
31 #include "../staging/android/timed_output.h"
32
33 static struct regulator *regulator;
34 static int timeout;
35
36 static void vibrator_start(void)
37 {
38         regulator_enable(regulator);
39 }
40
41 static void vibrator_stop(void)
42 {
43         int ret;
44
45         ret = regulator_is_enabled(regulator);
46         if (ret > 0)
47                 regulator_disable(regulator);
48 }
49
50 /*
51  * Timeout value can be changed from sysfs entry
52  * created by timed_output_dev.
53  * echo 100 > /sys/class/timed_output/vibrator/enable
54  */
55 static void vibrator_enable(struct timed_output_dev *dev, int value)
56 {
57         timeout = value;
58         if (!regulator)
59                 return;
60
61         if (value) {
62                 vibrator_start();
63                 msleep(value);
64                 vibrator_stop();
65         } else {
66                 vibrator_stop();
67         }
68 }
69
70 /*
71  * Timeout value can be read from sysfs entry
72  * created by timed_output_dev.
73  * cat /sys/class/timed_output/vibrator/enable
74  */
75 static int vibrator_get_time(struct timed_output_dev *dev)
76 {
77         return timeout;
78 }
79
80 static struct timed_output_dev vibrator_dev = {
81         .name           = "vibrator",
82         .get_time       = vibrator_get_time,
83         .enable         = vibrator_enable,
84 };
85
86 static int __init vibrator_init(void)
87 {
88         int status;
89
90         regulator = regulator_get(NULL, "vdd_vbrtr");
91         if (IS_ERR_OR_NULL(regulator)) {
92                 pr_err("vibrator_init:Couldn't get regulator vdd_vbrtr\n");
93                 regulator = NULL;
94                 return PTR_ERR(regulator);
95         }
96
97         status = timed_output_dev_register(&vibrator_dev);
98
99         if (status) {
100                 regulator_put(regulator);
101                 regulator = NULL;
102         }
103         return status;
104 }
105
106 static void __exit vibrator_exit(void)
107 {
108         if (regulator) {
109                 timed_output_dev_unregister(&vibrator_dev);
110                 regulator_put(regulator);
111                 regulator = NULL;
112         }
113 }
114
115 MODULE_DESCRIPTION("timed output vibrator device");
116 MODULE_AUTHOR("GPL");
117
118 module_init(vibrator_init);
119 module_exit(vibrator_exit);