blob: 40c7643189572ef17f37ba00a06d11fd4d686532 [file] [log] [blame]
Russell King1a189b92008-04-13 21:41:55 +01001#ifndef __LINUX_PWM_H
2#define __LINUX_PWM_H
3
Thierry Reding7299ab72011-12-14 11:10:32 +01004#include <linux/of.h>
5
Russell King1a189b92008-04-13 21:41:55 +01006struct pwm_device;
Thierry Reding62099ab2012-03-26 09:31:48 +02007struct seq_file;
Russell King1a189b92008-04-13 21:41:55 +01008
9/*
10 * pwm_request - request a PWM device
11 */
12struct pwm_device *pwm_request(int pwm_id, const char *label);
13
14/*
15 * pwm_free - free a PWM device
16 */
17void pwm_free(struct pwm_device *pwm);
18
19/*
20 * pwm_config - change a PWM device configuration
21 */
22int pwm_config(struct pwm_device *pwm, int duty_ns, int period_ns);
23
24/*
25 * pwm_enable - start a PWM output toggling
26 */
27int pwm_enable(struct pwm_device *pwm);
28
29/*
30 * pwm_disable - stop a PWM output toggling
31 */
32void pwm_disable(struct pwm_device *pwm);
33
Sascha Hauer0c2498f2011-01-28 09:40:40 +010034#ifdef CONFIG_PWM
35struct pwm_chip;
36
Philip, Avinash0aa08692012-07-24 19:35:32 +053037/**
38 * enum pwm_polarity - polarity of a PWM signal
39 * @PWM_POLARITY_NORMAL: a high signal for the duration of the duty-
40 * cycle, followed by a low signal for the remainder of the pulse
41 * period
42 * @PWM_POLARITY_INVERSED: a low signal for the duration of the duty-
43 * cycle, followed by a high signal for the remainder of the pulse
44 * period
45 */
46enum pwm_polarity {
47 PWM_POLARITY_NORMAL,
48 PWM_POLARITY_INVERSED,
49};
50
Thierry Redingf051c462011-12-14 11:12:23 +010051enum {
52 PWMF_REQUESTED = 1 << 0,
53 PWMF_ENABLED = 1 << 1,
54};
55
56struct pwm_device {
57 const char *label;
58 unsigned long flags;
59 unsigned int hwpwm;
60 unsigned int pwm;
61 struct pwm_chip *chip;
62 void *chip_data;
63
64 unsigned int period; /* in nanoseconds */
65};
66
67static inline void pwm_set_period(struct pwm_device *pwm, unsigned int period)
68{
69 if (pwm)
70 pwm->period = period;
71}
72
73static inline unsigned int pwm_get_period(struct pwm_device *pwm)
74{
75 return pwm ? pwm->period : 0;
76}
77
Philip, Avinash0aa08692012-07-24 19:35:32 +053078/*
79 * pwm_set_polarity - configure the polarity of a PWM signal
80 */
81int pwm_set_polarity(struct pwm_device *pwm, enum pwm_polarity polarity);
82
Sascha Hauer0c2498f2011-01-28 09:40:40 +010083/**
84 * struct pwm_ops - PWM controller operations
85 * @request: optional hook for requesting a PWM
86 * @free: optional hook for freeing a PWM
87 * @config: configure duty cycles and period length for this PWM
Philip, Avinash0aa08692012-07-24 19:35:32 +053088 * @set_polarity: configure the polarity of this PWM
Sascha Hauer0c2498f2011-01-28 09:40:40 +010089 * @enable: enable PWM output toggling
90 * @disable: disable PWM output toggling
Thierry Reding62099ab2012-03-26 09:31:48 +020091 * @dbg_show: optional routine to show contents in debugfs
Sascha Hauer0c2498f2011-01-28 09:40:40 +010092 * @owner: helps prevent removal of modules exporting active PWMs
93 */
94struct pwm_ops {
Thierry Redingf051c462011-12-14 11:12:23 +010095 int (*request)(struct pwm_chip *chip,
96 struct pwm_device *pwm);
97 void (*free)(struct pwm_chip *chip,
98 struct pwm_device *pwm);
99 int (*config)(struct pwm_chip *chip,
100 struct pwm_device *pwm,
101 int duty_ns, int period_ns);
Philip, Avinash0aa08692012-07-24 19:35:32 +0530102 int (*set_polarity)(struct pwm_chip *chip,
103 struct pwm_device *pwm,
104 enum pwm_polarity polarity);
Thierry Redingf051c462011-12-14 11:12:23 +0100105 int (*enable)(struct pwm_chip *chip,
106 struct pwm_device *pwm);
107 void (*disable)(struct pwm_chip *chip,
108 struct pwm_device *pwm);
Thierry Reding62099ab2012-03-26 09:31:48 +0200109#ifdef CONFIG_DEBUG_FS
110 void (*dbg_show)(struct pwm_chip *chip,
111 struct seq_file *s);
112#endif
Sascha Hauer0c2498f2011-01-28 09:40:40 +0100113 struct module *owner;
114};
115
116/**
Thierry Redingf051c462011-12-14 11:12:23 +0100117 * struct pwm_chip - abstract a PWM controller
118 * @dev: device providing the PWMs
119 * @list: list node for internal use
120 * @ops: callbacks for this PWM controller
121 * @base: number of first PWM controlled by this chip
122 * @npwm: number of PWMs controlled by this chip
123 * @pwms: array of PWM devices allocated by the framework
Sascha Hauer0c2498f2011-01-28 09:40:40 +0100124 */
125struct pwm_chip {
Thierry Redingf051c462011-12-14 11:12:23 +0100126 struct device *dev;
127 struct list_head list;
128 const struct pwm_ops *ops;
129 int base;
130 unsigned int npwm;
131
132 struct pwm_device *pwms;
Thierry Reding7299ab72011-12-14 11:10:32 +0100133
134 struct pwm_device * (*of_xlate)(struct pwm_chip *pc,
135 const struct of_phandle_args *args);
136 unsigned int of_pwm_n_cells;
Sascha Hauer0c2498f2011-01-28 09:40:40 +0100137};
138
Thierry Redingf051c462011-12-14 11:12:23 +0100139int pwm_set_chip_data(struct pwm_device *pwm, void *data);
140void *pwm_get_chip_data(struct pwm_device *pwm);
141
Sascha Hauer0c2498f2011-01-28 09:40:40 +0100142int pwmchip_add(struct pwm_chip *chip);
143int pwmchip_remove(struct pwm_chip *chip);
Thierry Redingf051c462011-12-14 11:12:23 +0100144struct pwm_device *pwm_request_from_chip(struct pwm_chip *chip,
145 unsigned int index,
146 const char *label);
Thierry Reding8138d2d2012-03-26 08:42:48 +0200147
148struct pwm_device *pwm_get(struct device *dev, const char *consumer);
149void pwm_put(struct pwm_device *pwm);
150
Alexandre Courbot63543162012-08-01 19:20:58 +0900151struct pwm_device *devm_pwm_get(struct device *dev, const char *consumer);
152void devm_pwm_put(struct device *dev, struct pwm_device *pwm);
153
Thierry Reding8138d2d2012-03-26 08:42:48 +0200154struct pwm_lookup {
155 struct list_head list;
156 const char *provider;
157 unsigned int index;
158 const char *dev_id;
159 const char *con_id;
160};
161
162#define PWM_LOOKUP(_provider, _index, _dev_id, _con_id) \
163 { \
164 .provider = _provider, \
165 .index = _index, \
166 .dev_id = _dev_id, \
167 .con_id = _con_id, \
168 }
169
170void pwm_add_table(struct pwm_lookup *table, size_t num);
171
Sascha Hauer0c2498f2011-01-28 09:40:40 +0100172#endif
173
Mark Vels5243ef82009-01-18 18:42:45 +0100174#endif /* __LINUX_PWM_H */