[PATCH 2/2] media: v4l: fwnode: Parse CSI-2 C-PHY line-orders like bus-type

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Provided a safe-guard from the raw values used in device tree sources
and the in-kernel defines used to describe the different line orders.
This mimics what have been done for the bus-type property to provide the
same safe-guard.

The macros used in device tree sources are defined in video-interfaces.h
(MEDIA_BUS_CSI2_CPHY_LINE_ORDER_*) and are only visible to DTS source
files. These raw values map directly to the in-kernel names by fwnode
defines in v4l2-fwnode.h (V4L2_FWNODE_CSI2_CPHY_LINE_ORDER_*). These
fwnode defines are finally translated to defines which are exposed to
drivers to act on (V4L2_MBUS_CSI2_CPHY_LINE_ORDER_*).

Previously the translation to values provided to drivers have exploited
the fact that the numerical value for each setting are the same for the
defines used in device tree sources. While this is unlikely to change
this harmonises the bus-type and line-orders parsing to work using the
same mechanics, while at the same time make the large CSI-2 parsing
function a little more readable.

Suggested-by: Geert Uytterhoeven <geert@xxxxxxxxxxxxxx>
Signed-off-by: Niklas Söderlund <niklas.soderlund+renesas@xxxxxxxxxxxx>
---
 drivers/media/v4l2-core/v4l2-fwnode.c | 80 ++++++++++++++++++++++-----
 1 file changed, 66 insertions(+), 14 deletions(-)

diff --git a/drivers/media/v4l2-core/v4l2-fwnode.c b/drivers/media/v4l2-core/v4l2-fwnode.c
index cb153ce42c45..69f6d1df8c39 100644
--- a/drivers/media/v4l2-core/v4l2-fwnode.c
+++ b/drivers/media/v4l2-core/v4l2-fwnode.c
@@ -121,6 +121,70 @@ v4l2_fwnode_mbus_type_to_string(enum v4l2_mbus_type type)
 	return conv ? conv->name : "not found";
 }
 
+static const struct v4l2_fwnode_csi2_cphy_line_orders_conv {
+	enum v4l2_fwnode_csi2_cphy_line_orders_type fwnode_order;
+	enum v4l2_mbus_csi2_cphy_line_orders_type mbus_order;
+	const char *name;
+} csi2_cphy_line_orders[] = {
+	{
+		V4L2_FWNODE_CSI2_CPHY_LINE_ORDER_ABC,
+		V4L2_MBUS_CSI2_CPHY_LINE_ORDER_ABC,
+		"ABC",
+	}, {
+		V4L2_FWNODE_CSI2_CPHY_LINE_ORDER_ACB,
+		V4L2_MBUS_CSI2_CPHY_LINE_ORDER_ACB,
+		"ACB",
+	}, {
+		V4L2_FWNODE_CSI2_CPHY_LINE_ORDER_BAC,
+		V4L2_MBUS_CSI2_CPHY_LINE_ORDER_BAC,
+		"BAC",
+	}, {
+		V4L2_FWNODE_CSI2_CPHY_LINE_ORDER_BCA,
+		V4L2_MBUS_CSI2_CPHY_LINE_ORDER_BCA,
+		"BCA",
+	}, {
+		V4L2_FWNODE_CSI2_CPHY_LINE_ORDER_CAB,
+		V4L2_MBUS_CSI2_CPHY_LINE_ORDER_CAB,
+		"CAB",
+	}, {
+		V4L2_FWNODE_CSI2_CPHY_LINE_ORDER_CBA,
+		V4L2_MBUS_CSI2_CPHY_LINE_ORDER_CBA,
+		"CBA",
+	}
+};
+
+static const struct v4l2_fwnode_csi2_cphy_line_orders_conv *
+get_v4l2_fwnode_line_order_conv_by_fwnode_order(enum v4l2_fwnode_csi2_cphy_line_orders_type order)
+{
+	unsigned int i;
+
+	for (i = 0; i < ARRAY_SIZE(csi2_cphy_line_orders); i++)
+		if (csi2_cphy_line_orders[i].fwnode_order == order)
+			return &csi2_cphy_line_orders[i];
+
+	/* The default line order is ABC */
+	pr_warn("invalid line-order assuming ABC (got %u)\n", order);
+	return &csi2_cphy_line_orders[0];
+}
+
+static enum v4l2_mbus_csi2_cphy_line_orders_type
+v4l2_fwnode_line_order_to_mbus(enum v4l2_fwnode_csi2_cphy_line_orders_type order)
+{
+	const struct v4l2_fwnode_csi2_cphy_line_orders_conv *conv =
+		get_v4l2_fwnode_line_order_conv_by_fwnode_order(order);
+
+	return conv->mbus_order;
+}
+
+static const char *
+v4l2_fwnode_line_order_to_string(enum v4l2_fwnode_csi2_cphy_line_orders_type order)
+{
+	const struct v4l2_fwnode_csi2_cphy_line_orders_conv *conv =
+		get_v4l2_fwnode_line_order_conv_by_fwnode_order(order);
+
+	return conv->name;
+}
+
 static int v4l2_fwnode_endpoint_parse_csi2_bus(struct fwnode_handle *fwnode,
 					       struct v4l2_fwnode_endpoint *vep,
 					       enum v4l2_mbus_type bus_type)
@@ -268,21 +332,9 @@ static int v4l2_fwnode_endpoint_parse_csi2_bus(struct fwnode_handle *fwnode,
 						       num_data_lanes);
 
 			for (i = 0; i < num_data_lanes; i++) {
-				static const char * const orders[] = {
-					"ABC", "ACB", "BAC", "BCA", "CAB", "CBA"
-				};
-
-				if (array[i] >= ARRAY_SIZE(orders)) {
-					pr_warn("lane %u invalid line-order assuming ABC (got %u)\n",
-						i, array[i]);
-					bus->line_orders[i] =
-						V4L2_MBUS_CSI2_CPHY_LINE_ORDER_ABC;
-					continue;
-				}
-
-				bus->line_orders[i] = array[i];
+				bus->line_orders[i] = v4l2_fwnode_line_order_to_mbus(array[i]);
 				pr_debug("lane %u line order %s", i,
-					 orders[array[i]]);
+					 v4l2_fwnode_line_order_to_string(array[i]));
 			}
 		} else {
 			for (i = 0; i < num_data_lanes; i++)
-- 
2.47.1





[Index of Archives]     [Linux Samsung SOC]     [Linux Wireless]     [Linux Kernel]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]

  Powered by Linux