Logo Search packages:      
Sourcecode: linux version File versions  Download package

mx51_babbage_pmic_mc13892.c

/*
 * mx51-3stack-pmic-mc13892.c  --  i.MX51 3STACK Driver for Atlas MC13892 PMIC
 */
 /*
  * Copyright 2009 Freescale Semiconductor, Inc. All Rights Reserved.
  */

 /*
  * The code contained herein is licensed under the GNU General Public
  * License. You may obtain a copy of the GNU General Public License
  * Version 2 or later at the following locations:
  *
  * http://www.opensource.org/licenses/gpl-license.html
  * http://www.gnu.org/copyleft/gpl.html
  */

#include <linux/module.h>
#include <linux/init.h>
#include <linux/platform_device.h>
#include <linux/spi/spi.h>
#include <linux/err.h>
#include <linux/pmic_external.h>
#include <linux/regulator/machine.h>
#include <linux/mfd/mc13892/core.h>
#include "iomux.h"

/*
 * Convenience conversion.
 * Here atm, maybe there is somewhere better for this.
 */
#define mV_to_uV(mV) (mV * 1000)
#define uV_to_mV(uV) (uV / 1000)
#define V_to_uV(V) (mV_to_uV(V * 1000))
#define uV_to_V(uV) (uV_to_mV(uV) / 1000)

/* CPU */
static struct regulator_consumer_supply sw1_consumers[] = {
      {
            .supply = "cpu_vcc",
      }
};

struct mc13892;

static struct regulator_init_data sw1_init = {
      .constraints = {
            .name = "SW1",
            .min_uV = mV_to_uV(600),
            .max_uV = mV_to_uV(1375),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
            .valid_modes_mask = 0,
            .always_on = 1,
            .boot_on = 1,
            .initial_state = PM_SUSPEND_MEM,
            .state_mem = {
                  .uV = 700000,
                  .mode = REGULATOR_MODE_NORMAL,
                  .enabled = 1,
            },
      },
      .num_consumer_supplies = ARRAY_SIZE(sw1_consumers),
      .consumer_supplies = sw1_consumers,
};

static struct regulator_init_data sw2_init = {
      .constraints = {
            .name = "SW2",
            .min_uV = mV_to_uV(900),
            .max_uV = mV_to_uV(1850),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
            .always_on = 1,
            .boot_on = 1,
            .initial_state = PM_SUSPEND_MEM,
            .state_mem = {
                  .uV = 900000,
                  .mode = REGULATOR_MODE_NORMAL,
                  .enabled = 1,
            },
      }
};

static struct regulator_init_data sw3_init = {
      .constraints = {
            .name = "SW3",
            .min_uV = mV_to_uV(1100),
            .max_uV = mV_to_uV(1850),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
            .always_on = 1,
            .boot_on = 1,
      }
};

static struct regulator_init_data sw4_init = {
      .constraints = {
            .name = "SW4",
            .min_uV = mV_to_uV(1100),
            .max_uV = mV_to_uV(1850),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
            .always_on = 1,
            .boot_on = 1,
      }
};

static struct regulator_init_data viohi_init = {
      .constraints = {
            .name = "VIOHI",
            .boot_on = 1,
      }
};

static struct regulator_init_data vusb_init = {
      .constraints = {
            .name = "VUSB",
            .boot_on = 1,
      }
};

static struct regulator_init_data swbst_init = {
      .constraints = {
            .name = "SWBST",
      }
};

static struct regulator_init_data vdig_init = {
      .constraints = {
            .name = "VDIG",
            .min_uV = mV_to_uV(1050),
            .max_uV = mV_to_uV(1800),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
            .boot_on = 1,
      }
};

static struct regulator_init_data vpll_init = {
      .constraints = {
            .name = "VPLL",
            .min_uV = mV_to_uV(1050),
            .max_uV = mV_to_uV(1800),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
            .boot_on = 1,
      }
};

static struct regulator_init_data vusb2_init = {
      .constraints = {
            .name = "VUSB2",
            .min_uV = mV_to_uV(2400),
            .max_uV = mV_to_uV(2775),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
            .boot_on = 1,
      }
};

static struct regulator_init_data vvideo_init = {
      .constraints = {
            .name = "VVIDEO",
            .min_uV = mV_to_uV(2775),
            .max_uV = mV_to_uV(2775),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
            .always_on = 1,
            .apply_uV =1,
      }
};

static struct regulator_init_data vaudio_init = {
      .constraints = {
            .name = "VAUDIO",
            .min_uV = mV_to_uV(2300),
            .max_uV = mV_to_uV(3000),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
      }
};

static struct regulator_init_data vsd_init = {
      .constraints = {
            .name = "VSD",
            .min_uV = mV_to_uV(1800),
            .max_uV = mV_to_uV(3150),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
      }
};

static struct regulator_init_data vcam_init = {
      .constraints = {
            .name = "VCAM",
            .min_uV = mV_to_uV(2500),
            .max_uV = mV_to_uV(3000),
            .valid_ops_mask =
                  REGULATOR_CHANGE_VOLTAGE | REGULATOR_CHANGE_MODE,
            .valid_modes_mask = REGULATOR_MODE_FAST | REGULATOR_MODE_NORMAL,
      }
};

static struct regulator_init_data vgen1_init = {
      .constraints = {
            .name = "VGEN1",
            .min_uV = mV_to_uV(1200),
            .max_uV = mV_to_uV(3150),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
      }
};

static struct regulator_init_data vgen2_init = {
      .constraints = {
            .name = "VGEN2",
            .min_uV = mV_to_uV(1200),
            .max_uV = mV_to_uV(3150),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
      }
};

static struct regulator_init_data vgen3_init = {
      .constraints = {
            .name = "VGEN3",
            .min_uV = mV_to_uV(1800),
            .max_uV = mV_to_uV(2900),
            .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
      }
};

static int mc13892_regulator_init(struct mc13892 *mc13892)
{
      if (mxc_cpu_is_rev(CHIP_REV_2_0) < 0)
            sw2_init.constraints.state_mem.uV = 1100000;

      mc13892_register_regulator(mc13892, MC13892_SW1, &sw1_init);
      mc13892_register_regulator(mc13892, MC13892_SW2, &sw2_init);
      mc13892_register_regulator(mc13892, MC13892_SW3, &sw3_init);
      mc13892_register_regulator(mc13892, MC13892_SW4, &sw4_init);
      mc13892_register_regulator(mc13892, MC13892_SWBST, &swbst_init);
      mc13892_register_regulator(mc13892, MC13892_VIOHI, &viohi_init);
      mc13892_register_regulator(mc13892, MC13892_VPLL, &vpll_init);
      mc13892_register_regulator(mc13892, MC13892_VDIG, &vdig_init);
      mc13892_register_regulator(mc13892, MC13892_VSD, &vsd_init);
      mc13892_register_regulator(mc13892, MC13892_VUSB2, &vusb2_init);
      mc13892_register_regulator(mc13892, MC13892_VVIDEO, &vvideo_init);
      mc13892_register_regulator(mc13892, MC13892_VAUDIO, &vaudio_init);
      mc13892_register_regulator(mc13892, MC13892_VCAM, &vcam_init);
      mc13892_register_regulator(mc13892, MC13892_VGEN1, &vgen1_init);
      mc13892_register_regulator(mc13892, MC13892_VGEN2, &vgen2_init);
      mc13892_register_regulator(mc13892, MC13892_VGEN3, &vgen3_init);
      mc13892_register_regulator(mc13892, MC13892_VUSB, &vusb_init);

      return 0;
}

static struct mc13892_platform_data mc13892_plat = {
      .init = mc13892_regulator_init,
};

static struct spi_board_info __initdata mc13892_spi_device = {
      .modalias = "pmic_spi",
      .irq = IOMUX_TO_IRQ(MX51_PIN_GPIO1_8),
      .max_speed_hz = 1000000,      /* max spi SCK clock speed in HZ */
      .bus_num = 1,
      .chip_select = 0,
      .platform_data = &mc13892_plat,
};


int __init mx51_babbage_init_mc13892(void)
{
      return spi_register_board_info(&mc13892_spi_device, 1);
}


Generated by  Doxygen 1.6.0   Back to index