media: ti-vpe: cal: Group CAMERARX-related functions together
Group the CAMERARX functions together to make the overall driver structure easier to navigate. This only moves functions around, no functional change is included. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Tomi Valkeinen <tomi.valkeinen@ti.com> Reviewed-by: Benoit Parrot <bparrot@ti.com> Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
This commit is contained in:
parent
f7cd15eb0b
commit
825800dc22
@ -468,9 +468,30 @@ static inline void set_field(u32 *valp, u32 field, u32 mask)
|
||||
*valp = val;
|
||||
}
|
||||
|
||||
static u32 cal_camerarx_max_lanes(struct cal_camerarx *phy)
|
||||
static void cal_quickdump_regs(struct cal_dev *cal)
|
||||
{
|
||||
return phy->cal->data->camerarx[phy->instance].num_lanes;
|
||||
cal_info(cal, "CAL Registers @ 0x%pa:\n", &cal->res->start);
|
||||
print_hex_dump(KERN_INFO, "", DUMP_PREFIX_OFFSET, 16, 4,
|
||||
(__force const void *)cal->base,
|
||||
resource_size(cal->res), false);
|
||||
|
||||
if (cal->ctx[0]) {
|
||||
cal_info(cal, "CSI2 Core 0 Registers @ %pa:\n",
|
||||
&cal->ctx[0]->phy->res->start);
|
||||
print_hex_dump(KERN_INFO, "", DUMP_PREFIX_OFFSET, 16, 4,
|
||||
(__force const void *)cal->ctx[0]->phy->base,
|
||||
resource_size(cal->ctx[0]->phy->res),
|
||||
false);
|
||||
}
|
||||
|
||||
if (cal->ctx[1]) {
|
||||
cal_info(cal, "CSI2 Core 1 Registers @ %pa:\n",
|
||||
&cal->ctx[1]->phy->res->start);
|
||||
print_hex_dump(KERN_INFO, "", DUMP_PREFIX_OFFSET, 16, 4,
|
||||
(__force const void *)cal->ctx[1]->phy->base,
|
||||
resource_size(cal->ctx[1]->phy->res),
|
||||
false);
|
||||
}
|
||||
}
|
||||
|
||||
static u32 cal_data_get_num_csi2_phy(struct cal_dev *cal)
|
||||
@ -478,74 +499,16 @@ static u32 cal_data_get_num_csi2_phy(struct cal_dev *cal)
|
||||
return cal->data->num_csi2_phy;
|
||||
}
|
||||
|
||||
static int cal_camerarx_regmap_init(struct cal_dev *cal,
|
||||
struct cal_camerarx *phy)
|
||||
{
|
||||
const struct cal_camerarx_data *phy_data;
|
||||
unsigned int i;
|
||||
|
||||
if (!cal->data)
|
||||
return -EINVAL;
|
||||
|
||||
phy_data = &cal->data->camerarx[phy->instance];
|
||||
|
||||
for (i = 0; i < F_MAX_FIELDS; i++) {
|
||||
struct reg_field field = {
|
||||
.reg = cal->syscon_camerrx_offset,
|
||||
.lsb = phy_data->fields[i].lsb,
|
||||
.msb = phy_data->fields[i].msb,
|
||||
};
|
||||
|
||||
/*
|
||||
* Here we update the reg offset with the
|
||||
* value found in DT
|
||||
*/
|
||||
phy->fields[i] = devm_regmap_field_alloc(&cal->pdev->dev,
|
||||
cal->syscon_camerrx,
|
||||
field);
|
||||
if (IS_ERR(phy->fields[i])) {
|
||||
cal_err(cal, "Unable to allocate regmap fields\n");
|
||||
return PTR_ERR(phy->fields[i]);
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct regmap *cal_get_camerarx_regmap(struct cal_dev *cal)
|
||||
{
|
||||
struct platform_device *pdev = cal->pdev;
|
||||
struct regmap_config config = { };
|
||||
struct regmap *regmap;
|
||||
void __iomem *base;
|
||||
struct resource *res;
|
||||
|
||||
res = platform_get_resource_byname(pdev, IORESOURCE_MEM,
|
||||
"camerrx_control");
|
||||
base = devm_ioremap_resource(&pdev->dev, res);
|
||||
if (IS_ERR(base)) {
|
||||
cal_err(cal, "failed to ioremap\n");
|
||||
return ERR_CAST(base);
|
||||
}
|
||||
|
||||
cal_dbg(1, cal, "ioresource %s at %pa - %pa\n",
|
||||
res->name, &res->start, &res->end);
|
||||
|
||||
config.reg_bits = 32;
|
||||
config.reg_stride = 4;
|
||||
config.val_bits = 32;
|
||||
config.max_register = resource_size(res) - 4;
|
||||
|
||||
regmap = regmap_init_mmio(NULL, base, &config);
|
||||
if (IS_ERR(regmap))
|
||||
pr_err("regmap init failed\n");
|
||||
|
||||
return regmap;
|
||||
}
|
||||
|
||||
/*
|
||||
* Control Module CAMERARX block access
|
||||
/* ------------------------------------------------------------------
|
||||
* CAMERARX Management
|
||||
* ------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
static u32 cal_camerarx_max_lanes(struct cal_camerarx *phy)
|
||||
{
|
||||
return phy->cal->data->camerarx[phy->instance].num_lanes;
|
||||
}
|
||||
|
||||
static void cal_camerarx_enable(struct cal_camerarx *phy)
|
||||
{
|
||||
u32 max_lanes;
|
||||
@ -565,61 +528,6 @@ static void cal_camerarx_disable(struct cal_camerarx *phy)
|
||||
regmap_field_write(phy->fields[F_CTRLCLKEN], 0);
|
||||
}
|
||||
|
||||
/*
|
||||
* Camera Instance access block
|
||||
*/
|
||||
static struct cal_camerarx *cal_camerarx_create(struct cal_dev *cal,
|
||||
unsigned int instance)
|
||||
{
|
||||
struct platform_device *pdev = cal->pdev;
|
||||
struct cal_camerarx *phy;
|
||||
int ret;
|
||||
|
||||
phy = devm_kzalloc(&pdev->dev, sizeof(*phy), GFP_KERNEL);
|
||||
if (!phy)
|
||||
return ERR_PTR(-ENOMEM);
|
||||
|
||||
phy->cal = cal;
|
||||
phy->instance = instance;
|
||||
phy->external_rate = 192000000;
|
||||
|
||||
phy->res = platform_get_resource_byname(pdev, IORESOURCE_MEM,
|
||||
(instance == 0) ?
|
||||
"cal_rx_core0" :
|
||||
"cal_rx_core1");
|
||||
phy->base = devm_ioremap_resource(&pdev->dev, phy->res);
|
||||
if (IS_ERR(phy->base)) {
|
||||
cal_err(cal, "failed to ioremap\n");
|
||||
return ERR_CAST(phy->base);
|
||||
}
|
||||
|
||||
cal_dbg(1, cal, "ioresource %s at %pa - %pa\n",
|
||||
phy->res->name, &phy->res->start, &phy->res->end);
|
||||
|
||||
ret = cal_camerarx_regmap_init(cal, phy);
|
||||
if (ret)
|
||||
return ERR_PTR(ret);
|
||||
|
||||
return phy;
|
||||
}
|
||||
|
||||
/*
|
||||
* Get Revision and HW info
|
||||
*/
|
||||
static void cal_get_hwinfo(struct cal_dev *cal)
|
||||
{
|
||||
u32 revision;
|
||||
u32 hwinfo;
|
||||
|
||||
revision = reg_read(cal, CAL_HL_REVISION);
|
||||
cal_dbg(3, cal, "CAL_HL_REVISION = 0x%08x (expecting 0x40000200)\n",
|
||||
revision);
|
||||
|
||||
hwinfo = reg_read(cal, CAL_HL_HWINFO);
|
||||
cal_dbg(3, cal, "CAL_HL_HWINFO = 0x%08x (expecting 0xA3C90469)\n",
|
||||
hwinfo);
|
||||
}
|
||||
|
||||
/*
|
||||
* Errata i913: CSI2 LDO Needs to be disabled when module is powered on
|
||||
*
|
||||
@ -649,32 +557,6 @@ static void cal_camerarx_i913_errata(struct cal_camerarx *phy)
|
||||
reg_write(phy, CAL_CSI2_PHY_REG10, reg10);
|
||||
}
|
||||
|
||||
static void cal_quickdump_regs(struct cal_dev *cal)
|
||||
{
|
||||
cal_info(cal, "CAL Registers @ 0x%pa:\n", &cal->res->start);
|
||||
print_hex_dump(KERN_INFO, "", DUMP_PREFIX_OFFSET, 16, 4,
|
||||
(__force const void *)cal->base,
|
||||
resource_size(cal->res), false);
|
||||
|
||||
if (cal->ctx[0]) {
|
||||
cal_info(cal, "CSI2 Core 0 Registers @ %pa:\n",
|
||||
&cal->ctx[0]->phy->res->start);
|
||||
print_hex_dump(KERN_INFO, "", DUMP_PREFIX_OFFSET, 16, 4,
|
||||
(__force const void *)cal->ctx[0]->phy->base,
|
||||
resource_size(cal->ctx[0]->phy->res),
|
||||
false);
|
||||
}
|
||||
|
||||
if (cal->ctx[1]) {
|
||||
cal_info(cal, "CSI2 Core 1 Registers @ %pa:\n",
|
||||
&cal->ctx[1]->phy->res->start);
|
||||
print_hex_dump(KERN_INFO, "", DUMP_PREFIX_OFFSET, 16, 4,
|
||||
(__force const void *)cal->ctx[1]->phy->base,
|
||||
resource_size(cal->ctx[1]->phy->res),
|
||||
false);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Enable the expected IRQ sources
|
||||
*/
|
||||
@ -1010,6 +892,126 @@ static void cal_camerarx_ppi_disable(struct cal_camerarx *phy)
|
||||
0, CAL_CSI2_PPI_CTRL_IF_EN_MASK);
|
||||
}
|
||||
|
||||
static int cal_camerarx_get_external_info(struct cal_camerarx *phy)
|
||||
{
|
||||
struct v4l2_ctrl *ctrl;
|
||||
|
||||
if (!phy->sensor)
|
||||
return -ENODEV;
|
||||
|
||||
ctrl = v4l2_ctrl_find(phy->sensor->ctrl_handler, V4L2_CID_PIXEL_RATE);
|
||||
if (!ctrl) {
|
||||
phy_err(phy, "no pixel rate control in subdev: %s\n",
|
||||
phy->sensor->name);
|
||||
return -EPIPE;
|
||||
}
|
||||
|
||||
phy->external_rate = v4l2_ctrl_g_ctrl_int64(ctrl);
|
||||
phy_dbg(3, phy, "sensor Pixel Rate: %u\n", phy->external_rate);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cal_camerarx_regmap_init(struct cal_dev *cal,
|
||||
struct cal_camerarx *phy)
|
||||
{
|
||||
const struct cal_camerarx_data *phy_data;
|
||||
unsigned int i;
|
||||
|
||||
if (!cal->data)
|
||||
return -EINVAL;
|
||||
|
||||
phy_data = &cal->data->camerarx[phy->instance];
|
||||
|
||||
for (i = 0; i < F_MAX_FIELDS; i++) {
|
||||
struct reg_field field = {
|
||||
.reg = cal->syscon_camerrx_offset,
|
||||
.lsb = phy_data->fields[i].lsb,
|
||||
.msb = phy_data->fields[i].msb,
|
||||
};
|
||||
|
||||
/*
|
||||
* Here we update the reg offset with the
|
||||
* value found in DT
|
||||
*/
|
||||
phy->fields[i] = devm_regmap_field_alloc(&cal->pdev->dev,
|
||||
cal->syscon_camerrx,
|
||||
field);
|
||||
if (IS_ERR(phy->fields[i])) {
|
||||
cal_err(cal, "Unable to allocate regmap fields\n");
|
||||
return PTR_ERR(phy->fields[i]);
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct cal_camerarx *cal_camerarx_create(struct cal_dev *cal,
|
||||
unsigned int instance)
|
||||
{
|
||||
struct platform_device *pdev = cal->pdev;
|
||||
struct cal_camerarx *phy;
|
||||
int ret;
|
||||
|
||||
phy = devm_kzalloc(&pdev->dev, sizeof(*phy), GFP_KERNEL);
|
||||
if (!phy)
|
||||
return ERR_PTR(-ENOMEM);
|
||||
|
||||
phy->cal = cal;
|
||||
phy->instance = instance;
|
||||
phy->external_rate = 192000000;
|
||||
|
||||
phy->res = platform_get_resource_byname(pdev, IORESOURCE_MEM,
|
||||
(instance == 0) ?
|
||||
"cal_rx_core0" :
|
||||
"cal_rx_core1");
|
||||
phy->base = devm_ioremap_resource(&pdev->dev, phy->res);
|
||||
if (IS_ERR(phy->base)) {
|
||||
cal_err(cal, "failed to ioremap\n");
|
||||
return ERR_CAST(phy->base);
|
||||
}
|
||||
|
||||
cal_dbg(1, cal, "ioresource %s at %pa - %pa\n",
|
||||
phy->res->name, &phy->res->start, &phy->res->end);
|
||||
|
||||
ret = cal_camerarx_regmap_init(cal, phy);
|
||||
if (ret)
|
||||
return ERR_PTR(ret);
|
||||
|
||||
return phy;
|
||||
}
|
||||
|
||||
static struct regmap *cal_get_camerarx_regmap(struct cal_dev *cal)
|
||||
{
|
||||
struct platform_device *pdev = cal->pdev;
|
||||
struct regmap_config config = { };
|
||||
struct regmap *regmap;
|
||||
void __iomem *base;
|
||||
struct resource *res;
|
||||
|
||||
res = platform_get_resource_byname(pdev, IORESOURCE_MEM,
|
||||
"camerrx_control");
|
||||
base = devm_ioremap_resource(&pdev->dev, res);
|
||||
if (IS_ERR(base)) {
|
||||
cal_err(cal, "failed to ioremap\n");
|
||||
return ERR_CAST(base);
|
||||
}
|
||||
|
||||
cal_dbg(1, cal, "ioresource %s at %pa - %pa\n",
|
||||
res->name, &res->start, &res->end);
|
||||
|
||||
config.reg_bits = 32;
|
||||
config.reg_stride = 4;
|
||||
config.val_bits = 32;
|
||||
config.max_register = resource_size(res) - 4;
|
||||
|
||||
regmap = regmap_init_mmio(NULL, base, &config);
|
||||
if (IS_ERR(regmap))
|
||||
pr_err("regmap init failed\n");
|
||||
|
||||
return regmap;
|
||||
}
|
||||
|
||||
static void csi2_ctx_config(struct cal_ctx *ctx)
|
||||
{
|
||||
u32 val;
|
||||
@ -1146,26 +1148,6 @@ static void cal_wr_dma_addr(struct cal_ctx *ctx, unsigned int dmaaddr)
|
||||
reg_write(ctx->cal, CAL_WR_DMA_ADDR(ctx->csi2_port), dmaaddr);
|
||||
}
|
||||
|
||||
static int cal_camerarx_get_external_info(struct cal_camerarx *phy)
|
||||
{
|
||||
struct v4l2_ctrl *ctrl;
|
||||
|
||||
if (!phy->sensor)
|
||||
return -ENODEV;
|
||||
|
||||
ctrl = v4l2_ctrl_find(phy->sensor->ctrl_handler, V4L2_CID_PIXEL_RATE);
|
||||
if (!ctrl) {
|
||||
phy_err(phy, "no pixel rate control in subdev: %s\n",
|
||||
phy->sensor->name);
|
||||
return -EPIPE;
|
||||
}
|
||||
|
||||
phy->external_rate = v4l2_ctrl_g_ctrl_int64(ctrl);
|
||||
phy_dbg(3, phy, "sensor Pixel Rate: %u\n", phy->external_rate);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static inline void cal_schedule_next_buffer(struct cal_ctx *ctx)
|
||||
{
|
||||
struct cal_dmaqueue *dma_q = &ctx->vidq;
|
||||
@ -2244,6 +2226,23 @@ static const struct of_device_id cal_of_match[] = {
|
||||
};
|
||||
MODULE_DEVICE_TABLE(of, cal_of_match);
|
||||
|
||||
/*
|
||||
* Get Revision and HW info
|
||||
*/
|
||||
static void cal_get_hwinfo(struct cal_dev *cal)
|
||||
{
|
||||
u32 revision;
|
||||
u32 hwinfo;
|
||||
|
||||
revision = reg_read(cal, CAL_HL_REVISION);
|
||||
cal_dbg(3, cal, "CAL_HL_REVISION = 0x%08x (expecting 0x40000200)\n",
|
||||
revision);
|
||||
|
||||
hwinfo = reg_read(cal, CAL_HL_HWINFO);
|
||||
cal_dbg(3, cal, "CAL_HL_HWINFO = 0x%08x (expecting 0xA3C90469)\n",
|
||||
hwinfo);
|
||||
}
|
||||
|
||||
static int cal_probe(struct platform_device *pdev)
|
||||
{
|
||||
struct cal_dev *cal;
|
||||
|
Loading…
Reference in New Issue
Block a user