2019-06-04 10:11:33 +02:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2014-08-19 19:17:35 +03:00
|
|
|
/*
|
|
|
|
* Intel Low Power Subsystem PWM controller driver
|
|
|
|
*
|
|
|
|
* Copyright (C) 2014, Intel Corporation
|
|
|
|
*
|
|
|
|
* Derived from the original pwm-lpss.c
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __PWM_LPSS_H
|
|
|
|
#define __PWM_LPSS_H
|
|
|
|
|
|
|
|
#include <linux/device.h>
|
|
|
|
#include <linux/pwm.h>
|
|
|
|
|
2018-10-12 12:12:26 +02:00
|
|
|
#define MAX_PWMS 4
|
|
|
|
|
|
|
|
struct pwm_lpss_chip {
|
|
|
|
struct pwm_chip chip;
|
|
|
|
void __iomem *regs;
|
|
|
|
const struct pwm_lpss_boardinfo *info;
|
|
|
|
};
|
2014-08-19 19:17:35 +03:00
|
|
|
|
|
|
|
struct pwm_lpss_boardinfo {
|
|
|
|
unsigned long clk_rate;
|
2015-10-20 16:53:05 +03:00
|
|
|
unsigned int npwm;
|
2015-11-17 17:20:15 +08:00
|
|
|
unsigned long base_unit_bits;
|
2022-09-27 19:24:21 +03:00
|
|
|
/*
|
|
|
|
* Some versions of the IP may stuck in the state machine if enable
|
|
|
|
* bit is not set, and hence update bit will show busy status till
|
|
|
|
* the reset. For the rest it may be otherwise.
|
|
|
|
*/
|
2017-04-06 14:54:01 +03:00
|
|
|
bool bypass;
|
2018-10-14 17:12:01 +02:00
|
|
|
/*
|
|
|
|
* On some devices the _PS0/_PS3 AML code of the GPU (GFX0) device
|
|
|
|
* messes with the PWM0 controllers state,
|
|
|
|
*/
|
|
|
|
bool other_devices_aml_touches_pwm_regs;
|
2014-08-19 19:17:35 +03:00
|
|
|
};
|
|
|
|
|
2022-09-27 19:24:15 +03:00
|
|
|
extern const struct pwm_lpss_boardinfo pwm_lpss_byt_info;
|
|
|
|
extern const struct pwm_lpss_boardinfo pwm_lpss_bsw_info;
|
|
|
|
extern const struct pwm_lpss_boardinfo pwm_lpss_bxt_info;
|
|
|
|
extern const struct pwm_lpss_boardinfo pwm_lpss_tng_info;
|
|
|
|
|
2022-09-27 19:24:17 +03:00
|
|
|
struct pwm_lpss_chip *pwm_lpss_probe(struct device *dev, void __iomem *base,
|
2014-08-19 19:17:35 +03:00
|
|
|
const struct pwm_lpss_boardinfo *info);
|
|
|
|
|
|
|
|
#endif /* __PWM_LPSS_H */
|