OMAP3+ VP: replace transaction done check/clear with VP ops
authorKevin Hilman <khilman@ti.com>
Mon, 28 Mar 2011 18:57:18 +0000 (11:57 -0700)
committerKevin Hilman <khilman@ti.com>
Thu, 15 Sep 2011 19:02:07 +0000 (12:02 -0700)
Replace the VP tranxdone check/clear with helper functions from the
PRM layer.

In the process, remove prm_irqst_* voltage structure fields for IRQ
status checking which are no longer needed.

Since these reads/writes of the IRQ status bits were the only PRM
accesses that were not to VC/VP registers, this allows the rest of the
register accesses in the VC/VP code to use VC/VP specific register
access functions (done in the following patch.)

Signed-off-by: Kevin Hilman <khilman@ti.com>
arch/arm/mach-omap2/voltage.h
arch/arm/mach-omap2/voltagedomains3xxx_data.c
arch/arm/mach-omap2/voltagedomains44xx_data.c
arch/arm/mach-omap2/vp.c

index 5ca30fca114d1ca0da66bfa9b87af771098f7f41..04e06266dbd74d791174b8fc5f267efc073b382b 100644 (file)
@@ -133,7 +133,6 @@ struct omap_volt_pmic_info {
  * @vfsm                : voltage manager FSM data
  * @debug_dir          : debug directory for this voltage domain.
  * @curr_volt          : current voltage for this vdd.
- * @prm_irqst_mod       : PRM module id used for PRM IRQ status register access
  * @vp_enabled         : flag to keep track of whether vp is enabled or not
  * @volt_scale         : API to scale the voltage of the vdd.
  */
@@ -147,8 +146,6 @@ struct omap_vdd_info {
        u32 curr_volt;
        bool vp_enabled;
 
-       s16 prm_irqst_mod;
-       u8 prm_irqst_reg;
        u32 (*read_reg) (u16 mod, u8 offset);
        void (*write_reg) (u32 val, u16 mod, u8 offset);
        int (*volt_scale) (struct voltagedomain *voltdm,
index 7cb27ec64890d5a45d0466d8c1d9c370309c947f..ad8f05b6a889376d017bb6754f7c6d30b9017021 100644 (file)
@@ -38,8 +38,6 @@ static const struct omap_vfsm_instance_data omap3_vdd1_vfsm_data = {
 };
 
 static struct omap_vdd_info omap3_vdd1_info = {
-       .prm_irqst_mod = OCP_MOD,
-       .prm_irqst_reg = OMAP3_PRM_IRQSTATUS_MPU_OFFSET,
        .vp_data = &omap3_vp1_data,
        .vfsm = &omap3_vdd1_vfsm_data,
 };
@@ -51,8 +49,6 @@ static const struct omap_vfsm_instance_data omap3_vdd2_vfsm_data = {
 };
 
 static struct omap_vdd_info omap3_vdd2_info = {
-       .prm_irqst_mod = OCP_MOD,
-       .prm_irqst_reg = OMAP3_PRM_IRQSTATUS_MPU_OFFSET,
        .vp_data = &omap3_vp2_data,
        .vfsm = &omap3_vdd2_vfsm_data,
 };
index a05d90ab68696e700f745aca711938ab063d5e55..43e1d3817244fd93ec7b7c6db50d738e1a2b5839 100644 (file)
@@ -37,8 +37,6 @@ static const struct omap_vfsm_instance_data omap4_vdd_mpu_vfsm_data = {
 };
 
 static struct omap_vdd_info omap4_vdd_mpu_info = {
-       .prm_irqst_mod = OMAP4430_PRM_OCP_SOCKET_INST,
-       .prm_irqst_reg = OMAP4_PRM_IRQSTATUS_MPU_2_OFFSET,
        .vp_data = &omap4_vp_mpu_data,
        .vfsm = &omap4_vdd_mpu_vfsm_data,
 };
@@ -48,8 +46,6 @@ static const struct omap_vfsm_instance_data omap4_vdd_iva_vfsm_data = {
 };
 
 static struct omap_vdd_info omap4_vdd_iva_info = {
-       .prm_irqst_mod = OMAP4430_PRM_OCP_SOCKET_INST,
-       .prm_irqst_reg = OMAP4_PRM_IRQSTATUS_MPU_OFFSET,
        .vp_data = &omap4_vp_iva_data,
        .vfsm = &omap4_vdd_iva_vfsm_data,
 };
@@ -59,8 +55,6 @@ static const struct omap_vfsm_instance_data omap4_vdd_core_vfsm_data = {
 };
 
 static struct omap_vdd_info omap4_vdd_core_info = {
-       .prm_irqst_mod = OMAP4430_PRM_OCP_SOCKET_INST,
-       .prm_irqst_reg = OMAP4_PRM_IRQSTATUS_MPU_OFFSET,
        .vp_data = &omap4_vp_core_data,
        .vfsm = &omap4_vdd_core_vfsm_data,
 };
index f3503de5d8fd2b1786db216ceff1413336c50032..113c839f6e23da0e07fa7ded603ef4e4061aa1d7 100644 (file)
@@ -111,10 +111,8 @@ int omap_vp_forceupdate_scale(struct voltagedomain *voltdm,
         * is <3us
         */
        while (timeout++ < VP_TRANXDONE_TIMEOUT) {
-               vdd->write_reg(vp->prm_irqst_data->tranxdone_status,
-                              vdd->prm_irqst_mod, vdd->prm_irqst_reg);
-               if (!(vdd->read_reg(vdd->prm_irqst_mod, vdd->prm_irqst_reg) &
-                     vp->prm_irqst_data->tranxdone_status))
+               vp->vp_common->ops->clear_txdone(vp->id);
+               if (!vp->vp_common->ops->check_txdone(vp->id))
                        break;
                udelay(1);
        }
@@ -146,9 +144,7 @@ int omap_vp_forceupdate_scale(struct voltagedomain *voltdm,
         * Depends on SMPSWAITTIMEMIN/MAX and voltage change
         */
        timeout = 0;
-       omap_test_timeout((vdd->read_reg(vdd->prm_irqst_mod,
-                                        vdd->prm_irqst_reg) &
-                          vp->prm_irqst_data->tranxdone_status),
+       omap_test_timeout(vp->vp_common->ops->check_txdone(vp->id),
                          VP_TRANXDONE_TIMEOUT, timeout);
        if (timeout >= VP_TRANXDONE_TIMEOUT)
                pr_err("%s: vdd_%s TRANXDONE timeout exceeded."
@@ -163,10 +159,8 @@ int omap_vp_forceupdate_scale(struct voltagedomain *voltdm,
         */
        timeout = 0;
        while (timeout++ < VP_TRANXDONE_TIMEOUT) {
-               vdd->write_reg(vp->prm_irqst_data->tranxdone_status,
-                              vdd->prm_irqst_mod, vdd->prm_irqst_reg);
-               if (!(vdd->read_reg(vdd->prm_irqst_mod, vdd->prm_irqst_reg) &
-                     vp->prm_irqst_data->tranxdone_status))
+               vp->vp_common->ops->clear_txdone(vp->id);
+               if (!vp->vp_common->ops->check_txdone(vp->id))
                        break;
                udelay(1);
        }