Linux Audio

Check our new training course

Linux BSP development engineering services

Need help to port Linux and bootloaders to your hardware?
Loading...
v6.2
  1/* SPDX-License-Identifier: GPL-2.0-or-later */
  2/*
  3 * mc13xxx.h - regulators for the Freescale mc13xxx PMIC
  4 *
  5 *  Copyright (C) 2010 Yong Shen <yong.shen@linaro.org>
 
 
 
 
 
  6 */
  7
  8#ifndef __LINUX_REGULATOR_MC13XXX_H
  9#define __LINUX_REGULATOR_MC13XXX_H
 10
 11#include <linux/regulator/driver.h>
 12
 13struct mc13xxx_regulator {
 14	struct regulator_desc desc;
 15	int reg;
 16	int enable_bit;
 17	int vsel_reg;
 18	int vsel_shift;
 19	int vsel_mask;
 
 
 20};
 21
 22struct mc13xxx_regulator_priv {
 23	struct mc13xxx *mc13xxx;
 24	u32 powermisc_pwgt_state;
 25	struct mc13xxx_regulator *mc13xxx_regulators;
 26	int num_regulators;
 27	struct regulator_dev *regulators[];
 28};
 29
 
 
 
 
 30extern int mc13xxx_fixed_regulator_set_voltage(struct regulator_dev *rdev,
 31		int min_uV, int max_uV, unsigned *selector);
 
 32
 33#ifdef CONFIG_OF
 34extern int mc13xxx_get_num_regulators_dt(struct platform_device *pdev);
 35extern struct mc13xxx_regulator_init_data *mc13xxx_parse_regulators_dt(
 36	struct platform_device *pdev, struct mc13xxx_regulator *regulators,
 37	int num_regulators);
 38#else
 39static inline int mc13xxx_get_num_regulators_dt(struct platform_device *pdev)
 40{
 41	return -ENODEV;
 42}
 43
 44static inline struct mc13xxx_regulator_init_data *mc13xxx_parse_regulators_dt(
 45	struct platform_device *pdev, struct mc13xxx_regulator *regulators,
 46	int num_regulators)
 47{
 48	return NULL;
 49}
 50#endif
 51
 52extern const struct regulator_ops mc13xxx_regulator_ops;
 53extern const struct regulator_ops mc13xxx_fixed_regulator_ops;
 54
 55#define MC13xxx_DEFINE(prefix, _name, _node, _reg, _vsel_reg, _voltages, _ops)	\
 56	[prefix ## _name] = {				\
 57		.desc = {						\
 58			.name = #_node,					\
 59			.n_voltages = ARRAY_SIZE(_voltages),		\
 60			.volt_table =  _voltages,			\
 61			.ops = &_ops,			\
 62			.type = REGULATOR_VOLTAGE,			\
 63			.id = prefix ## _name,		\
 64			.owner = THIS_MODULE,				\
 65		},							\
 66		.reg = prefix ## _reg,				\
 67		.enable_bit = prefix ## _reg ## _ ## _name ## EN,	\
 68		.vsel_reg = prefix ## _vsel_reg,			\
 69		.vsel_shift = prefix ## _vsel_reg ## _ ## _name ## VSEL,\
 70		.vsel_mask = prefix ## _vsel_reg ## _ ## _name ## VSEL_M,\
 
 71	}
 72
 73#define MC13xxx_FIXED_DEFINE(prefix, _name, _node, _reg, _voltages, _ops)	\
 74	[prefix ## _name] = {				\
 75		.desc = {						\
 76			.name = #_node,					\
 77			.n_voltages = ARRAY_SIZE(_voltages),		\
 78			.volt_table =  _voltages,			\
 79			.ops = &_ops,		\
 80			.type = REGULATOR_VOLTAGE,			\
 81			.id = prefix ## _name,		\
 82			.owner = THIS_MODULE,				\
 83		},							\
 84		.reg = prefix ## _reg,				\
 85		.enable_bit = prefix ## _reg ## _ ## _name ## EN,	\
 
 86	}
 87
 88#define MC13xxx_GPO_DEFINE(prefix, _name, _node, _reg,  _voltages, _ops)	\
 89	[prefix ## _name] = {				\
 90		.desc = {						\
 91			.name = #_node,					\
 92			.n_voltages = ARRAY_SIZE(_voltages),		\
 93			.volt_table =  _voltages,			\
 94			.ops = &_ops,		\
 95			.type = REGULATOR_VOLTAGE,			\
 96			.id = prefix ## _name,		\
 97			.owner = THIS_MODULE,				\
 98		},							\
 99		.reg = prefix ## _reg,				\
100		.enable_bit = prefix ## _reg ## _ ## _name ## EN,	\
 
101	}
102
103#define MC13xxx_DEFINE_SW(_name, _node, _reg, _vsel_reg, _voltages, ops) \
104	MC13xxx_DEFINE(SW, _name, _node, _reg, _vsel_reg, _voltages, ops)
105#define MC13xxx_DEFINE_REGU(_name, _node, _reg, _vsel_reg, _voltages, ops) \
106	MC13xxx_DEFINE(REGU, _name, _node, _reg, _vsel_reg, _voltages, ops)
107
108#endif
v3.5.6
 
  1/*
  2 * mc13xxx.h - regulators for the Freescale mc13xxx PMIC
  3 *
  4 *  Copyright (C) 2010 Yong Shen <yong.shen@linaro.org>
  5 *
  6 * This program is free software; you can redistribute it and/or modify
  7 * it under the terms of the GNU General Public License as published by
  8 * the Free Software Foundation; either version 2 of the License, or
  9 * (at your option) any later version.
 10 */
 11
 12#ifndef __LINUX_REGULATOR_MC13XXX_H
 13#define __LINUX_REGULATOR_MC13XXX_H
 14
 15#include <linux/regulator/driver.h>
 16
 17struct mc13xxx_regulator {
 18	struct regulator_desc desc;
 19	int reg;
 20	int enable_bit;
 21	int vsel_reg;
 22	int vsel_shift;
 23	int vsel_mask;
 24	int hi_bit;
 25	int const *voltages;
 26};
 27
 28struct mc13xxx_regulator_priv {
 29	struct mc13xxx *mc13xxx;
 30	u32 powermisc_pwgt_state;
 31	struct mc13xxx_regulator *mc13xxx_regulators;
 32	int num_regulators;
 33	struct regulator_dev *regulators[];
 34};
 35
 36extern int mc13xxx_sw_regulator(struct regulator_dev *rdev);
 37extern int mc13xxx_sw_regulator_is_enabled(struct regulator_dev *rdev);
 38extern int mc13xxx_regulator_list_voltage(struct regulator_dev *rdev,
 39						unsigned selector);
 40extern int mc13xxx_fixed_regulator_set_voltage(struct regulator_dev *rdev,
 41		int min_uV, int max_uV, unsigned *selector);
 42extern int mc13xxx_fixed_regulator_get_voltage(struct regulator_dev *rdev);
 43
 44#ifdef CONFIG_OF
 45extern int mc13xxx_get_num_regulators_dt(struct platform_device *pdev);
 46extern struct mc13xxx_regulator_init_data *mc13xxx_parse_regulators_dt(
 47	struct platform_device *pdev, struct mc13xxx_regulator *regulators,
 48	int num_regulators);
 49#else
 50static inline int mc13xxx_get_num_regulators_dt(struct platform_device *pdev)
 51{
 52	return -ENODEV;
 53}
 54
 55static inline struct mc13xxx_regulator_init_data *mc13xxx_parse_regulators_dt(
 56	struct platform_device *pdev, struct mc13xxx_regulator *regulators,
 57	int num_regulators)
 58{
 59	return NULL;
 60}
 61#endif
 62
 63extern struct regulator_ops mc13xxx_regulator_ops;
 64extern struct regulator_ops mc13xxx_fixed_regulator_ops;
 65
 66#define MC13xxx_DEFINE(prefix, _name, _reg, _vsel_reg, _voltages, _ops)	\
 67	[prefix ## _name] = {				\
 68		.desc = {						\
 69			.name = #_name,					\
 70			.n_voltages = ARRAY_SIZE(_voltages),		\
 
 71			.ops = &_ops,			\
 72			.type = REGULATOR_VOLTAGE,			\
 73			.id = prefix ## _name,		\
 74			.owner = THIS_MODULE,				\
 75		},							\
 76		.reg = prefix ## _reg,				\
 77		.enable_bit = prefix ## _reg ## _ ## _name ## EN,	\
 78		.vsel_reg = prefix ## _vsel_reg,			\
 79		.vsel_shift = prefix ## _vsel_reg ## _ ## _name ## VSEL,\
 80		.vsel_mask = prefix ## _vsel_reg ## _ ## _name ## VSEL_M,\
 81		.voltages =  _voltages,					\
 82	}
 83
 84#define MC13xxx_FIXED_DEFINE(prefix, _name, _reg, _voltages, _ops)	\
 85	[prefix ## _name] = {				\
 86		.desc = {						\
 87			.name = #_name,					\
 88			.n_voltages = ARRAY_SIZE(_voltages),		\
 
 89			.ops = &_ops,		\
 90			.type = REGULATOR_VOLTAGE,			\
 91			.id = prefix ## _name,		\
 92			.owner = THIS_MODULE,				\
 93		},							\
 94		.reg = prefix ## _reg,				\
 95		.enable_bit = prefix ## _reg ## _ ## _name ## EN,	\
 96		.voltages =  _voltages,					\
 97	}
 98
 99#define MC13xxx_GPO_DEFINE(prefix, _name, _reg,  _voltages, _ops)	\
100	[prefix ## _name] = {				\
101		.desc = {						\
102			.name = #_name,					\
103			.n_voltages = ARRAY_SIZE(_voltages),		\
 
104			.ops = &_ops,		\
105			.type = REGULATOR_VOLTAGE,			\
106			.id = prefix ## _name,		\
107			.owner = THIS_MODULE,				\
108		},							\
109		.reg = prefix ## _reg,				\
110		.enable_bit = prefix ## _reg ## _ ## _name ## EN,	\
111		.voltages =  _voltages,					\
112	}
113
114#define MC13xxx_DEFINE_SW(_name, _reg, _vsel_reg, _voltages, ops)	\
115	MC13xxx_DEFINE(SW, _name, _reg, _vsel_reg, _voltages, ops)
116#define MC13xxx_DEFINE_REGU(_name, _reg, _vsel_reg, _voltages, ops)	\
117	MC13xxx_DEFINE(REGU, _name, _reg, _vsel_reg, _voltages, ops)
118
119#endif