media: venus: core: Add io base variables for each block
[ Upstream commit b4053a2097ec2f8ea622e817ae5a46a83b23aefe ] New silicon means that the pre-determined offsets we have been using in this driver no longer hold. Existing blocks of registers can exist at different offsets relative to the IO base address. This commit adds a routine to assign the IO base hooks a subsequent commit will convert from absolute to relative addressing. Signed-off-by: Bryan O'Donoghue <bryan.odonoghue@linaro.org> Signed-off-by: Stanimir Varbanov <stanimir.varbanov@linaro.org> Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org> Stable-dep-of: d74e48160980 ("media: venus: hfi_venus: Write to VIDC_CTRL_INIT after unmasking interrupts") Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
6d3745bbc3
commit
4ccdeb68da
@@ -21,6 +21,7 @@
|
|||||||
#include "core.h"
|
#include "core.h"
|
||||||
#include "firmware.h"
|
#include "firmware.h"
|
||||||
#include "pm_helpers.h"
|
#include "pm_helpers.h"
|
||||||
|
#include "hfi_venus_io.h"
|
||||||
|
|
||||||
static void venus_event_notify(struct venus_core *core, u32 event)
|
static void venus_event_notify(struct venus_core *core, u32 event)
|
||||||
{
|
{
|
||||||
@@ -210,6 +211,15 @@ err:
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void venus_assign_register_offsets(struct venus_core *core)
|
||||||
|
{
|
||||||
|
core->vbif_base = core->base + VBIF_BASE;
|
||||||
|
core->cpu_base = core->base + CPU_BASE;
|
||||||
|
core->cpu_cs_base = core->base + CPU_CS_BASE;
|
||||||
|
core->cpu_ic_base = core->base + CPU_IC_BASE;
|
||||||
|
core->wrapper_base = core->base + WRAPPER_BASE;
|
||||||
|
}
|
||||||
|
|
||||||
static int venus_probe(struct platform_device *pdev)
|
static int venus_probe(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
struct device *dev = &pdev->dev;
|
struct device *dev = &pdev->dev;
|
||||||
@@ -276,6 +286,8 @@ static int venus_probe(struct platform_device *pdev)
|
|||||||
if (ret)
|
if (ret)
|
||||||
goto err_core_put;
|
goto err_core_put;
|
||||||
|
|
||||||
|
venus_assign_register_offsets(core);
|
||||||
|
|
||||||
ret = v4l2_device_register(dev, &core->v4l2_dev);
|
ret = v4l2_device_register(dev, &core->v4l2_dev);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err_core_deinit;
|
goto err_core_deinit;
|
||||||
|
@@ -119,6 +119,11 @@ struct venus_caps {
|
|||||||
* struct venus_core - holds core parameters valid for all instances
|
* struct venus_core - holds core parameters valid for all instances
|
||||||
*
|
*
|
||||||
* @base: IO memory base address
|
* @base: IO memory base address
|
||||||
|
* @vbif_base IO memory vbif base address
|
||||||
|
* @cpu_base IO memory cpu base address
|
||||||
|
* @cpu_cs_base IO memory cpu_cs base address
|
||||||
|
* @cpu_ic_base IO memory cpu_ic base address
|
||||||
|
* @wrapper_base IO memory wrapper base address
|
||||||
* @irq: Venus irq
|
* @irq: Venus irq
|
||||||
* @clks: an array of struct clk pointers
|
* @clks: an array of struct clk pointers
|
||||||
* @vcodec0_clks: an array of vcodec0 struct clk pointers
|
* @vcodec0_clks: an array of vcodec0 struct clk pointers
|
||||||
@@ -152,6 +157,11 @@ struct venus_caps {
|
|||||||
*/
|
*/
|
||||||
struct venus_core {
|
struct venus_core {
|
||||||
void __iomem *base;
|
void __iomem *base;
|
||||||
|
void __iomem *vbif_base;
|
||||||
|
void __iomem *cpu_base;
|
||||||
|
void __iomem *cpu_cs_base;
|
||||||
|
void __iomem *cpu_ic_base;
|
||||||
|
void __iomem *wrapper_base;
|
||||||
int irq;
|
int irq;
|
||||||
struct clk *clks[VIDC_CLKS_NUM_MAX];
|
struct clk *clks[VIDC_CLKS_NUM_MAX];
|
||||||
struct clk *vcodec0_clks[VIDC_VCODEC_CLKS_NUM_MAX];
|
struct clk *vcodec0_clks[VIDC_VCODEC_CLKS_NUM_MAX];
|
||||||
|
Reference in New Issue
Block a user