static void _dpu_kms_hw_destroy(struct dpu_kms *dpu_kms)
{
- int i;
-
dpu_kms->hw_intr = NULL;
/* safe to call these more than once during shutdown */
_dpu_kms_mmu_destroy(dpu_kms);
- for (i = 0; i < ARRAY_SIZE(dpu_kms->hw_vbif); i++) {
- dpu_kms->hw_vbif[i] = NULL;
- }
+ dpu_kms->hw_vbif = NULL;
dpu_kms_global_obj_fini(dpu_kms);
struct dpu_hw_vbif *hw;
const struct dpu_vbif_cfg *vbif = dpu_kms->catalog->vbif;
- hw = dpu_hw_vbif_init(dev, vbif, dpu_kms->vbif[vbif->id]);
+ hw = dpu_hw_vbif_init(dev, vbif, dpu_kms->vbif);
if (IS_ERR(hw)) {
rc = PTR_ERR(hw);
DPU_ERROR("failed to init vbif: %d\n", rc);
goto err_pm_put;
}
- dpu_kms->hw_vbif[vbif->id] = hw;
+ dpu_kms->hw_vbif = hw;
/* TODO: use the same max_freq as in dpu_kms_hw_init */
max_core_clk_rate = dpu_kms_get_clk_rate(dpu_kms, "core");
}
DRM_DEBUG("mapped dpu address space @%p\n", dpu_kms->mmio);
- dpu_kms->vbif[VBIF_RT] = msm_ioremap_mdss(mdss_dev,
- dpu_kms->pdev,
- "vbif_phys");
- if (IS_ERR(dpu_kms->vbif[VBIF_RT])) {
- ret = PTR_ERR(dpu_kms->vbif[VBIF_RT]);
+ dpu_kms->vbif = msm_ioremap_mdss(mdss_dev, dpu_kms->pdev, "vbif_phys");
+ if (IS_ERR(dpu_kms->vbif)) {
+ ret = PTR_ERR(dpu_kms->vbif);
DPU_ERROR("vbif register memory map failed: %d\n", ret);
- dpu_kms->vbif[VBIF_RT] = NULL;
+ dpu_kms->vbif = NULL;
return ret;
}
}
DRM_DEBUG("mapped dpu address space @%p\n", dpu_kms->mmio);
- dpu_kms->vbif[VBIF_RT] = msm_ioremap(pdev, "vbif");
- if (IS_ERR(dpu_kms->vbif[VBIF_RT])) {
- ret = PTR_ERR(dpu_kms->vbif[VBIF_RT]);
+ dpu_kms->vbif = msm_ioremap(pdev, "vbif");
+ if (IS_ERR(dpu_kms->vbif)) {
+ ret = PTR_ERR(dpu_kms->vbif);
DPU_ERROR("vbif register memory map failed: %d\n", ret);
- dpu_kms->vbif[VBIF_RT] = NULL;
+ dpu_kms->vbif = NULL;
return ret;
}
#include "dpu_hw_vbif.h"
#include "dpu_trace.h"
-static struct dpu_hw_vbif *dpu_get_vbif(struct dpu_kms *dpu_kms, enum dpu_vbif vbif_idx)
-{
- if (vbif_idx < ARRAY_SIZE(dpu_kms->hw_vbif))
- return dpu_kms->hw_vbif[vbif_idx];
-
- return NULL;
-}
-
static const char *dpu_vbif_name(enum dpu_vbif idx)
{
switch (idx) {
u32 ot_lim;
int ret;
- vbif = dpu_get_vbif(dpu_kms, params->vbif_idx);
+ vbif = dpu_kms->hw_vbif;
if (!vbif) {
DRM_DEBUG_ATOMIC("invalid arguments vbif %d\n", vbif != NULL);
return;
return;
}
- vbif = dpu_get_vbif(dpu_kms, params->vbif_idx);
+ vbif = dpu_kms->hw_vbif;
if (!vbif || !vbif->cap) {
DPU_ERROR("invalid vbif %d\n", params->vbif_idx);
void dpu_vbif_clear_errors(struct dpu_kms *dpu_kms)
{
struct dpu_hw_vbif *vbif;
- u32 i, pnd, src;
-
- for (i = 0; i < ARRAY_SIZE(dpu_kms->hw_vbif); i++) {
- vbif = dpu_kms->hw_vbif[i];
- if (vbif && vbif->ops.clear_errors) {
- vbif->ops.clear_errors(vbif, &pnd, &src);
- if (pnd || src) {
- DRM_DEBUG_KMS("%s: pnd 0x%X, src 0x%X\n",
- dpu_vbif_name(vbif->idx), pnd, src);
- }
+ u32 pnd, src;
+
+ vbif = dpu_kms->hw_vbif;
+ if (vbif && vbif->ops.clear_errors) {
+ vbif->ops.clear_errors(vbif, &pnd, &src);
+ if (pnd || src) {
+ DRM_DEBUG_KMS("%s: pnd 0x%X, src 0x%X\n",
+ dpu_vbif_name(vbif->idx), pnd, src);
}
}
}
void dpu_vbif_init_memtypes(struct dpu_kms *dpu_kms)
{
struct dpu_hw_vbif *vbif;
- int i, j;
-
- for (i = 0; i < ARRAY_SIZE(dpu_kms->hw_vbif); i++) {
- vbif = dpu_kms->hw_vbif[i];
- if (vbif && vbif->cap && vbif->ops.set_mem_type) {
- for (j = 0; j < vbif->cap->memtype_count; j++)
- vbif->ops.set_mem_type(
- vbif, j, vbif->cap->memtype[j]);
- }
+ int j;
+
+ vbif = dpu_kms->hw_vbif;
+ if (vbif && vbif->cap && vbif->ops.set_mem_type) {
+ for (j = 0; j < vbif->cap->memtype_count; j++)
+ vbif->ops.set_mem_type(vbif, j, vbif->cap->memtype[j]);
}
}