一、技术方案
1.1 方案介绍
增加一个设备树节点属性用于绑定红外补光灯的控电管脚,在针对性的摄像头推流时,控制对应管脚进行拉高拉低操作。
1.2 核心流程
新增mc_infrared-gpios按钮用于绑定红外补光灯的管脚。
打开GC2053 红外摄像头,获取摄像头数据流时,针对红外补光灯的控电管脚进行拉高操作。
关闭GC2053 红外摄像头,不获取摄像头数据流时,针对红外补光灯的控电管脚进行拉低操作。
二、详细设计
diff --git a/arch/arm64/boot/dts/rockchip/m10g30.dts b/arch/arm64/boot/dts/rockchip/m10g30.dts
index b8f1c150f9ec..ea891342b8bf 100644
--- a/arch/arm64/boot/dts/rockchip/m10g30.dts
+++ b/arch/arm64/boot/dts/rockchip/m10g30.dts
@@ -59,3 +59,6 @@
status = "okay";
};
+&gc2053 {
+ mc_infrared-gpios = <&gpio1 RK_PA1 GPIO_ACTIVE_LOW>;
+};
diff --git a/arch/arm64/boot/dts/rockchip/m16g30.dts b/arch/arm64/boot/dts/rockchip/m16g30.dts
index 0ce1ed914b48..265c4b00d39a 100644
--- a/arch/arm64/boot/dts/rockchip/m16g30.dts
+++ b/arch/arm64/boot/dts/rockchip/m16g30.dts
@@ -59,3 +59,6 @@
status = "okay";
};
+&gc2053 {
+ mc_infrared-gpios = <&gpio1 RK_PA1 GPIO_ACTIVE_LOW>;
+};
diff --git a/drivers/media/i2c/gc2053.c b/drivers/media/i2c/gc2053.c
diff --git a/drivers/media/i2c/gc2053.c b/drivers/media/i2c/gc2053.c
index fad8aeec9ee9..74df19b344ac 100644
--- a/drivers/media/i2c/gc2053.c
+++ b/drivers/media/i2c/gc2053.c
@@ -131,6 +131,7 @@ struct gc2053 {
struct clk *xvclk;
struct gpio_desc *reset_gpio;
struct gpio_desc *pwdn_gpio;
+ struct gpio_desc *infrared_gpio;
struct gpio_desc *power_gpio;
struct regulator_bulk_data supplies[GC2053_NUM_SUPPLIES];
@@ -1171,6 +1172,10 @@ static int gc2053_s_stream(struct v4l2_subdev *sd, int on)
goto unlock_and_return;
}
+ if (!IS_ERR(gc2053->infrared_gpio)) {
+ gpiod_set_value_cansleep(gc2053->infrared_gpio, 0);
+ }
+
ret = __gc2053_start_stream(gc2053);
if (ret) {
v4l2_err(sd, "start stream failed while write regs\n");
@@ -1178,6 +1183,9 @@ static int gc2053_s_stream(struct v4l2_subdev *sd, int on)
goto unlock_and_return;
}
} else {
+ if (!IS_ERR(gc2053->infrared_gpio)) {
+ gpiod_set_value_cansleep(gc2053->infrared_gpio, 1);
+ }
__gc2053_stop_stream(gc2053);
pm_runtime_put(&client->dev);
}
@@ -1495,6 +1503,10 @@ static int gc2053_probe(struct i2c_client *client,
if (IS_ERR(gc2053->reset_gpio))
dev_warn(dev, "Failed to get reset-gpios\n");
+ gc2053->infrared_gpio = devm_gpiod_get(dev, "mc_infrared", GPIOD_OUT_HIGH);
+ if (IS_ERR(gc2053->infrared_gpio))
+ dev_warn(dev, "Failed to get infrared-gpios\n");
+
gc2053->pwdn_gpio = devm_gpiod_get(dev, "pwdn", GPIOD_OUT_LOW);
if (IS_ERR(gc2053->pwdn_gpio))
dev_info(dev, "Failed to get pwdn-gpios, maybe no used\n");