blob: 4326baaa42a809744189eea51d09ffb8f6783b18 [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0-or-later */
/* Copyright (C) 2020 Gateworks Corporation */
#ifndef MP5416_H_
#define MP5416_H_
#define MP6416_REGULATOR_DRIVER "mp5416_regulator"
enum {
MP5416_CTL0 = 0x00,
MP5416_CTL1 = 0x01,
MP5416_CTL2 = 0x02,
MP5416_ILIMIT = 0x03,
MP5416_VSET_SW1 = 0x04,
MP5416_VSET_SW2 = 0x05,
MP5416_VSET_SW3 = 0x06,
MP5416_VSET_SW4 = 0x07,
MP5416_VSET_LDO2 = 0x08,
MP5416_VSET_LDO3 = 0x09,
MP5416_VSET_LDO4 = 0x0a,
MP5416_VSET_LDO5 = 0x0b,
MP5416_STATUS1 = 0x0d,
MP5416_STATUS2 = 0x0e,
MP5416_STATUS3 = 0x0f,
MP5416_ID2 = 0x11,
MP5416_NUM_OF_REGS = 0x12,
};
#define MP5416_VSET_EN BIT(7)
#define MP5416_VSET_SW1_GVAL(x) ((((x) & 0x7f) * 12500) + 600000)
#define MP5416_VSET_SW2_GVAL(x) ((((x) & 0x7f) * 25000) + 800000)
#define MP5416_VSET_SW3_GVAL(x) ((((x) & 0x7f) * 12500) + 600000)
#define MP5416_VSET_SW4_GVAL(x) ((((x) & 0x7f) * 25000) + 800000)
#define MP5416_VSET_LDO_GVAL(x) ((((x) & 0x7f) * 25000) + 800000)
#define MP5416_VSET_LDO_SVAL(x) (((x) - 800000) / 25000)
#define MP5416_VSET_SW1_SVAL(x) (((x) - 600000) / 12500)
#define MP5416_VSET_SW2_SVAL(x) (((x) - 800000) / 25000)
#define MP5416_VSET_SW3_SVAL(x) (((x) - 600000) / 12500)
#define MP5416_VSET_SW4_SVAL(x) (((x) - 800000) / 25000)
#endif