WIP FPC-III support
[linux/fpc-iii.git] / drivers / pwm / pwm-lpss.h
blob70db7e389d66b15b15a83bdbcc3c124b2ca1d9a8
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3 * Intel Low Power Subsystem PWM controller driver
5 * Copyright (C) 2014, Intel Corporation
7 * Derived from the original pwm-lpss.c
8 */
10 #ifndef __PWM_LPSS_H
11 #define __PWM_LPSS_H
13 #include <linux/device.h>
14 #include <linux/pwm.h>
16 #define MAX_PWMS 4
18 struct pwm_lpss_chip {
19 struct pwm_chip chip;
20 void __iomem *regs;
21 const struct pwm_lpss_boardinfo *info;
24 struct pwm_lpss_boardinfo {
25 unsigned long clk_rate;
26 unsigned int npwm;
27 unsigned long base_unit_bits;
28 bool bypass;
30 * On some devices the _PS0/_PS3 AML code of the GPU (GFX0) device
31 * messes with the PWM0 controllers state,
33 bool other_devices_aml_touches_pwm_regs;
36 struct pwm_lpss_chip *pwm_lpss_probe(struct device *dev, struct resource *r,
37 const struct pwm_lpss_boardinfo *info);
38 int pwm_lpss_remove(struct pwm_lpss_chip *lpwm);
40 #endif /* __PWM_LPSS_H */