media: camss: vfe: Rework vfe_hw_version_read() function definition

Expose the VFE version by returning the value read from the HW_VERSION
register.

Secondly, change the name of this function to conform with the CSID
equivalent.

Signed-off-by: Robert Foss <robert.foss@linaro.org>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
This commit is contained in:
Robert Foss 2021-07-26 10:01:13 +02:00 committed by Mauro Carvalho Chehab
parent 5ad5866737
commit d2e8654036
6 changed files with 18 additions and 10 deletions

View File

@ -177,7 +177,7 @@
#define VFE_BUS_WM_FRAME_INC(n) (0x2258 + (n) * 0x100) #define VFE_BUS_WM_FRAME_INC(n) (0x2258 + (n) * 0x100)
#define VFE_BUS_WM_BURST_LIMIT(n) (0x225c + (n) * 0x100) #define VFE_BUS_WM_BURST_LIMIT(n) (0x225c + (n) * 0x100)
static void vfe_hw_version_read(struct vfe_device *vfe) static u32 vfe_hw_version(struct vfe_device *vfe)
{ {
u32 hw_version = readl_relaxed(vfe->base + VFE_HW_VERSION); u32 hw_version = readl_relaxed(vfe->base + VFE_HW_VERSION);
@ -187,6 +187,8 @@ static void vfe_hw_version_read(struct vfe_device *vfe)
dev_dbg(vfe->camss->dev, "VFE HW Version = %u.%u.%u\n", dev_dbg(vfe->camss->dev, "VFE HW Version = %u.%u.%u\n",
gen, rev, step); gen, rev, step);
return hw_version;
} }
static inline void vfe_reg_clr(struct vfe_device *vfe, u32 reg, u32 clr_bits) static inline void vfe_reg_clr(struct vfe_device *vfe, u32 reg, u32 clr_bits)
@ -772,7 +774,7 @@ static void vfe_subdev_init(struct device *dev, struct vfe_device *vfe)
const struct vfe_hw_ops vfe_ops_170 = { const struct vfe_hw_ops vfe_ops_170 = {
.global_reset = vfe_global_reset, .global_reset = vfe_global_reset,
.hw_version_read = vfe_hw_version_read, .hw_version = vfe_hw_version,
.isr_read = vfe_isr_read, .isr_read = vfe_isr_read,
.isr = vfe_isr, .isr = vfe_isr,
.pm_domain_off = vfe_pm_domain_off, .pm_domain_off = vfe_pm_domain_off,

View File

@ -210,11 +210,13 @@
#define MSM_VFE_VFE0_UB_SIZE 1023 #define MSM_VFE_VFE0_UB_SIZE 1023
#define MSM_VFE_VFE0_UB_SIZE_RDI (MSM_VFE_VFE0_UB_SIZE / 3) #define MSM_VFE_VFE0_UB_SIZE_RDI (MSM_VFE_VFE0_UB_SIZE / 3)
static void vfe_hw_version_read(struct vfe_device *vfe) static u32 vfe_hw_version(struct vfe_device *vfe)
{ {
u32 hw_version = readl_relaxed(vfe->base + VFE_0_HW_VERSION); u32 hw_version = readl_relaxed(vfe->base + VFE_0_HW_VERSION);
dev_dbg(vfe->camss->dev, "VFE HW Version = 0x%08x\n", hw_version); dev_dbg(vfe->camss->dev, "VFE HW Version = 0x%08x\n", hw_version);
return hw_version;
} }
static u16 vfe_get_ub_size(u8 vfe_id) static u16 vfe_get_ub_size(u8 vfe_id)
@ -1004,7 +1006,7 @@ static void vfe_subdev_init(struct device *dev, struct vfe_device *vfe)
const struct vfe_hw_ops vfe_ops_4_1 = { const struct vfe_hw_ops vfe_ops_4_1 = {
.global_reset = vfe_global_reset, .global_reset = vfe_global_reset,
.hw_version_read = vfe_hw_version_read, .hw_version = vfe_hw_version,
.isr_read = vfe_isr_read, .isr_read = vfe_isr_read,
.isr = vfe_isr, .isr = vfe_isr,
.pm_domain_off = vfe_pm_domain_off, .pm_domain_off = vfe_pm_domain_off,

View File

@ -254,11 +254,13 @@
#define MSM_VFE_VFE1_UB_SIZE 1535 #define MSM_VFE_VFE1_UB_SIZE 1535
#define MSM_VFE_VFE1_UB_SIZE_RDI (MSM_VFE_VFE1_UB_SIZE / 3) #define MSM_VFE_VFE1_UB_SIZE_RDI (MSM_VFE_VFE1_UB_SIZE / 3)
static void vfe_hw_version_read(struct vfe_device *vfe) static u32 vfe_hw_version(struct vfe_device *vfe)
{ {
u32 hw_version = readl_relaxed(vfe->base + VFE_0_HW_VERSION); u32 hw_version = readl_relaxed(vfe->base + VFE_0_HW_VERSION);
dev_dbg(vfe->camss->dev, "VFE HW Version = 0x%08x\n", hw_version); dev_dbg(vfe->camss->dev, "VFE HW Version = 0x%08x\n", hw_version);
return hw_version;
} }
static u16 vfe_get_ub_size(u8 vfe_id) static u16 vfe_get_ub_size(u8 vfe_id)
@ -1196,7 +1198,7 @@ static void vfe_subdev_init(struct device *dev, struct vfe_device *vfe)
const struct vfe_hw_ops vfe_ops_4_7 = { const struct vfe_hw_ops vfe_ops_4_7 = {
.global_reset = vfe_global_reset, .global_reset = vfe_global_reset,
.hw_version_read = vfe_hw_version_read, .hw_version = vfe_hw_version,
.isr_read = vfe_isr_read, .isr_read = vfe_isr_read,
.isr = vfe_isr, .isr = vfe_isr,
.pm_domain_off = vfe_pm_domain_off, .pm_domain_off = vfe_pm_domain_off,

View File

@ -247,11 +247,13 @@
#define MSM_VFE_VFE1_UB_SIZE 1535 #define MSM_VFE_VFE1_UB_SIZE 1535
#define MSM_VFE_VFE1_UB_SIZE_RDI (MSM_VFE_VFE1_UB_SIZE / 3) #define MSM_VFE_VFE1_UB_SIZE_RDI (MSM_VFE_VFE1_UB_SIZE / 3)
static void vfe_hw_version_read(struct vfe_device *vfe) static u32 vfe_hw_version(struct vfe_device *vfe)
{ {
u32 hw_version = readl_relaxed(vfe->base + VFE_0_HW_VERSION); u32 hw_version = readl_relaxed(vfe->base + VFE_0_HW_VERSION);
dev_dbg(vfe->camss->dev, "VFE HW Version = 0x%08x\n", hw_version); dev_dbg(vfe->camss->dev, "VFE HW Version = 0x%08x\n", hw_version);
return hw_version;
} }
static inline void vfe_reg_clr(struct vfe_device *vfe, u32 reg, u32 clr_bits) static inline void vfe_reg_clr(struct vfe_device *vfe, u32 reg, u32 clr_bits)
@ -1180,7 +1182,7 @@ static void vfe_subdev_init(struct device *dev, struct vfe_device *vfe)
const struct vfe_hw_ops vfe_ops_4_8 = { const struct vfe_hw_ops vfe_ops_4_8 = {
.global_reset = vfe_global_reset, .global_reset = vfe_global_reset,
.hw_version_read = vfe_hw_version_read, .hw_version = vfe_hw_version,
.isr_read = vfe_isr_read, .isr_read = vfe_isr_read,
.isr = vfe_isr, .isr = vfe_isr,
.pm_domain_off = vfe_pm_domain_off, .pm_domain_off = vfe_pm_domain_off,

View File

@ -1299,7 +1299,7 @@ int msm_vfe_subdev_init(struct camss *camss, struct vfe_device *vfe,
return -EINVAL; return -EINVAL;
} }
vfe->ops->subdev_init(dev, vfe); vfe->ops->subdev_init(dev, vfe);
vfe->ops->hw_version_read(vfe); vfe->ops->hw_version(vfe);
/* Memory */ /* Memory */

View File

@ -103,7 +103,7 @@ struct vfe_device;
struct vfe_hw_ops { struct vfe_hw_ops {
void (*enable_irq_common)(struct vfe_device *vfe); void (*enable_irq_common)(struct vfe_device *vfe);
void (*global_reset)(struct vfe_device *vfe); void (*global_reset)(struct vfe_device *vfe);
void (*hw_version_read)(struct vfe_device *vfe); u32 (*hw_version)(struct vfe_device *vfe);
irqreturn_t (*isr)(int irq, void *dev); irqreturn_t (*isr)(int irq, void *dev);
void (*isr_read)(struct vfe_device *vfe, u32 *value0, u32 *value1); void (*isr_read)(struct vfe_device *vfe, u32 *value0, u32 *value1);
void (*pm_domain_off)(struct vfe_device *vfe); void (*pm_domain_off)(struct vfe_device *vfe);