/* SPDX-License-Identifier: GPL-2.0+ */ /* * (C) Copyright 2010 * Stefano Babic, DENX Software Engineering, sbabic@denx.de. * * (C) Copyright 2009 Freescale Semiconductor, Inc. */ #ifndef __FSL_PMIC_H__ #define __FSL_PMIC_H__ /* * The registers of different PMIC has the same meaning * but the bit positions of the fields can differ or * some fields has a meaning only on some devices. * You have to check with the internal SPI bitmap * (see Freescale Documentation) to set the registers * for the device you are using */ enum { REG_INT_STATUS0 = 0, REG_INT_MASK0, REG_INT_SENSE0, REG_INT_STATUS1, REG_INT_MASK1, REG_INT_SENSE1, REG_PU_MODE_S, REG_IDENTIFICATION, REG_UNUSED0, REG_ACC0, REG_ACC1, /*10 */ REG_UNUSED1, REG_UNUSED2, REG_POWER_CTL0, REG_POWER_CTL1, REG_POWER_CTL2, REG_REGEN_ASSIGN, REG_UNUSED3, REG_MEM_A, REG_MEM_B, REG_RTC_TIME, /*20 */ REG_RTC_ALARM, REG_RTC_DAY, REG_RTC_DAY_ALARM, REG_SW_0, REG_SW_1, REG_SW_2, REG_SW_3, REG_SW_4, REG_SW_5, REG_SETTING_0, /*30 */ REG_SETTING_1, REG_MODE_0, REG_MODE_1, REG_POWER_MISC, REG_UNUSED4, REG_UNUSED5, REG_UNUSED6, REG_UNUSED7, REG_UNUSED8, REG_UNUSED9, /*40 */ REG_UNUSED10, REG_UNUSED11, REG_ADC0, REG_ADC1, REG_ADC2, REG_ADC3, REG_ADC4, REG_CHARGE, REG_USB0, REG_USB1, /*50 */ REG_LED_CTL0, REG_LED_CTL1, REG_LED_CTL2, REG_LED_CTL3, REG_UNUSED12, REG_UNUSED13, REG_TRIM0, REG_TRIM1, REG_TEST0, REG_TEST1, /*60 */ REG_TEST2, REG_TEST3, REG_TEST4, PMIC_NUM_OF_REGS, }; /* REG_POWER_MISC */ #define GPO1EN (1 << 6) #define GPO1STBY (1 << 7) #define GPO2EN (1 << 8) #define GPO2STBY (1 << 9) #define GPO3EN (1 << 10) #define GPO3STBY (1 << 11) #define GPO4EN (1 << 12) #define GPO4STBY (1 << 13) #define PWGT1SPIEN (1 << 15) #define PWGT2SPIEN (1 << 16) #define PWUP (1 << 21) /* Power Control 0 */ #define COINCHEN (1 << 23) #define BATTDETEN (1 << 19) /* Interrupt status 1 */ #define RTCRSTI (1 << 7) /* MC34708 Definitions */ #define SWx_VOLT_MASK_MC34708 0x3F #define SWx_1_110V_MC34708 0x24 #define SWx_1_250V_MC34708 0x30 #define SWx_1_300V_MC34708 0x34 #define TIMER_MASK_MC34708 0x300 #define TIMER_4S_MC34708 0x100 #define VUSBSEL_MC34708 (1 << 2) #define VUSBEN_MC34708 (1 << 3) #define SWBST_CTRL 31 #define SWBST_AUTO 0x8 #define MC34708_REG_SW12_OPMODE 28 #define MC34708_SW1AMODE_MASK 0x00000f #define MC34708_SW1AMHMODE 0x000010 #define MC34708_SW1AUOMODE 0x000020 #define MC34708_SW1DVSSPEED 0x0000c0 #define MC34708_SW2MODE_MASK 0x03c000 #define MC34708_SW2MHMODE 0x040000 #define MC34708_SW2UOMODE 0x080000 #define MC34708_SW2DVSSPEED 0x300000 #define MC34708_PLLEN 0x400000 #define MC34708_PLLX 0x800000 #define MC34708_REG_SW345_OPMODE 29 #define MC34708_SW3MODE_MASK 0x00000f #define MC34708_SW3MHMODE 0x000010 #define MC34708_SW3UOMODE 0x000020 #define MC34708_SW4AMODE_MASK 0x0003c0 #define MC34708_SW4AMHMODE 0x000400 #define MC34708_SW4AUOMODE 0x000800 #define MC34708_SW4BMODE_MASK 0x00f000 #define MC34708_SW4BMHMODE 0x010000 #define MC34708_SW4BUOMODE 0x020000 #define MC34708_SW5MODE_MASK 0x3c0000 #define MC34708_SW5MHMODE 0x400000 #define MC34708_SW5UOMODE 0x800000 #define SW_MODE_OFFOFF 0x00 #define SW_MODE_PWMOFF 0x01 #define SW_MODE_PFMOFF 0x03 #define SW_MODE_APSOFF 0x04 #define SW_MODE_PWMPWM 0x05 #define SW_MODE_PWMAPS 0x06 #define SW_MODE_APSAPS 0x08 #define SW_MODE_APSPFM 0x0c #define SW_MODE_PWMPFM 0x0d #define SW_MODE_PFMPFM 0x0f #define MC34708_TRANSFER_SIZE 3 #endif