From eb3a99bc183e36922b9e8314620e4e64964bcaf0 Mon Sep 17 00:00:00 2001 From: Adrian Schmutzler Date: Tue, 5 Oct 2021 20:51:18 +0200 Subject: bcm27xx: remove obsolete kernel 5.4 With the upgrade to kernel 5.10 per default the old version is no longer required to be in tree. Signed-off-by: Adrian Schmutzler --- ...dia-i2c-Add-driver-for-Sony-IMX219-sensor.patch | 1372 -------------------- 1 file changed, 1372 deletions(-) delete mode 100644 target/linux/bcm27xx/patches-5.4/950-0452-media-i2c-Add-driver-for-Sony-IMX219-sensor.patch (limited to 'target/linux/bcm27xx/patches-5.4/950-0452-media-i2c-Add-driver-for-Sony-IMX219-sensor.patch') diff --git a/target/linux/bcm27xx/patches-5.4/950-0452-media-i2c-Add-driver-for-Sony-IMX219-sensor.patch b/target/linux/bcm27xx/patches-5.4/950-0452-media-i2c-Add-driver-for-Sony-IMX219-sensor.patch deleted file mode 100644 index 4ca345f2ad..0000000000 --- a/target/linux/bcm27xx/patches-5.4/950-0452-media-i2c-Add-driver-for-Sony-IMX219-sensor.patch +++ /dev/null @@ -1,1372 +0,0 @@ -From 5cd8c4efeb46ce1ef370dd3012a7951ba430b58f Mon Sep 17 00:00:00 2001 -From: Dave Stevenson -Date: Mon, 20 Jan 2020 05:15:58 -0300 -Subject: [PATCH] media: i2c: Add driver for Sony IMX219 sensor - -Commit 1283b3b8f82b9004fbb94398cade5c8e797a2c8d upstream. -(Currently on linux-media/master, queued for 5.7) - -Adds a driver for the 8MPix Sony IMX219 CSI2 sensor. -Whilst the sensor supports 2 or 4 CSI2 data lanes, this driver -currently only supports 2 lanes. -8MPix @ 15fps, 1080P @ 30fps (cropped FOV), and 1640x1232 (2x2 binned) -@ 30fps are currently supported. - -[Sakari Ailus: make imx219_check_hwcfg static] - -Signed-off-by: Dave Stevenson -Signed-off-by: Andrey Konovalov -Signed-off-by: Sakari Ailus -Signed-off-by: Mauro Carvalho Chehab ---- - drivers/media/i2c/Kconfig | 11 + - drivers/media/i2c/Makefile | 1 + - drivers/media/i2c/imx219.c | 1312 ++++++++++++++++++++++++++++++++++++ - 3 files changed, 1324 insertions(+) - create mode 100644 drivers/media/i2c/imx219.c - ---- a/drivers/media/i2c/Kconfig -+++ b/drivers/media/i2c/Kconfig -@@ -578,6 +578,17 @@ config VIDEO_IMX214 - To compile this driver as a module, choose M here: the - module will be called imx214. - -+config VIDEO_IMX219 -+ tristate "Sony IMX219 sensor support" -+ depends on I2C && VIDEO_V4L2 && VIDEO_V4L2_SUBDEV_API -+ select V4L2_FWNODE -+ help -+ This is a Video4Linux2 sensor driver for the Sony -+ IMX219 camera. -+ -+ To compile this driver as a module, choose M here: the -+ module will be called imx219. -+ - config VIDEO_IMX258 - tristate "Sony IMX258 sensor support" - depends on I2C && VIDEO_V4L2 && VIDEO_V4L2_SUBDEV_API ---- a/drivers/media/i2c/Makefile -+++ b/drivers/media/i2c/Makefile -@@ -111,6 +111,7 @@ obj-$(CONFIG_VIDEO_ML86V7667) += ml86v76 - obj-$(CONFIG_VIDEO_OV2659) += ov2659.o - obj-$(CONFIG_VIDEO_TC358743) += tc358743.o - obj-$(CONFIG_VIDEO_IMX214) += imx214.o -+obj-$(CONFIG_VIDEO_IMX219) += imx219.o - obj-$(CONFIG_VIDEO_IMX258) += imx258.o - obj-$(CONFIG_VIDEO_IMX274) += imx274.o - obj-$(CONFIG_VIDEO_IMX319) += imx319.o ---- /dev/null -+++ b/drivers/media/i2c/imx219.c -@@ -0,0 +1,1312 @@ -+// SPDX-License-Identifier: GPL-2.0 -+/* -+ * A V4L2 driver for Sony IMX219 cameras. -+ * Copyright (C) 2019, Raspberry Pi (Trading) Ltd -+ * -+ * Based on Sony imx258 camera driver -+ * Copyright (C) 2018 Intel Corporation -+ * -+ * DT / fwnode changes, and regulator / GPIO control taken from imx214 driver -+ * Copyright 2018 Qtechnology A/S -+ * -+ * Flip handling taken from the Sony IMX319 driver. -+ * Copyright (C) 2018 Intel Corporation -+ * -+ */ -+ -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+ -+#define IMX219_REG_VALUE_08BIT 1 -+#define IMX219_REG_VALUE_16BIT 2 -+ -+#define IMX219_REG_MODE_SELECT 0x0100 -+#define IMX219_MODE_STANDBY 0x00 -+#define IMX219_MODE_STREAMING 0x01 -+ -+/* Chip ID */ -+#define IMX219_REG_CHIP_ID 0x0000 -+#define IMX219_CHIP_ID 0x0219 -+ -+/* External clock frequency is 24.0M */ -+#define IMX219_XCLK_FREQ 24000000 -+ -+/* Pixel rate is fixed at 182.4M for all the modes */ -+#define IMX219_PIXEL_RATE 182400000 -+ -+#define IMX219_DEFAULT_LINK_FREQ 456000000 -+ -+/* V_TIMING internal */ -+#define IMX219_REG_VTS 0x0160 -+#define IMX219_VTS_15FPS 0x0dc6 -+#define IMX219_VTS_30FPS_1080P 0x06e3 -+#define IMX219_VTS_30FPS_BINNED 0x06e3 -+#define IMX219_VTS_MAX 0xffff -+ -+#define IMX219_VBLANK_MIN 4 -+ -+/*Frame Length Line*/ -+#define IMX219_FLL_MIN 0x08a6 -+#define IMX219_FLL_MAX 0xffff -+#define IMX219_FLL_STEP 1 -+#define IMX219_FLL_DEFAULT 0x0c98 -+ -+/* HBLANK control - read only */ -+#define IMX219_PPL_DEFAULT 3448 -+ -+/* Exposure control */ -+#define IMX219_REG_EXPOSURE 0x015a -+#define IMX219_EXPOSURE_MIN 4 -+#define IMX219_EXPOSURE_STEP 1 -+#define IMX219_EXPOSURE_DEFAULT 0x640 -+#define IMX219_EXPOSURE_MAX 65535 -+ -+/* Analog gain control */ -+#define IMX219_REG_ANALOG_GAIN 0x0157 -+#define IMX219_ANA_GAIN_MIN 0 -+#define IMX219_ANA_GAIN_MAX 232 -+#define IMX219_ANA_GAIN_STEP 1 -+#define IMX219_ANA_GAIN_DEFAULT 0x0 -+ -+/* Digital gain control */ -+#define IMX219_REG_DIGITAL_GAIN 0x0158 -+#define IMX219_DGTL_GAIN_MIN 0x0100 -+#define IMX219_DGTL_GAIN_MAX 0x0fff -+#define IMX219_DGTL_GAIN_DEFAULT 0x0100 -+#define IMX219_DGTL_GAIN_STEP 1 -+ -+#define IMX219_REG_ORIENTATION 0x0172 -+ -+/* Test Pattern Control */ -+#define IMX219_REG_TEST_PATTERN 0x0600 -+#define IMX219_TEST_PATTERN_DISABLE 0 -+#define IMX219_TEST_PATTERN_SOLID_COLOR 1 -+#define IMX219_TEST_PATTERN_COLOR_BARS 2 -+#define IMX219_TEST_PATTERN_GREY_COLOR 3 -+#define IMX219_TEST_PATTERN_PN9 4 -+ -+/* Test pattern colour components */ -+#define IMX219_REG_TESTP_RED 0x0602 -+#define IMX219_REG_TESTP_GREENR 0x0604 -+#define IMX219_REG_TESTP_BLUE 0x0606 -+#define IMX219_REG_TESTP_GREENB 0x0608 -+#define IMX219_TESTP_COLOUR_MIN 0 -+#define IMX219_TESTP_COLOUR_MAX 0x03ff -+#define IMX219_TESTP_COLOUR_STEP 1 -+#define IMX219_TESTP_RED_DEFAULT IMX219_TESTP_COLOUR_MAX -+#define IMX219_TESTP_GREENR_DEFAULT 0 -+#define IMX219_TESTP_BLUE_DEFAULT 0 -+#define IMX219_TESTP_GREENB_DEFAULT 0 -+ -+struct imx219_reg { -+ u16 address; -+ u8 val; -+}; -+ -+struct imx219_reg_list { -+ unsigned int num_of_regs; -+ const struct imx219_reg *regs; -+}; -+ -+/* Mode : resolution and related config&values */ -+struct imx219_mode { -+ /* Frame width */ -+ unsigned int width; -+ /* Frame height */ -+ unsigned int height; -+ -+ /* V-timing */ -+ unsigned int vts_def; -+ -+ /* Default register values */ -+ struct imx219_reg_list reg_list; -+}; -+ -+/* -+ * Register sets lifted off the i2C interface from the Raspberry Pi firmware -+ * driver. -+ * 3280x2464 = mode 2, 1920x1080 = mode 1, and 1640x1232 = mode 4. -+ */ -+static const struct imx219_reg mode_3280x2464_regs[] = { -+ {0x0100, 0x00}, -+ {0x30eb, 0x0c}, -+ {0x30eb, 0x05}, -+ {0x300a, 0xff}, -+ {0x300b, 0xff}, -+ {0x30eb, 0x05}, -+ {0x30eb, 0x09}, -+ {0x0114, 0x01}, -+ {0x0128, 0x00}, -+ {0x012a, 0x18}, -+ {0x012b, 0x00}, -+ {0x0164, 0x00}, -+ {0x0165, 0x00}, -+ {0x0166, 0x0c}, -+ {0x0167, 0xcf}, -+ {0x0168, 0x00}, -+ {0x0169, 0x00}, -+ {0x016a, 0x09}, -+ {0x016b, 0x9f}, -+ {0x016c, 0x0c}, -+ {0x016d, 0xd0}, -+ {0x016e, 0x09}, -+ {0x016f, 0xa0}, -+ {0x0170, 0x01}, -+ {0x0171, 0x01}, -+ {0x0174, 0x00}, -+ {0x0175, 0x00}, -+ {0x018c, 0x0a}, -+ {0x018d, 0x0a}, -+ {0x0301, 0x05}, -+ {0x0303, 0x01}, -+ {0x0304, 0x03}, -+ {0x0305, 0x03}, -+ {0x0306, 0x00}, -+ {0x0307, 0x39}, -+ {0x0309, 0x0a}, -+ {0x030b, 0x01}, -+ {0x030c, 0x00}, -+ {0x030d, 0x72}, -+ {0x0624, 0x0c}, -+ {0x0625, 0xd0}, -+ {0x0626, 0x09}, -+ {0x0627, 0xa0}, -+ {0x455e, 0x00}, -+ {0x471e, 0x4b}, -+ {0x4767, 0x0f}, -+ {0x4750, 0x14}, -+ {0x4540, 0x00}, -+ {0x47b4, 0x14}, -+ {0x4713, 0x30}, -+ {0x478b, 0x10}, -+ {0x478f, 0x10}, -+ {0x4793, 0x10}, -+ {0x4797, 0x0e}, -+ {0x479b, 0x0e}, -+ {0x0162, 0x0d}, -+ {0x0163, 0x78}, -+}; -+ -+static const struct imx219_reg mode_1920_1080_regs[] = { -+ {0x0100, 0x00}, -+ {0x30eb, 0x05}, -+ {0x30eb, 0x0c}, -+ {0x300a, 0xff}, -+ {0x300b, 0xff}, -+ {0x30eb, 0x05}, -+ {0x30eb, 0x09}, -+ {0x0114, 0x01}, -+ {0x0128, 0x00}, -+ {0x012a, 0x18}, -+ {0x012b, 0x00}, -+ {0x0162, 0x0d}, -+ {0x0163, 0x78}, -+ {0x0164, 0x02}, -+ {0x0165, 0xa8}, -+ {0x0166, 0x0a}, -+ {0x0167, 0x27}, -+ {0x0168, 0x02}, -+ {0x0169, 0xb4}, -+ {0x016a, 0x06}, -+ {0x016b, 0xeb}, -+ {0x016c, 0x07}, -+ {0x016d, 0x80}, -+ {0x016e, 0x04}, -+ {0x016f, 0x38}, -+ {0x0170, 0x01}, -+ {0x0171, 0x01}, -+ {0x0174, 0x00}, -+ {0x0175, 0x00}, -+ {0x018c, 0x0a}, -+ {0x018d, 0x0a}, -+ {0x0301, 0x05}, -+ {0x0303, 0x01}, -+ {0x0304, 0x03}, -+ {0x0305, 0x03}, -+ {0x0306, 0x00}, -+ {0x0307, 0x39}, -+ {0x0309, 0x0a}, -+ {0x030b, 0x01}, -+ {0x030c, 0x00}, -+ {0x030d, 0x72}, -+ {0x0624, 0x07}, -+ {0x0625, 0x80}, -+ {0x0626, 0x04}, -+ {0x0627, 0x38}, -+ {0x455e, 0x00}, -+ {0x471e, 0x4b}, -+ {0x4767, 0x0f}, -+ {0x4750, 0x14}, -+ {0x4540, 0x00}, -+ {0x47b4, 0x14}, -+ {0x4713, 0x30}, -+ {0x478b, 0x10}, -+ {0x478f, 0x10}, -+ {0x4793, 0x10}, -+ {0x4797, 0x0e}, -+ {0x479b, 0x0e}, -+ {0x0162, 0x0d}, -+ {0x0163, 0x78}, -+}; -+ -+static const struct imx219_reg mode_1640_1232_regs[] = { -+ {0x0100, 0x00}, -+ {0x30eb, 0x0c}, -+ {0x30eb, 0x05}, -+ {0x300a, 0xff}, -+ {0x300b, 0xff}, -+ {0x30eb, 0x05}, -+ {0x30eb, 0x09}, -+ {0x0114, 0x01}, -+ {0x0128, 0x00}, -+ {0x012a, 0x18}, -+ {0x012b, 0x00}, -+ {0x0164, 0x00}, -+ {0x0165, 0x00}, -+ {0x0166, 0x0c}, -+ {0x0167, 0xcf}, -+ {0x0168, 0x00}, -+ {0x0169, 0x00}, -+ {0x016a, 0x09}, -+ {0x016b, 0x9f}, -+ {0x016c, 0x06}, -+ {0x016d, 0x68}, -+ {0x016e, 0x04}, -+ {0x016f, 0xd0}, -+ {0x0170, 0x01}, -+ {0x0171, 0x01}, -+ {0x0174, 0x01}, -+ {0x0175, 0x01}, -+ {0x018c, 0x0a}, -+ {0x018d, 0x0a}, -+ {0x0301, 0x05}, -+ {0x0303, 0x01}, -+ {0x0304, 0x03}, -+ {0x0305, 0x03}, -+ {0x0306, 0x00}, -+ {0x0307, 0x39}, -+ {0x0309, 0x0a}, -+ {0x030b, 0x01}, -+ {0x030c, 0x00}, -+ {0x030d, 0x72}, -+ {0x0624, 0x06}, -+ {0x0625, 0x68}, -+ {0x0626, 0x04}, -+ {0x0627, 0xd0}, -+ {0x455e, 0x00}, -+ {0x471e, 0x4b}, -+ {0x4767, 0x0f}, -+ {0x4750, 0x14}, -+ {0x4540, 0x00}, -+ {0x47b4, 0x14}, -+ {0x4713, 0x30}, -+ {0x478b, 0x10}, -+ {0x478f, 0x10}, -+ {0x4793, 0x10}, -+ {0x4797, 0x0e}, -+ {0x479b, 0x0e}, -+ {0x0162, 0x0d}, -+ {0x0163, 0x78}, -+}; -+ -+static const char * const imx219_test_pattern_menu[] = { -+ "Disabled", -+ "Color Bars", -+ "Solid Color", -+ "Grey Color Bars", -+ "PN9" -+}; -+ -+static const int imx219_test_pattern_val[] = { -+ IMX219_TEST_PATTERN_DISABLE, -+ IMX219_TEST_PATTERN_COLOR_BARS, -+ IMX219_TEST_PATTERN_SOLID_COLOR, -+ IMX219_TEST_PATTERN_GREY_COLOR, -+ IMX219_TEST_PATTERN_PN9, -+}; -+ -+/* regulator supplies */ -+static const char * const imx219_supply_name[] = { -+ /* Supplies can be enabled in any order */ -+ "VANA", /* Analog (2.8V) supply */ -+ "VDIG", /* Digital Core (1.8V) supply */ -+ "VDDL", /* IF (1.2V) supply */ -+}; -+ -+#define IMX219_NUM_SUPPLIES ARRAY_SIZE(imx219_supply_name) -+ -+/* -+ * Initialisation delay between XCLR low->high and the moment when the sensor -+ * can start capture (i.e. can leave software stanby) must be not less than: -+ * t4 + max(t5, t6 +