1 /* SPDX-License-Identifier: GPL-2.0+ */ 2 /* 3 * header file for pwm driver. 4 * 5 * Copyright 2016 Google Inc. 6 * Copyright (c) 2011 samsung electronics 7 * Donghwa Lee <dh09.lee (at) samsung.com> 8 */ 9 10 #ifndef _pwm_h_ 11 #define _pwm_h_ 12 13 /* struct pwm_ops: Operations for the PWM uclass */ 14 struct pwm_ops { 15 /** 16 * set_config() - Set the PWM configuration 17 * 18 * @dev: PWM device to update 19 * @channel: PWM channel to update 20 * @period_ns: PWM period in nanoseconds 21 * @duty_ns: PWM duty period in nanoseconds 22 * @return 0 if OK, -ve on error 23 */ 24 int (*set_config)(struct udevice *dev, uint channel, uint period_ns, 25 uint duty_ns); 26 27 /** 28 * set_enable() - Enable or disable the PWM 29 * 30 * @dev: PWM device to update 31 * @channel: PWM channel to update 32 * @enable: true to enable, false to disable 33 * @return 0 if OK, -ve on error 34 */ 35 int (*set_enable)(struct udevice *dev, uint channel, bool enable); 36 /** 37 * set_invert() - Set the PWM invert 38 * 39 * @dev: PWM device to update 40 * @channel: PWM channel to update 41 * @polarity: true to invert, false to keep normal polarity 42 * @return 0 if OK, -ve on error 43 */ 44 int (*set_invert)(struct udevice *dev, uint channel, bool polarity); 45 }; 46 47 #define pwm_get_ops(dev) ((struct pwm_ops *)(dev)->driver->ops) 48 49 /** 50 * pwm_set_config() - Set the PWM configuration 51 * 52 * @dev: PWM device to update 53 * @channel: PWM channel to update 54 * @period_ns: PWM period in nanoseconds 55 * @duty_ns: PWM duty period in nanoseconds 56 * @return 0 if OK, -ve on error 57 */ 58 int pwm_set_config(struct udevice *dev, uint channel, uint period_ns, 59 uint duty_ns); 60 61 /** 62 * pwm_set_enable() - Enable or disable the PWM 63 * 64 * @dev: PWM device to update 65 * @channel: PWM channel to update 66 * @enable: true to enable, false to disable 67 * @return 0 if OK, -ve on error 68 */ 69 int pwm_set_enable(struct udevice *dev, uint channel, bool enable); 70 71 /** 72 * pwm_set_invert() - Set pwm default polarity 73 * 74 * @dev: PWM device to update 75 * @channel: PWM channel to update 76 * @polarity: true to invert, false to keep normal polarity 77 * @return 0 if OK, -ve on error 78 */ 79 int pwm_set_invert(struct udevice *dev, uint channel, bool polarity); 80 81 /* Legacy interface */ 82 #ifndef CONFIG_DM_PWM 83 int pwm_init (int pwm_id, int div, int invert); 84 int pwm_config (int pwm_id, int duty_ns, int period_ns); 85 int pwm_enable (int pwm_id); 86 void pwm_disable (int pwm_id); 87 #endif 88 89 #endif /* _pwm_h_ */ 90