Server : Apache/2.4.41 (Ubuntu) System : Linux journalup 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /usr/src/linux-headers-5.4.0-200/include/linux/mfd/ |
/* SPDX-License-Identifier: GPL-2.0-only */ /* * TI/National Semiconductor LP3943 Device * * Copyright 2013 Texas Instruments * * Author: Milo Kim <[email protected]> */ #ifndef __MFD_LP3943_H__ #define __MFD_LP3943_H__ #include <linux/gpio.h> #include <linux/pwm.h> #include <linux/regmap.h> /* Registers */ #define LP3943_REG_GPIO_A 0x00 #define LP3943_REG_GPIO_B 0x01 #define LP3943_REG_PRESCALE0 0x02 #define LP3943_REG_PWM0 0x03 #define LP3943_REG_PRESCALE1 0x04 #define LP3943_REG_PWM1 0x05 #define LP3943_REG_MUX0 0x06 #define LP3943_REG_MUX1 0x07 #define LP3943_REG_MUX2 0x08 #define LP3943_REG_MUX3 0x09 /* Bit description for LP3943_REG_MUX0 ~ 3 */ #define LP3943_GPIO_IN 0x00 #define LP3943_GPIO_OUT_HIGH 0x00 #define LP3943_GPIO_OUT_LOW 0x01 #define LP3943_DIM_PWM0 0x02 #define LP3943_DIM_PWM1 0x03 #define LP3943_NUM_PWMS 2 enum lp3943_pwm_output { LP3943_PWM_OUT0, LP3943_PWM_OUT1, LP3943_PWM_OUT2, LP3943_PWM_OUT3, LP3943_PWM_OUT4, LP3943_PWM_OUT5, LP3943_PWM_OUT6, LP3943_PWM_OUT7, LP3943_PWM_OUT8, LP3943_PWM_OUT9, LP3943_PWM_OUT10, LP3943_PWM_OUT11, LP3943_PWM_OUT12, LP3943_PWM_OUT13, LP3943_PWM_OUT14, LP3943_PWM_OUT15, }; /* * struct lp3943_pwm_map * @output: Output pins which are mapped to each PWM channel * @num_outputs: Number of outputs */ struct lp3943_pwm_map { enum lp3943_pwm_output *output; int num_outputs; }; /* * struct lp3943_platform_data * @pwms: Output channel definitions for PWM channel 0 and 1 */ struct lp3943_platform_data { struct lp3943_pwm_map *pwms[LP3943_NUM_PWMS]; }; /* * struct lp3943_reg_cfg * @reg: Register address * @mask: Register bit mask to be updated * @shift: Register bit shift */ struct lp3943_reg_cfg { u8 reg; u8 mask; u8 shift; }; /* * struct lp3943 * @dev: Parent device pointer * @regmap: Used for I2C communication on accessing registers * @pdata: LP3943 platform specific data * @mux_cfg: Register configuration for pin MUX * @pin_used: Bit mask for output pin used. * This bitmask is used for pin assignment management. * 1 = pin used, 0 = available. * Only LSB 16 bits are used, but it is unsigned long type * for atomic bitwise operations. */ struct lp3943 { struct device *dev; struct regmap *regmap; struct lp3943_platform_data *pdata; const struct lp3943_reg_cfg *mux_cfg; unsigned long pin_used; }; int lp3943_read_byte(struct lp3943 *lp3943, u8 reg, u8 *read); int lp3943_write_byte(struct lp3943 *lp3943, u8 reg, u8 data); int lp3943_update_bits(struct lp3943 *lp3943, u8 reg, u8 mask, u8 data); #endif