Commit 6a006ee9 authored by Imre Deak's avatar Imre Deak

drm/i915: Move the HSW power well flags to a common bitfield

Save some space by grouping the HSW power well descriptor flags along
with other flags in one bitfield.

This change also lets simplifying the definition of power well
descriptors sharing the same flags in an upcoming patch.
Signed-off-by: default avatarImre Deak <imre.deak@intel.com>
Reviewed-by: default avatarJouni Högander <jouni.hogander@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220414210657.1785773-5-imre.deak@intel.com
parent 92f6d062
...@@ -76,10 +76,10 @@ static const struct i915_power_well_desc hsw_power_wells[] = { ...@@ -76,10 +76,10 @@ static const struct i915_power_well_desc hsw_power_wells[] = {
.name = "display", .name = "display",
.domains = HSW_DISPLAY_POWER_DOMAINS, .domains = HSW_DISPLAY_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_vga = true,
.id = HSW_DISP_PW_GLOBAL, .id = HSW_DISP_PW_GLOBAL,
{ {
.hsw.idx = HSW_PW_CTL_IDX_GLOBAL, .hsw.idx = HSW_PW_CTL_IDX_GLOBAL,
.hsw.has_vga = true,
}, },
}, },
}; };
...@@ -112,11 +112,11 @@ static const struct i915_power_well_desc bdw_power_wells[] = { ...@@ -112,11 +112,11 @@ static const struct i915_power_well_desc bdw_power_wells[] = {
.name = "display", .name = "display",
.domains = BDW_DISPLAY_POWER_DOMAINS, .domains = BDW_DISPLAY_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_vga = true,
.irq_pipe_mask = BIT(PIPE_B) | BIT(PIPE_C),
.id = HSW_DISP_PW_GLOBAL, .id = HSW_DISP_PW_GLOBAL,
{ {
.hsw.idx = HSW_PW_CTL_IDX_GLOBAL, .hsw.idx = HSW_PW_CTL_IDX_GLOBAL,
.hsw.irq_pipe_mask = BIT(PIPE_B) | BIT(PIPE_C),
.hsw.has_vga = true,
}, },
}, },
}; };
...@@ -368,10 +368,10 @@ static const struct i915_power_well_desc skl_power_wells[] = { ...@@ -368,10 +368,10 @@ static const struct i915_power_well_desc skl_power_wells[] = {
.domains = 0, .domains = 0,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.always_on = true, .always_on = true,
.has_fuses = true,
.id = SKL_DISP_PW_1, .id = SKL_DISP_PW_1,
{ {
.hsw.idx = SKL_PW_CTL_IDX_PW_1, .hsw.idx = SKL_PW_CTL_IDX_PW_1,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "MISC IO power well", .name = "MISC IO power well",
...@@ -392,12 +392,12 @@ static const struct i915_power_well_desc skl_power_wells[] = { ...@@ -392,12 +392,12 @@ static const struct i915_power_well_desc skl_power_wells[] = {
.name = "power well 2", .name = "power well 2",
.domains = SKL_DISPLAY_POWERWELL_2_POWER_DOMAINS, .domains = SKL_DISPLAY_POWERWELL_2_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_vga = true,
.irq_pipe_mask = BIT(PIPE_B) | BIT(PIPE_C),
.has_fuses = true,
.id = SKL_DISP_PW_2, .id = SKL_DISP_PW_2,
{ {
.hsw.idx = SKL_PW_CTL_IDX_PW_2, .hsw.idx = SKL_PW_CTL_IDX_PW_2,
.hsw.irq_pipe_mask = BIT(PIPE_B) | BIT(PIPE_C),
.hsw.has_vga = true,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DDI A/E IO power well", .name = "DDI A/E IO power well",
...@@ -484,10 +484,10 @@ static const struct i915_power_well_desc bxt_power_wells[] = { ...@@ -484,10 +484,10 @@ static const struct i915_power_well_desc bxt_power_wells[] = {
.domains = 0, .domains = 0,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.always_on = true, .always_on = true,
.has_fuses = true,
.id = SKL_DISP_PW_1, .id = SKL_DISP_PW_1,
{ {
.hsw.idx = SKL_PW_CTL_IDX_PW_1, .hsw.idx = SKL_PW_CTL_IDX_PW_1,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DC off", .name = "DC off",
...@@ -498,12 +498,12 @@ static const struct i915_power_well_desc bxt_power_wells[] = { ...@@ -498,12 +498,12 @@ static const struct i915_power_well_desc bxt_power_wells[] = {
.name = "power well 2", .name = "power well 2",
.domains = BXT_DISPLAY_POWERWELL_2_POWER_DOMAINS, .domains = BXT_DISPLAY_POWERWELL_2_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_vga = true,
.irq_pipe_mask = BIT(PIPE_B) | BIT(PIPE_C),
.has_fuses = true,
.id = SKL_DISP_PW_2, .id = SKL_DISP_PW_2,
{ {
.hsw.idx = SKL_PW_CTL_IDX_PW_2, .hsw.idx = SKL_PW_CTL_IDX_PW_2,
.hsw.irq_pipe_mask = BIT(PIPE_B) | BIT(PIPE_C),
.hsw.has_vga = true,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "dpio-common-a", .name = "dpio-common-a",
...@@ -594,10 +594,10 @@ static const struct i915_power_well_desc glk_power_wells[] = { ...@@ -594,10 +594,10 @@ static const struct i915_power_well_desc glk_power_wells[] = {
.domains = 0, .domains = 0,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.always_on = true, .always_on = true,
.has_fuses = true,
.id = SKL_DISP_PW_1, .id = SKL_DISP_PW_1,
{ {
.hsw.idx = SKL_PW_CTL_IDX_PW_1, .hsw.idx = SKL_PW_CTL_IDX_PW_1,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DC off", .name = "DC off",
...@@ -608,12 +608,12 @@ static const struct i915_power_well_desc glk_power_wells[] = { ...@@ -608,12 +608,12 @@ static const struct i915_power_well_desc glk_power_wells[] = {
.name = "power well 2", .name = "power well 2",
.domains = GLK_DISPLAY_POWERWELL_2_POWER_DOMAINS, .domains = GLK_DISPLAY_POWERWELL_2_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_vga = true,
.irq_pipe_mask = BIT(PIPE_B) | BIT(PIPE_C),
.has_fuses = true,
.id = SKL_DISP_PW_2, .id = SKL_DISP_PW_2,
{ {
.hsw.idx = SKL_PW_CTL_IDX_PW_2, .hsw.idx = SKL_PW_CTL_IDX_PW_2,
.hsw.irq_pipe_mask = BIT(PIPE_B) | BIT(PIPE_C),
.hsw.has_vga = true,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "dpio-common-a", .name = "dpio-common-a",
...@@ -789,10 +789,10 @@ static const struct i915_power_well_desc icl_power_wells[] = { ...@@ -789,10 +789,10 @@ static const struct i915_power_well_desc icl_power_wells[] = {
.domains = 0, .domains = 0,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.always_on = true, .always_on = true,
.has_fuses = true,
.id = SKL_DISP_PW_1, .id = SKL_DISP_PW_1,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_1, .hsw.idx = ICL_PW_CTL_IDX_PW_1,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DC off", .name = "DC off",
...@@ -803,21 +803,21 @@ static const struct i915_power_well_desc icl_power_wells[] = { ...@@ -803,21 +803,21 @@ static const struct i915_power_well_desc icl_power_wells[] = {
.name = "power well 2", .name = "power well 2",
.domains = ICL_PW_2_POWER_DOMAINS, .domains = ICL_PW_2_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_fuses = true,
.id = SKL_DISP_PW_2, .id = SKL_DISP_PW_2,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_2, .hsw.idx = ICL_PW_CTL_IDX_PW_2,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "power well 3", .name = "power well 3",
.domains = ICL_PW_3_POWER_DOMAINS, .domains = ICL_PW_3_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_vga = true,
.irq_pipe_mask = BIT(PIPE_B),
.has_fuses = true,
.id = ICL_DISP_PW_3, .id = ICL_DISP_PW_3,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_3, .hsw.idx = ICL_PW_CTL_IDX_PW_3,
.hsw.irq_pipe_mask = BIT(PIPE_B),
.hsw.has_vga = true,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DDI A IO", .name = "DDI A IO",
...@@ -887,83 +887,83 @@ static const struct i915_power_well_desc icl_power_wells[] = { ...@@ -887,83 +887,83 @@ static const struct i915_power_well_desc icl_power_wells[] = {
.name = "AUX C TC1", .name = "AUX C TC1",
.domains = ICL_AUX_C_TC1_IO_POWER_DOMAINS, .domains = ICL_AUX_C_TC1_IO_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_AUX_C, .hsw.idx = ICL_PW_CTL_IDX_AUX_C,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "AUX D TC2", .name = "AUX D TC2",
.domains = ICL_AUX_D_TC2_IO_POWER_DOMAINS, .domains = ICL_AUX_D_TC2_IO_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_AUX_D, .hsw.idx = ICL_PW_CTL_IDX_AUX_D,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "AUX E TC3", .name = "AUX E TC3",
.domains = ICL_AUX_E_TC3_IO_POWER_DOMAINS, .domains = ICL_AUX_E_TC3_IO_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_AUX_E, .hsw.idx = ICL_PW_CTL_IDX_AUX_E,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "AUX F TC4", .name = "AUX F TC4",
.domains = ICL_AUX_F_TC4_IO_POWER_DOMAINS, .domains = ICL_AUX_F_TC4_IO_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_AUX_F, .hsw.idx = ICL_PW_CTL_IDX_AUX_F,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "AUX C TBT1", .name = "AUX C TBT1",
.domains = ICL_AUX_C_TBT1_IO_POWER_DOMAINS, .domains = ICL_AUX_C_TBT1_IO_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_AUX_TBT1, .hsw.idx = ICL_PW_CTL_IDX_AUX_TBT1,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "AUX D TBT2", .name = "AUX D TBT2",
.domains = ICL_AUX_D_TBT2_IO_POWER_DOMAINS, .domains = ICL_AUX_D_TBT2_IO_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_AUX_TBT2, .hsw.idx = ICL_PW_CTL_IDX_AUX_TBT2,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "AUX E TBT3", .name = "AUX E TBT3",
.domains = ICL_AUX_E_TBT3_IO_POWER_DOMAINS, .domains = ICL_AUX_E_TBT3_IO_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_AUX_TBT3, .hsw.idx = ICL_PW_CTL_IDX_AUX_TBT3,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "AUX F TBT4", .name = "AUX F TBT4",
.domains = ICL_AUX_F_TBT4_IO_POWER_DOMAINS, .domains = ICL_AUX_F_TBT4_IO_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_AUX_TBT4, .hsw.idx = ICL_PW_CTL_IDX_AUX_TBT4,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "power well 4", .name = "power well 4",
.domains = ICL_PW_4_POWER_DOMAINS, .domains = ICL_PW_4_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.irq_pipe_mask = BIT(PIPE_C),
.has_fuses = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_4, .hsw.idx = ICL_PW_CTL_IDX_PW_4,
.hsw.has_fuses = true,
.hsw.irq_pipe_mask = BIT(PIPE_C),
}, },
}, },
}; };
...@@ -1077,10 +1077,10 @@ static const struct i915_power_well_desc tgl_power_wells[] = { ...@@ -1077,10 +1077,10 @@ static const struct i915_power_well_desc tgl_power_wells[] = {
.domains = 0, .domains = 0,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.always_on = true, .always_on = true,
.has_fuses = true,
.id = SKL_DISP_PW_1, .id = SKL_DISP_PW_1,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_1, .hsw.idx = ICL_PW_CTL_IDX_PW_1,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DC off", .name = "DC off",
...@@ -1091,21 +1091,21 @@ static const struct i915_power_well_desc tgl_power_wells[] = { ...@@ -1091,21 +1091,21 @@ static const struct i915_power_well_desc tgl_power_wells[] = {
.name = "power well 2", .name = "power well 2",
.domains = TGL_PW_2_POWER_DOMAINS, .domains = TGL_PW_2_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_fuses = true,
.id = SKL_DISP_PW_2, .id = SKL_DISP_PW_2,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_2, .hsw.idx = ICL_PW_CTL_IDX_PW_2,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "power well 3", .name = "power well 3",
.domains = TGL_PW_3_POWER_DOMAINS, .domains = TGL_PW_3_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_vga = true,
.irq_pipe_mask = BIT(PIPE_B),
.has_fuses = true,
.id = ICL_DISP_PW_3, .id = ICL_DISP_PW_3,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_3, .hsw.idx = ICL_PW_CTL_IDX_PW_3,
.hsw.irq_pipe_mask = BIT(PIPE_B),
.hsw.has_vga = true,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DDI A IO", .name = "DDI A IO",
...@@ -1212,129 +1212,129 @@ static const struct i915_power_well_desc tgl_power_wells[] = { ...@@ -1212,129 +1212,129 @@ static const struct i915_power_well_desc tgl_power_wells[] = {
.name = "AUX USBC1", .name = "AUX USBC1",
.domains = TGL_AUX_IO_USBC1_POWER_DOMAINS, .domains = TGL_AUX_IO_USBC1_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TC1, .hsw.idx = TGL_PW_CTL_IDX_AUX_TC1,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "AUX USBC2", .name = "AUX USBC2",
.domains = TGL_AUX_IO_USBC2_POWER_DOMAINS, .domains = TGL_AUX_IO_USBC2_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TC2, .hsw.idx = TGL_PW_CTL_IDX_AUX_TC2,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "AUX USBC3", .name = "AUX USBC3",
.domains = TGL_AUX_IO_USBC3_POWER_DOMAINS, .domains = TGL_AUX_IO_USBC3_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TC3, .hsw.idx = TGL_PW_CTL_IDX_AUX_TC3,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "AUX USBC4", .name = "AUX USBC4",
.domains = TGL_AUX_IO_USBC4_POWER_DOMAINS, .domains = TGL_AUX_IO_USBC4_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TC4, .hsw.idx = TGL_PW_CTL_IDX_AUX_TC4,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "AUX USBC5", .name = "AUX USBC5",
.domains = TGL_AUX_IO_USBC5_POWER_DOMAINS, .domains = TGL_AUX_IO_USBC5_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TC5, .hsw.idx = TGL_PW_CTL_IDX_AUX_TC5,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "AUX USBC6", .name = "AUX USBC6",
.domains = TGL_AUX_IO_USBC6_POWER_DOMAINS, .domains = TGL_AUX_IO_USBC6_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TC6, .hsw.idx = TGL_PW_CTL_IDX_AUX_TC6,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "AUX TBT1", .name = "AUX TBT1",
.domains = TGL_AUX_IO_TBT1_POWER_DOMAINS, .domains = TGL_AUX_IO_TBT1_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TBT1, .hsw.idx = TGL_PW_CTL_IDX_AUX_TBT1,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "AUX TBT2", .name = "AUX TBT2",
.domains = TGL_AUX_IO_TBT2_POWER_DOMAINS, .domains = TGL_AUX_IO_TBT2_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TBT2, .hsw.idx = TGL_PW_CTL_IDX_AUX_TBT2,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "AUX TBT3", .name = "AUX TBT3",
.domains = TGL_AUX_IO_TBT3_POWER_DOMAINS, .domains = TGL_AUX_IO_TBT3_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TBT3, .hsw.idx = TGL_PW_CTL_IDX_AUX_TBT3,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "AUX TBT4", .name = "AUX TBT4",
.domains = TGL_AUX_IO_TBT4_POWER_DOMAINS, .domains = TGL_AUX_IO_TBT4_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TBT4, .hsw.idx = TGL_PW_CTL_IDX_AUX_TBT4,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "AUX TBT5", .name = "AUX TBT5",
.domains = TGL_AUX_IO_TBT5_POWER_DOMAINS, .domains = TGL_AUX_IO_TBT5_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TBT5, .hsw.idx = TGL_PW_CTL_IDX_AUX_TBT5,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "AUX TBT6", .name = "AUX TBT6",
.domains = TGL_AUX_IO_TBT6_POWER_DOMAINS, .domains = TGL_AUX_IO_TBT6_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TBT6, .hsw.idx = TGL_PW_CTL_IDX_AUX_TBT6,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "power well 4", .name = "power well 4",
.domains = TGL_PW_4_POWER_DOMAINS, .domains = TGL_PW_4_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_fuses = true,
.irq_pipe_mask = BIT(PIPE_C),
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_4, .hsw.idx = ICL_PW_CTL_IDX_PW_4,
.hsw.has_fuses = true,
.hsw.irq_pipe_mask = BIT(PIPE_C),
} }
}, { }, {
.name = "power well 5", .name = "power well 5",
.domains = TGL_PW_5_POWER_DOMAINS, .domains = TGL_PW_5_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_fuses = true,
.irq_pipe_mask = BIT(PIPE_D),
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_PW_5, .hsw.idx = TGL_PW_CTL_IDX_PW_5,
.hsw.has_fuses = true,
.hsw.irq_pipe_mask = BIT(PIPE_D),
}, },
}, },
}; };
...@@ -1400,10 +1400,10 @@ static const struct i915_power_well_desc rkl_power_wells[] = { ...@@ -1400,10 +1400,10 @@ static const struct i915_power_well_desc rkl_power_wells[] = {
.domains = 0, .domains = 0,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.always_on = true, .always_on = true,
.has_fuses = true,
.id = SKL_DISP_PW_1, .id = SKL_DISP_PW_1,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_1, .hsw.idx = ICL_PW_CTL_IDX_PW_1,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DC off", .name = "DC off",
...@@ -1414,22 +1414,22 @@ static const struct i915_power_well_desc rkl_power_wells[] = { ...@@ -1414,22 +1414,22 @@ static const struct i915_power_well_desc rkl_power_wells[] = {
.name = "power well 3", .name = "power well 3",
.domains = RKL_PW_3_POWER_DOMAINS, .domains = RKL_PW_3_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.irq_pipe_mask = BIT(PIPE_B),
.has_vga = true,
.has_fuses = true,
.id = ICL_DISP_PW_3, .id = ICL_DISP_PW_3,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_3, .hsw.idx = ICL_PW_CTL_IDX_PW_3,
.hsw.irq_pipe_mask = BIT(PIPE_B),
.hsw.has_vga = true,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "power well 4", .name = "power well 4",
.domains = RKL_PW_4_POWER_DOMAINS, .domains = RKL_PW_4_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_fuses = true,
.irq_pipe_mask = BIT(PIPE_C),
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_4, .hsw.idx = ICL_PW_CTL_IDX_PW_4,
.hsw.has_fuses = true,
.hsw.irq_pipe_mask = BIT(PIPE_C),
} }
}, { }, {
.name = "DDI A IO", .name = "DDI A IO",
...@@ -1540,10 +1540,10 @@ static const struct i915_power_well_desc dg1_power_wells[] = { ...@@ -1540,10 +1540,10 @@ static const struct i915_power_well_desc dg1_power_wells[] = {
.domains = 0, .domains = 0,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.always_on = true, .always_on = true,
.has_fuses = true,
.id = SKL_DISP_PW_1, .id = SKL_DISP_PW_1,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_1, .hsw.idx = ICL_PW_CTL_IDX_PW_1,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DC off", .name = "DC off",
...@@ -1554,21 +1554,21 @@ static const struct i915_power_well_desc dg1_power_wells[] = { ...@@ -1554,21 +1554,21 @@ static const struct i915_power_well_desc dg1_power_wells[] = {
.name = "power well 2", .name = "power well 2",
.domains = DG1_PW_2_POWER_DOMAINS, .domains = DG1_PW_2_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_fuses = true,
.id = SKL_DISP_PW_2, .id = SKL_DISP_PW_2,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_2, .hsw.idx = ICL_PW_CTL_IDX_PW_2,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "power well 3", .name = "power well 3",
.domains = DG1_PW_3_POWER_DOMAINS, .domains = DG1_PW_3_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.irq_pipe_mask = BIT(PIPE_B),
.has_vga = true,
.has_fuses = true,
.id = ICL_DISP_PW_3, .id = ICL_DISP_PW_3,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_3, .hsw.idx = ICL_PW_CTL_IDX_PW_3,
.hsw.irq_pipe_mask = BIT(PIPE_B),
.hsw.has_vga = true,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DDI A IO", .name = "DDI A IO",
...@@ -1622,39 +1622,39 @@ static const struct i915_power_well_desc dg1_power_wells[] = { ...@@ -1622,39 +1622,39 @@ static const struct i915_power_well_desc dg1_power_wells[] = {
.name = "AUX USBC1", .name = "AUX USBC1",
.domains = TGL_AUX_IO_USBC1_POWER_DOMAINS, .domains = TGL_AUX_IO_USBC1_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TC1, .hsw.idx = TGL_PW_CTL_IDX_AUX_TC1,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "AUX USBC2", .name = "AUX USBC2",
.domains = TGL_AUX_IO_USBC2_POWER_DOMAINS, .domains = TGL_AUX_IO_USBC2_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = false,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TC2, .hsw.idx = TGL_PW_CTL_IDX_AUX_TC2,
.hsw.is_tc_tbt = false,
}, },
}, { }, {
.name = "power well 4", .name = "power well 4",
.domains = TGL_PW_4_POWER_DOMAINS, .domains = TGL_PW_4_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_fuses = true,
.irq_pipe_mask = BIT(PIPE_C),
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_4, .hsw.idx = ICL_PW_CTL_IDX_PW_4,
.hsw.has_fuses = true,
.hsw.irq_pipe_mask = BIT(PIPE_C),
} }
}, { }, {
.name = "power well 5", .name = "power well 5",
.domains = TGL_PW_5_POWER_DOMAINS, .domains = TGL_PW_5_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_fuses = true,
.irq_pipe_mask = BIT(PIPE_D),
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_PW_5, .hsw.idx = TGL_PW_CTL_IDX_PW_5,
.hsw.has_fuses = true,
.hsw.irq_pipe_mask = BIT(PIPE_D),
}, },
}, },
}; };
...@@ -1784,10 +1784,10 @@ static const struct i915_power_well_desc xelpd_power_wells[] = { ...@@ -1784,10 +1784,10 @@ static const struct i915_power_well_desc xelpd_power_wells[] = {
.domains = 0, .domains = 0,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.always_on = true, .always_on = true,
.has_fuses = true,
.id = SKL_DISP_PW_1, .id = SKL_DISP_PW_1,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_1, .hsw.idx = ICL_PW_CTL_IDX_PW_1,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DC off", .name = "DC off",
...@@ -1798,51 +1798,51 @@ static const struct i915_power_well_desc xelpd_power_wells[] = { ...@@ -1798,51 +1798,51 @@ static const struct i915_power_well_desc xelpd_power_wells[] = {
.name = "power well 2", .name = "power well 2",
.domains = XELPD_PW_2_POWER_DOMAINS, .domains = XELPD_PW_2_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.has_vga = true,
.has_fuses = true,
.id = SKL_DISP_PW_2, .id = SKL_DISP_PW_2,
{ {
.hsw.idx = ICL_PW_CTL_IDX_PW_2, .hsw.idx = ICL_PW_CTL_IDX_PW_2,
.hsw.has_vga = true,
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "power well A", .name = "power well A",
.domains = XELPD_PW_A_POWER_DOMAINS, .domains = XELPD_PW_A_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.irq_pipe_mask = BIT(PIPE_A),
.has_fuses = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = XELPD_PW_CTL_IDX_PW_A, .hsw.idx = XELPD_PW_CTL_IDX_PW_A,
.hsw.irq_pipe_mask = BIT(PIPE_A),
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "power well B", .name = "power well B",
.domains = XELPD_PW_B_POWER_DOMAINS, .domains = XELPD_PW_B_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.irq_pipe_mask = BIT(PIPE_B),
.has_fuses = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = XELPD_PW_CTL_IDX_PW_B, .hsw.idx = XELPD_PW_CTL_IDX_PW_B,
.hsw.irq_pipe_mask = BIT(PIPE_B),
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "power well C", .name = "power well C",
.domains = XELPD_PW_C_POWER_DOMAINS, .domains = XELPD_PW_C_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.irq_pipe_mask = BIT(PIPE_C),
.has_fuses = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = XELPD_PW_CTL_IDX_PW_C, .hsw.idx = XELPD_PW_CTL_IDX_PW_C,
.hsw.irq_pipe_mask = BIT(PIPE_C),
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "power well D", .name = "power well D",
.domains = XELPD_PW_D_POWER_DOMAINS, .domains = XELPD_PW_D_POWER_DOMAINS,
.ops = &hsw_power_well_ops, .ops = &hsw_power_well_ops,
.irq_pipe_mask = BIT(PIPE_D),
.has_fuses = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = XELPD_PW_CTL_IDX_PW_D, .hsw.idx = XELPD_PW_CTL_IDX_PW_D,
.hsw.irq_pipe_mask = BIT(PIPE_D),
.hsw.has_fuses = true,
}, },
}, { }, {
.name = "DDI A IO", .name = "DDI A IO",
...@@ -1997,37 +1997,37 @@ static const struct i915_power_well_desc xelpd_power_wells[] = { ...@@ -1997,37 +1997,37 @@ static const struct i915_power_well_desc xelpd_power_wells[] = {
.name = "AUX TBT1", .name = "AUX TBT1",
.domains = XELPD_AUX_IO_TBT1_POWER_DOMAINS, .domains = XELPD_AUX_IO_TBT1_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TBT1, .hsw.idx = TGL_PW_CTL_IDX_AUX_TBT1,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "AUX TBT2", .name = "AUX TBT2",
.domains = XELPD_AUX_IO_TBT2_POWER_DOMAINS, .domains = XELPD_AUX_IO_TBT2_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TBT2, .hsw.idx = TGL_PW_CTL_IDX_AUX_TBT2,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "AUX TBT3", .name = "AUX TBT3",
.domains = XELPD_AUX_IO_TBT3_POWER_DOMAINS, .domains = XELPD_AUX_IO_TBT3_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TBT3, .hsw.idx = TGL_PW_CTL_IDX_AUX_TBT3,
.hsw.is_tc_tbt = true,
}, },
}, { }, {
.name = "AUX TBT4", .name = "AUX TBT4",
.domains = XELPD_AUX_IO_TBT4_POWER_DOMAINS, .domains = XELPD_AUX_IO_TBT4_POWER_DOMAINS,
.ops = &icl_aux_power_well_ops, .ops = &icl_aux_power_well_ops,
.is_tc_tbt = true,
.id = DISP_PW_ID_NONE, .id = DISP_PW_ID_NONE,
{ {
.hsw.idx = TGL_PW_CTL_IDX_AUX_TBT4, .hsw.idx = TGL_PW_CTL_IDX_AUX_TBT4,
.hsw.is_tc_tbt = true,
}, },
}, },
}; };
......
...@@ -197,7 +197,7 @@ static enum aux_ch icl_aux_pw_to_ch(const struct i915_power_well *power_well) ...@@ -197,7 +197,7 @@ static enum aux_ch icl_aux_pw_to_ch(const struct i915_power_well *power_well)
{ {
int pw_idx = power_well->desc->hsw.idx; int pw_idx = power_well->desc->hsw.idx;
return power_well->desc->hsw.is_tc_tbt ? ICL_TBT_AUX_PW_TO_CH(pw_idx) : return power_well->desc->is_tc_tbt ? ICL_TBT_AUX_PW_TO_CH(pw_idx) :
ICL_AUX_PW_TO_CH(pw_idx); ICL_AUX_PW_TO_CH(pw_idx);
} }
...@@ -326,7 +326,7 @@ static void hsw_power_well_enable(struct drm_i915_private *dev_priv, ...@@ -326,7 +326,7 @@ static void hsw_power_well_enable(struct drm_i915_private *dev_priv,
int pw_idx = power_well->desc->hsw.idx; int pw_idx = power_well->desc->hsw.idx;
u32 val; u32 val;
if (power_well->desc->hsw.has_fuses) { if (power_well->desc->has_fuses) {
enum skl_power_gate pg; enum skl_power_gate pg;
pg = DISPLAY_VER(dev_priv) >= 11 ? ICL_PW_CTL_IDX_TO_PG(pw_idx) : pg = DISPLAY_VER(dev_priv) >= 11 ? ICL_PW_CTL_IDX_TO_PG(pw_idx) :
...@@ -353,7 +353,7 @@ static void hsw_power_well_enable(struct drm_i915_private *dev_priv, ...@@ -353,7 +353,7 @@ static void hsw_power_well_enable(struct drm_i915_private *dev_priv,
hsw_wait_for_power_well_enable(dev_priv, power_well, false); hsw_wait_for_power_well_enable(dev_priv, power_well, false);
if (power_well->desc->hsw.has_fuses) { if (power_well->desc->has_fuses) {
enum skl_power_gate pg; enum skl_power_gate pg;
pg = DISPLAY_VER(dev_priv) >= 11 ? ICL_PW_CTL_IDX_TO_PG(pw_idx) : pg = DISPLAY_VER(dev_priv) >= 11 ? ICL_PW_CTL_IDX_TO_PG(pw_idx) :
...@@ -362,8 +362,8 @@ static void hsw_power_well_enable(struct drm_i915_private *dev_priv, ...@@ -362,8 +362,8 @@ static void hsw_power_well_enable(struct drm_i915_private *dev_priv,
} }
hsw_power_well_post_enable(dev_priv, hsw_power_well_post_enable(dev_priv,
power_well->desc->hsw.irq_pipe_mask, power_well->desc->irq_pipe_mask,
power_well->desc->hsw.has_vga); power_well->desc->has_vga);
} }
static void hsw_power_well_disable(struct drm_i915_private *dev_priv, static void hsw_power_well_disable(struct drm_i915_private *dev_priv,
...@@ -374,7 +374,7 @@ static void hsw_power_well_disable(struct drm_i915_private *dev_priv, ...@@ -374,7 +374,7 @@ static void hsw_power_well_disable(struct drm_i915_private *dev_priv,
u32 val; u32 val;
hsw_power_well_pre_disable(dev_priv, hsw_power_well_pre_disable(dev_priv,
power_well->desc->hsw.irq_pipe_mask); power_well->desc->irq_pipe_mask);
val = intel_de_read(dev_priv, regs->driver); val = intel_de_read(dev_priv, regs->driver);
intel_de_write(dev_priv, regs->driver, intel_de_write(dev_priv, regs->driver,
...@@ -491,7 +491,7 @@ icl_tc_phy_aux_power_well_enable(struct drm_i915_private *dev_priv, ...@@ -491,7 +491,7 @@ icl_tc_phy_aux_power_well_enable(struct drm_i915_private *dev_priv,
enum aux_ch aux_ch = icl_aux_pw_to_ch(power_well); enum aux_ch aux_ch = icl_aux_pw_to_ch(power_well);
struct intel_digital_port *dig_port = aux_ch_to_digital_port(dev_priv, aux_ch); struct intel_digital_port *dig_port = aux_ch_to_digital_port(dev_priv, aux_ch);
const struct i915_power_well_regs *regs = power_well->desc->ops->regs; const struct i915_power_well_regs *regs = power_well->desc->ops->regs;
bool is_tbt = power_well->desc->hsw.is_tc_tbt; bool is_tbt = power_well->desc->is_tc_tbt;
bool timeout_expected; bool timeout_expected;
u32 val; u32 val;
......
...@@ -51,13 +51,24 @@ enum i915_power_well_id { ...@@ -51,13 +51,24 @@ enum i915_power_well_id {
struct i915_power_well_desc { struct i915_power_well_desc {
const char *name; const char *name;
u64 domains; u64 domains;
u8 always_on:1; /* Mask of pipes whose IRQ logic is backed by the pw */
u16 irq_pipe_mask:4;
u16 always_on:1;
/* /*
* Instead of waiting for the status bit to ack enables, * Instead of waiting for the status bit to ack enables,
* just wait a specific amount of time and then consider * just wait a specific amount of time and then consider
* the well enabled. * the well enabled.
*/ */
u8 fixed_enable_delay:1; u16 fixed_enable_delay:1;
/* The pw is backing the VGA functionality */
u16 has_vga:1;
u16 has_fuses:1;
/*
* The pw is for an ICL+ TypeC PHY port in
* Thunderbolt mode.
*/
u16 is_tc_tbt:1;
/* unique identifier for this power well */ /* unique identifier for this power well */
enum i915_power_well_id id; enum i915_power_well_id id;
/* /*
...@@ -81,16 +92,6 @@ struct i915_power_well_desc { ...@@ -81,16 +92,6 @@ struct i915_power_well_desc {
* constrol/status registers. * constrol/status registers.
*/ */
u8 idx; u8 idx;
/* Mask of pipes whose IRQ logic is backed by the pw */
u8 irq_pipe_mask;
/* The pw is backing the VGA functionality */
bool has_vga:1;
bool has_fuses:1;
/*
* The pw is for an ICL+ TypeC PHY port in
* Thunderbolt mode.
*/
bool is_tc_tbt:1;
} hsw; } hsw;
}; };
const struct i915_power_well_ops *ops; const struct i915_power_well_ops *ops;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment