#include <linux/bits.h>
#include <linux/clk.h>
#include <linux/err.h>
#include <linux/fpga/adi-axi-common.h>
#include <linux/io.h>
#include <linux/module.h>
#include <linux/platform_device.h>
#include <linux/pwm.h>
#include <linux/regmap.h>
#include <linux/slab.h>
#define AXI_PWMGEN_REG_ID …
#define AXI_PWMGEN_REG_SCRATCHPAD …
#define AXI_PWMGEN_REG_CORE_MAGIC …
#define AXI_PWMGEN_REG_CONFIG …
#define AXI_PWMGEN_REG_NPWM …
#define AXI_PWMGEN_CHX_PERIOD(ch) …
#define AXI_PWMGEN_CHX_DUTY(ch) …
#define AXI_PWMGEN_CHX_OFFSET(ch) …
#define AXI_PWMGEN_REG_CORE_MAGIC_VAL …
#define AXI_PWMGEN_LOAD_CONFIG …
#define AXI_PWMGEN_REG_CONFIG_RESET …
struct axi_pwmgen_ddata { … };
static const struct regmap_config axi_pwmgen_regmap_config = …;
static int axi_pwmgen_apply(struct pwm_chip *chip, struct pwm_device *pwm,
const struct pwm_state *state)
{ … }
static int axi_pwmgen_get_state(struct pwm_chip *chip, struct pwm_device *pwm,
struct pwm_state *state)
{ … }
static const struct pwm_ops axi_pwmgen_pwm_ops = …;
static int axi_pwmgen_setup(struct regmap *regmap, struct device *dev)
{ … }
static int axi_pwmgen_probe(struct platform_device *pdev)
{ … }
static const struct of_device_id axi_pwmgen_ids[] = …;
MODULE_DEVICE_TABLE(of, axi_pwmgen_ids);
static struct platform_driver axi_pwmgen_driver = …;
module_platform_driver(…) …;
MODULE_LICENSE(…) …;
MODULE_AUTHOR(…) …;
MODULE_AUTHOR(…) …;
MODULE_DESCRIPTION(…) …;