2008-04-14 03:41:55 +07:00
|
|
|
#ifndef __LINUX_PWM_H
|
|
|
|
#define __LINUX_PWM_H
|
|
|
|
|
|
|
|
struct pwm_device;
|
2012-03-26 14:31:48 +07:00
|
|
|
struct seq_file;
|
2008-04-14 03:41:55 +07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* pwm_request - request a PWM device
|
|
|
|
*/
|
|
|
|
struct pwm_device *pwm_request(int pwm_id, const char *label);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* pwm_free - free a PWM device
|
|
|
|
*/
|
|
|
|
void pwm_free(struct pwm_device *pwm);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* pwm_config - change a PWM device configuration
|
|
|
|
*/
|
|
|
|
int pwm_config(struct pwm_device *pwm, int duty_ns, int period_ns);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* pwm_enable - start a PWM output toggling
|
|
|
|
*/
|
|
|
|
int pwm_enable(struct pwm_device *pwm);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* pwm_disable - stop a PWM output toggling
|
|
|
|
*/
|
|
|
|
void pwm_disable(struct pwm_device *pwm);
|
|
|
|
|
2011-01-28 15:40:40 +07:00
|
|
|
#ifdef CONFIG_PWM
|
|
|
|
struct pwm_chip;
|
|
|
|
|
2011-12-14 17:12:23 +07:00
|
|
|
enum {
|
|
|
|
PWMF_REQUESTED = 1 << 0,
|
|
|
|
PWMF_ENABLED = 1 << 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct pwm_device {
|
|
|
|
const char *label;
|
|
|
|
unsigned long flags;
|
|
|
|
unsigned int hwpwm;
|
|
|
|
unsigned int pwm;
|
|
|
|
struct pwm_chip *chip;
|
|
|
|
void *chip_data;
|
|
|
|
|
|
|
|
unsigned int period; /* in nanoseconds */
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline void pwm_set_period(struct pwm_device *pwm, unsigned int period)
|
|
|
|
{
|
|
|
|
if (pwm)
|
|
|
|
pwm->period = period;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline unsigned int pwm_get_period(struct pwm_device *pwm)
|
|
|
|
{
|
|
|
|
return pwm ? pwm->period : 0;
|
|
|
|
}
|
|
|
|
|
2011-01-28 15:40:40 +07:00
|
|
|
/**
|
|
|
|
* struct pwm_ops - PWM controller operations
|
|
|
|
* @request: optional hook for requesting a PWM
|
|
|
|
* @free: optional hook for freeing a PWM
|
|
|
|
* @config: configure duty cycles and period length for this PWM
|
|
|
|
* @enable: enable PWM output toggling
|
|
|
|
* @disable: disable PWM output toggling
|
2012-03-26 14:31:48 +07:00
|
|
|
* @dbg_show: optional routine to show contents in debugfs
|
2011-01-28 15:40:40 +07:00
|
|
|
* @owner: helps prevent removal of modules exporting active PWMs
|
|
|
|
*/
|
|
|
|
struct pwm_ops {
|
2011-12-14 17:12:23 +07:00
|
|
|
int (*request)(struct pwm_chip *chip,
|
|
|
|
struct pwm_device *pwm);
|
|
|
|
void (*free)(struct pwm_chip *chip,
|
|
|
|
struct pwm_device *pwm);
|
|
|
|
int (*config)(struct pwm_chip *chip,
|
|
|
|
struct pwm_device *pwm,
|
|
|
|
int duty_ns, int period_ns);
|
|
|
|
int (*enable)(struct pwm_chip *chip,
|
|
|
|
struct pwm_device *pwm);
|
|
|
|
void (*disable)(struct pwm_chip *chip,
|
|
|
|
struct pwm_device *pwm);
|
2012-03-26 14:31:48 +07:00
|
|
|
#ifdef CONFIG_DEBUG_FS
|
|
|
|
void (*dbg_show)(struct pwm_chip *chip,
|
|
|
|
struct seq_file *s);
|
|
|
|
#endif
|
2011-01-28 15:40:40 +07:00
|
|
|
struct module *owner;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2011-12-14 17:12:23 +07:00
|
|
|
* struct pwm_chip - abstract a PWM controller
|
|
|
|
* @dev: device providing the PWMs
|
|
|
|
* @list: list node for internal use
|
|
|
|
* @ops: callbacks for this PWM controller
|
|
|
|
* @base: number of first PWM controlled by this chip
|
|
|
|
* @npwm: number of PWMs controlled by this chip
|
|
|
|
* @pwms: array of PWM devices allocated by the framework
|
2011-01-28 15:40:40 +07:00
|
|
|
*/
|
|
|
|
struct pwm_chip {
|
2011-12-14 17:12:23 +07:00
|
|
|
struct device *dev;
|
|
|
|
struct list_head list;
|
|
|
|
const struct pwm_ops *ops;
|
|
|
|
int base;
|
|
|
|
unsigned int npwm;
|
|
|
|
|
|
|
|
struct pwm_device *pwms;
|
2011-01-28 15:40:40 +07:00
|
|
|
};
|
|
|
|
|
2011-12-14 17:12:23 +07:00
|
|
|
int pwm_set_chip_data(struct pwm_device *pwm, void *data);
|
|
|
|
void *pwm_get_chip_data(struct pwm_device *pwm);
|
|
|
|
|
2011-01-28 15:40:40 +07:00
|
|
|
int pwmchip_add(struct pwm_chip *chip);
|
|
|
|
int pwmchip_remove(struct pwm_chip *chip);
|
2011-12-14 17:12:23 +07:00
|
|
|
struct pwm_device *pwm_request_from_chip(struct pwm_chip *chip,
|
|
|
|
unsigned int index,
|
|
|
|
const char *label);
|
2012-03-26 13:42:48 +07:00
|
|
|
|
|
|
|
struct pwm_device *pwm_get(struct device *dev, const char *consumer);
|
|
|
|
void pwm_put(struct pwm_device *pwm);
|
|
|
|
|
|
|
|
struct pwm_lookup {
|
|
|
|
struct list_head list;
|
|
|
|
const char *provider;
|
|
|
|
unsigned int index;
|
|
|
|
const char *dev_id;
|
|
|
|
const char *con_id;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define PWM_LOOKUP(_provider, _index, _dev_id, _con_id) \
|
|
|
|
{ \
|
|
|
|
.provider = _provider, \
|
|
|
|
.index = _index, \
|
|
|
|
.dev_id = _dev_id, \
|
|
|
|
.con_id = _con_id, \
|
|
|
|
}
|
|
|
|
|
|
|
|
void pwm_add_table(struct pwm_lookup *table, size_t num);
|
|
|
|
|
2011-01-28 15:40:40 +07:00
|
|
|
#endif
|
|
|
|
|
2009-01-19 00:42:45 +07:00
|
|
|
#endif /* __LINUX_PWM_H */
|