RV1103与FPGA通过MIPI CSI-2实现视频传输,实现网络推流

7 篇文章 6 订阅
3 篇文章 1 订阅

        RV1103与FPGA通过MIPI CSI-2实现视频传输,实现网络推流。   

一:图像格式

        支持图像格式如下:

        [0]: 'NV16' (Y/CbCr 4:2:2)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [1]: 'NV61' (Y/CrCb 4:2:2)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [2]: 'NV12' (Y/CbCr 4:2:0)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [3]: 'NV21' (Y/CrCb 4:2:0)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [4]: 'YUYV' (YUYV 4:2:2)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [5]: 'YVYU' (YVYU 4:2:2)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [6]: 'UYVY' (UYVY 4:2:2)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [7]: 'VYUY' (VYUY 4:2:2)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [8]: 'RGB3' (24-bit RGB 8-8-8)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [9]: 'BGR3' (24-bit BGR 8-8-8)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [10]: 'RGBP' (16-bit RGB 5-6-5)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [11]: 'BGRH' (18-bit BGRX 6-6-6-14)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [12]: 'RGGB' (8-bit Bayer RGRG/GBGB)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [13]: 'GRBG' (8-bit Bayer GRGR/BGBG)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [14]: 'GBRG' (8-bit Bayer GBGB/RGRG)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [15]: 'BA81' (8-bit Bayer BGBG/GRGR)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [16]: 'RG10' (10-bit Bayer RGRG/GBGB)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [17]: 'BA10' (10-bit Bayer GRGR/BGBG)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [18]: 'GB10' (10-bit Bayer GBGB/RGRG)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [19]: 'BG10' (10-bit Bayer BGBG/GRGR)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [20]: 'RG12' (12-bit Bayer RGRG/GBGB)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [21]: 'BA12' (12-bit Bayer GRGR/BGBG)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [22]: 'GB12' (12-bit Bayer GBGB/RGRG)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [23]: 'BG12' (12-bit Bayer BGBG/GRGR)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [24]: 'BYR2' (16-bit Bayer BGBG/GRGR)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [25]: 'GB16' (16-bit Bayer GBGB/RGRG)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [26]: 'GR16' (16-bit Bayer GRGR/BGBG)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [27]: 'RG16' (16-bit Bayer RGRG/GBGB)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [28]: 'Y16 ' (16-bit Greyscale)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [29]: 'GREY' (8-bit Greyscale)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [30]: 'EBD8' (Embedded data 8-bit)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [31]: 'SPD6' (Shield pix data 16-bit)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [32]: 'Y12 ' (12-bit Greyscale)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

        [33]: 'Y10 ' (10-bit Greyscale)

                Size: Stepwise 64x64 - 2304x1296 with step 8/8

二:DTS配置

        配置DTS:

&csi2_dphy_hw {
    status = "okay";
};

&csi2_dphy0 {
    status = "okay";

    ports {
        #address-cells = <1>;
        #size-cells = <0>;

        port@0 {
            reg = <0>;
            #address-cells = <1>;
            #size-cells = <0>;

            csi_dphy_input0: endpoint@0 {
                reg = <0>;
                remote-endpoint = <&sc3336_out>;
                data-lanes = <1 2>;
            };

            csi_dphy_input1: endpoint@1 {
                reg = <1>;
                remote-endpoint = <&sc4336_out>;
                data-lanes = <1 2>;
            };

            csi_dphy_input2: endpoint@2 {
                reg = <2>;
                remote-endpoint = <&sc530ai_out>;
                data-lanes = <1 2>;
            };
        };

        port@1 {
            reg = <1>;
            #address-cells = <1>;
            #size-cells = <0>;

            csi_dphy_output: endpoint@0 {
                reg = <0>;
                remote-endpoint = <&mipi_csi2_input>;
            };
        };
    };
};

&i2c4 {
    status = "okay";
    clock-frequency = <400000>;
    pinctrl-names = "default";
    pinctrl-0 = <&i2c4m2_xfer>;

    sc3336: sc3336@30 {
        compatible = "smartsens,sc3336";
        status = "okay";
        reg = <0x30>;
        clocks = <&cru MCLK_REF_MIPI0>;
        clock-names = "xvclk";
        pwdn-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
        pinctrl-names = "default";
        pinctrl-0 = <&mipi_refclk_out0>;
        rockchip,camera-module-index = <0>;
        rockchip,camera-module-facing = "back";
        rockchip,camera-module-name = "CMK-OT2119-PC1";
        rockchip,camera-module-lens-name = "30IRC-F16";
        port {
            sc3336_out: endpoint {
                remote-endpoint = <&csi_dphy_input0>;
                data-lanes = <1 2>;
            };
        };
    };

    sc4336: sc4336@30 {
        compatible = "smartsens,sc4336";
        status = "okay";
        reg = <0x30>;
        clocks = <&cru MCLK_REF_MIPI0>;
        clock-names = "xvclk";
        pwdn-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
        pinctrl-names = "default";
        pinctrl-0 = <&mipi_refclk_out0>;
        rockchip,camera-module-index = <0>;
        rockchip,camera-module-facing = "back";
        rockchip,camera-module-name = "OT01";
        rockchip,camera-module-lens-name = "40IRC_F16";
        port {
            sc4336_out: endpoint {
                remote-endpoint = <&csi_dphy_input1>;
                data-lanes = <1 2>;
            };
        };
    };

    sc530ai: sc530ai@30 {
        compatible = "smartsens,sc530ai";
        status = "okay";
        reg = <0x30>;
        clocks = <&cru MCLK_REF_MIPI0>;
        clock-names = "xvclk";
        pwdn-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
        pinctrl-names = "default";
        pinctrl-0 = <&mipi_refclk_out0>;
        rockchip,camera-module-index = <0>;
        rockchip,camera-module-facing = "back";
        rockchip,camera-module-name = "CMK-OT2115-PC1";
        rockchip,camera-module-lens-name = "30IRC-F16";
        port {
            sc530ai_out: endpoint {
                remote-endpoint = <&csi_dphy_input2>;
                data-lanes = <1 2>;
            };
        };
    };
};

&i2s0_8ch {
    #sound-dai-cells = <0>;
    status = "okay";
};

&mipi0_csi2 {
    status = "okay";

    ports {
        #address-cells = <1>;
        #size-cells = <0>;

        port@0 {
            reg = <0>;
            #address-cells = <1>;
            #size-cells = <0>;

            mipi_csi2_input: endpoint@1 {
                reg = <1>;
                remote-endpoint = <&csi_dphy_output>;
            };
        };

        port@1 {
            reg = <1>;
            #address-cells = <1>;
            #size-cells = <0>;

            mipi_csi2_output: endpoint@0 {
                reg = <0>;
                remote-endpoint = <&cif_mipi_in>;
            };
        };
    };
};

&pwm0 {
    status = "okay";
};

&rkcif {
    status = "okay";
};

&rkcif_mipi_lvds {
    status = "okay";

    pinctrl-names = "default";
    pinctrl-0 = <&mipi_pins>;
    port {
        /* MIPI CSI-2 endpoint */
        cif_mipi_in: endpoint {
            remote-endpoint = <&mipi_csi2_output>;
        };
    };
};

&rkcif_mipi_lvds_sditf {
    status = "okay";

    port {
        /* MIPI CSI-2 endpoint */
        mipi_lvds_sditf: endpoint {
            remote-endpoint = <&isp_in>;
        };
    };
};

&rkisp {
    status = "okay";
};

&rkisp_vir0 {
    status = "okay";

    port@0 {
        isp_in: endpoint {
            remote-endpoint = <&mipi_lvds_sditf>;
        };
    };
};

&saradc {
    status = "okay";
    vref-supply = <&vcc_1v8>;
};

三:驱动配置

        配置分辨率,数据类型。

static const struct sc3336_mode supported_modes[] = {
    {
        .width = 2304,
        .height = 1296,
        .max_fps = {
            .numerator = 10000,
            .denominator = 250000,
        },
        .exp_def = 0x0080,
        .hts_def = 0x05dc,
        .vts_def = 0x0654,
        .bus_fmt = MEDIA_BUS_FMT_SBGGR8_1X8,
        .reg_list = sc3336_linear_10_2304x1296_25fps_regs,
        .hdr_mode = NO_HDR,
        .xvclk_freq = 27000000,
        .link_freq_idx = 0,
        .vc[PAD0] = V4L2_MBUS_CSI2_CHANNEL_0,
    },
    {
        .width = 2304,
        .height = 1296,
        .max_fps = {
            .numerator = 10000,
            .denominator = 300000,
        },
        .exp_def = 0x0080,
        .hts_def = 0x0578 * 2,
        .vts_def = 0x0550,
        .bus_fmt = MEDIA_BUS_FMT_SBGGR8_1X8,
        .reg_list = sc3336_linear_10_2304x1296_30fps_regs,
        .hdr_mode = NO_HDR,
        .xvclk_freq = 24000000,
        .link_freq_idx = 1,
        .vc[PAD0] = V4L2_MBUS_CSI2_CHANNEL_0,
    }
};

四:注册查询

Media controller API version 5.10.110

Media device information

------------------------

driver          rkcif

model           rkcif-mipi-lvds

serial         

bus info       

hw revision     0x0

driver version  5.10.110

Device topology

- entity 1: stream_cif_mipi_id0 (1 pad, 11 links)

            type Node subtype V4L flags 0

            device node name /dev/video0

        pad0: Sink

                <- "rockchip-mipi-csi2":1 [ENABLED]

                <- "rockchip-mipi-csi2":2 []

                <- "rockchip-mipi-csi2":3 []

                <- "rockchip-mipi-csi2":4 []

                <- "rockchip-mipi-csi2":5 []

                <- "rockchip-mipi-csi2":6 []

                <- "rockchip-mipi-csi2":7 []

                <- "rockchip-mipi-csi2":8 []

                <- "rockchip-mipi-csi2":9 []

                <- "rockchip-mipi-csi2":10 []

                <- "rockchip-mipi-csi2":11 []

- entity 5: stream_cif_mipi_id1 (1 pad, 11 links)

            type Node subtype V4L flags 0

            device node name /dev/video1

        pad0: Sink

                <- "rockchip-mipi-csi2":1 []

                <- "rockchip-mipi-csi2":2 [ENABLED]

                <- "rockchip-mipi-csi2":3 []

                <- "rockchip-mipi-csi2":4 []

                <- "rockchip-mipi-csi2":5 []

                <- "rockchip-mipi-csi2":6 []

                <- "rockchip-mipi-csi2":7 []

                <- "rockchip-mipi-csi2":8 []

                <- "rockchip-mipi-csi2":9 []

                <- "rockchip-mipi-csi2":10 []

                <- "rockchip-mipi-csi2":11 []

- entity 9: stream_cif_mipi_id2 (1 pad, 11 links)

            type Node subtype V4L flags 0

            device node name /dev/video2

        pad0: Sink

                <- "rockchip-mipi-csi2":1 []

                <- "rockchip-mipi-csi2":2 []

                <- "rockchip-mipi-csi2":3 [ENABLED]

                <- "rockchip-mipi-csi2":4 []

                <- "rockchip-mipi-csi2":5 []

                <- "rockchip-mipi-csi2":6 []

                <- "rockchip-mipi-csi2":7 []

                <- "rockchip-mipi-csi2":8 []

                <- "rockchip-mipi-csi2":9 []

                <- "rockchip-mipi-csi2":10 []

                <- "rockchip-mipi-csi2":11 []

- entity 13: stream_cif_mipi_id3 (1 pad, 11 links)

             type Node subtype V4L flags 0

             device node name /dev/video3

        pad0: Sink

                <- "rockchip-mipi-csi2":1 []

                <- "rockchip-mipi-csi2":2 []

                <- "rockchip-mipi-csi2":3 []

                <- "rockchip-mipi-csi2":4 [ENABLED]

                <- "rockchip-mipi-csi2":5 []

                <- "rockchip-mipi-csi2":6 []

                <- "rockchip-mipi-csi2":7 []

                <- "rockchip-mipi-csi2":8 []

                <- "rockchip-mipi-csi2":9 []

                <- "rockchip-mipi-csi2":10 []

                <- "rockchip-mipi-csi2":11 []

- entity 17: rkcif_scale_ch0 (1 pad, 11 links)

             type Node subtype V4L flags 0

             device node name /dev/video4

        pad0: Sink

                <- "rockchip-mipi-csi2":1 []

                <- "rockchip-mipi-csi2":2 []

                <- "rockchip-mipi-csi2":3 []

                <- "rockchip-mipi-csi2":4 []

                <- "rockchip-mipi-csi2":5 [ENABLED]

                <- "rockchip-mipi-csi2":6 []

                <- "rockchip-mipi-csi2":7 []

                <- "rockchip-mipi-csi2":8 []

                <- "rockchip-mipi-csi2":9 []

                <- "rockchip-mipi-csi2":10 []

                <- "rockchip-mipi-csi2":11 []

- entity 21: rkcif_scale_ch1 (1 pad, 11 links)

             type Node subtype V4L flags 0

             device node name /dev/video5

        pad0: Sink

                <- "rockchip-mipi-csi2":1 []

                <- "rockchip-mipi-csi2":2 []

                <- "rockchip-mipi-csi2":3 []

                <- "rockchip-mipi-csi2":4 []

                <- "rockchip-mipi-csi2":5 []

                <- "rockchip-mipi-csi2":6 [ENABLED]

                <- "rockchip-mipi-csi2":7 []

                <- "rockchip-mipi-csi2":8 []

                <- "rockchip-mipi-csi2":9 []

                <- "rockchip-mipi-csi2":10 []

                <- "rockchip-mipi-csi2":11 []

- entity 25: rkcif_scale_ch2 (1 pad, 11 links)

             type Node subtype V4L flags 0

             device node name /dev/video6

        pad0: Sink

                <- "rockchip-mipi-csi2":1 []

                <- "rockchip-mipi-csi2":2 []

                <- "rockchip-mipi-csi2":3 []

                <- "rockchip-mipi-csi2":4 []

                <- "rockchip-mipi-csi2":5 []

                <- "rockchip-mipi-csi2":6 []

                <- "rockchip-mipi-csi2":7 [ENABLED]

                <- "rockchip-mipi-csi2":8 []

                <- "rockchip-mipi-csi2":9 []

                <- "rockchip-mipi-csi2":10 []

                <- "rockchip-mipi-csi2":11 []

- entity 29: rkcif_scale_ch3 (1 pad, 11 links)

             type Node subtype V4L flags 0

             device node name /dev/video7

        pad0: Sink

                <- "rockchip-mipi-csi2":1 []

                <- "rockchip-mipi-csi2":2 []

                <- "rockchip-mipi-csi2":3 []

                <- "rockchip-mipi-csi2":4 []

                <- "rockchip-mipi-csi2":5 []

                <- "rockchip-mipi-csi2":6 []

                <- "rockchip-mipi-csi2":7 []

                <- "rockchip-mipi-csi2":8 [ENABLED]

                <- "rockchip-mipi-csi2":9 []

                <- "rockchip-mipi-csi2":10 []

                <- "rockchip-mipi-csi2":11 []

- entity 33: rkcif_tools_id0 (1 pad, 11 links)

             type Node subtype V4L flags 0

             device node name /dev/video8

        pad0: Sink

                <- "rockchip-mipi-csi2":1 []

                <- "rockchip-mipi-csi2":2 []

                <- "rockchip-mipi-csi2":3 []

                <- "rockchip-mipi-csi2":4 []

                <- "rockchip-mipi-csi2":5 []

                <- "rockchip-mipi-csi2":6 []

                <- "rockchip-mipi-csi2":7 []

                <- "rockchip-mipi-csi2":8 []

                <- "rockchip-mipi-csi2":9 [ENABLED]

                <- "rockchip-mipi-csi2":10 []

                <- "rockchip-mipi-csi2":11 []

- entity 37: rkcif_tools_id1 (1 pad, 11 links)

             type Node subtype V4L flags 0

             device node name /dev/video9

        pad0: Sink

                <- "rockchip-mipi-csi2":1 []

                <- "rockchip-mipi-csi2":2 []

                <- "rockchip-mipi-csi2":3 []

                <- "rockchip-mipi-csi2":4 []

                <- "rockchip-mipi-csi2":5 []

                <- "rockchip-mipi-csi2":6 []

                <- "rockchip-mipi-csi2":7 []

                <- "rockchip-mipi-csi2":8 []

                <- "rockchip-mipi-csi2":9 []

                <- "rockchip-mipi-csi2":10 [ENABLED]

                <- "rockchip-mipi-csi2":11 []

- entity 41: rkcif_tools_id2 (1 pad, 11 links)

             type Node subtype V4L flags 0

             device node name /dev/video10

        pad0: Sink

                <- "rockchip-mipi-csi2":1 []

                <- "rockchip-mipi-csi2":2 []

                <- "rockchip-mipi-csi2":3 []

                <- "rockchip-mipi-csi2":4 []

                <- "rockchip-mipi-csi2":5 []

                <- "rockchip-mipi-csi2":6 []

                <- "rockchip-mipi-csi2":7 []

                <- "rockchip-mipi-csi2":8 []

                <- "rockchip-mipi-csi2":9 []

                <- "rockchip-mipi-csi2":10 []

                <- "rockchip-mipi-csi2":11 [ENABLED]

- entity 45: rockchip-mipi-csi2 (12 pads, 122 links)

             type V4L2 subdev subtype Unknown flags 0

             device node name /dev/v4l-subdev0

        pad0: Sink

                [fmt:SBGGR8_1X8/2304x1296 field:none

                 crop.bounds:(0,0)/2304x1296

                 crop:(0,0)/2304x1296]

                <- "rockchip-csi2-dphy0":1 [ENABLED]

        pad1: Source

                -> "stream_cif_mipi_id0":0 [ENABLED]

                -> "stream_cif_mipi_id1":0 []

                -> "stream_cif_mipi_id2":0 []

                -> "stream_cif_mipi_id3":0 []

                -> "rkcif_scale_ch0":0 []

                -> "rkcif_scale_ch1":0 []

                -> "rkcif_scale_ch2":0 []

                -> "rkcif_scale_ch3":0 []

                -> "rkcif_tools_id0":0 []

                -> "rkcif_tools_id1":0 []

                -> "rkcif_tools_id2":0 []

        pad2: Source

                -> "stream_cif_mipi_id0":0 []

                -> "stream_cif_mipi_id1":0 [ENABLED]

                -> "stream_cif_mipi_id2":0 []

                -> "stream_cif_mipi_id3":0 []

                -> "rkcif_scale_ch0":0 []

                -> "rkcif_scale_ch1":0 []

                -> "rkcif_scale_ch2":0 []

                -> "rkcif_scale_ch3":0 []

                -> "rkcif_tools_id0":0 []

                -> "rkcif_tools_id1":0 []

                -> "rkcif_tools_id2":0 []

        pad3: Source

                -> "stream_cif_mipi_id0":0 []

                -> "stream_cif_mipi_id1":0 []

                -> "stream_cif_mipi_id2":0 [ENABLED]

                -> "stream_cif_mipi_id3":0 []

                -> "rkcif_scale_ch0":0 []

                -> "rkcif_scale_ch1":0 []

                -> "rkcif_scale_ch2":0 []

                -> "rkcif_scale_ch3":0 []

                -> "rkcif_tools_id0":0 []

                -> "rkcif_tools_id1":0 []

                -> "rkcif_tools_id2":0 []

        pad4: Source

                -> "stream_cif_mipi_id0":0 []

                -> "stream_cif_mipi_id1":0 []

                -> "stream_cif_mipi_id2":0 []

                -> "stream_cif_mipi_id3":0 [ENABLED]

                -> "rkcif_scale_ch0":0 []

                -> "rkcif_scale_ch1":0 []

                -> "rkcif_scale_ch2":0 []

                -> "rkcif_scale_ch3":0 []

                -> "rkcif_tools_id0":0 []

                -> "rkcif_tools_id1":0 []

                -> "rkcif_tools_id2":0 []

        pad5: Source

                -> "stream_cif_mipi_id0":0 []

                -> "stream_cif_mipi_id1":0 []

                -> "stream_cif_mipi_id2":0 []

                -> "stream_cif_mipi_id3":0 []

                -> "rkcif_scale_ch0":0 [ENABLED]

                -> "rkcif_scale_ch1":0 []

                -> "rkcif_scale_ch2":0 []

                -> "rkcif_scale_ch3":0 []

                -> "rkcif_tools_id0":0 []

                -> "rkcif_tools_id1":0 []

                -> "rkcif_tools_id2":0 []

        pad6: Source

                -> "stream_cif_mipi_id0":0 []

                -> "stream_cif_mipi_id1":0 []

                -> "stream_cif_mipi_id2":0 []

                -> "stream_cif_mipi_id3":0 []

                -> "rkcif_scale_ch0":0 []

                -> "rkcif_scale_ch1":0 [ENABLED]

                -> "rkcif_scale_ch2":0 []

                -> "rkcif_scale_ch3":0 []

                -> "rkcif_tools_id0":0 []

                -> "rkcif_tools_id1":0 []

                -> "rkcif_tools_id2":0 []

        pad7: Source

                -> "stream_cif_mipi_id0":0 []

                -> "stream_cif_mipi_id1":0 []

                -> "stream_cif_mipi_id2":0 []

                -> "stream_cif_mipi_id3":0 []

                -> "rkcif_scale_ch0":0 []

                -> "rkcif_scale_ch1":0 []

                -> "rkcif_scale_ch2":0 [ENABLED]

                -> "rkcif_scale_ch3":0 []

                -> "rkcif_tools_id0":0 []

                -> "rkcif_tools_id1":0 []

                -> "rkcif_tools_id2":0 []

        pad8: Source

                -> "stream_cif_mipi_id0":0 []

                -> "stream_cif_mipi_id1":0 []

                -> "stream_cif_mipi_id2":0 []

                -> "stream_cif_mipi_id3":0 []

                -> "rkcif_scale_ch0":0 []

                -> "rkcif_scale_ch1":0 []

                -> "rkcif_scale_ch2":0 []

                -> "rkcif_scale_ch3":0 [ENABLED]

                -> "rkcif_tools_id0":0 []

                -> "rkcif_tools_id1":0 []

                -> "rkcif_tools_id2":0 []

        pad9: Source

                -> "stream_cif_mipi_id0":0 []

                -> "stream_cif_mipi_id1":0 []

                -> "stream_cif_mipi_id2":0 []

                -> "stream_cif_mipi_id3":0 []

                -> "rkcif_scale_ch0":0 []

                -> "rkcif_scale_ch1":0 []

                -> "rkcif_scale_ch2":0 []

                -> "rkcif_scale_ch3":0 []

                -> "rkcif_tools_id0":0 [ENABLED]

                -> "rkcif_tools_id1":0 []

                -> "rkcif_tools_id2":0 []

        pad10: Source

                -> "stream_cif_mipi_id0":0 []

                -> "stream_cif_mipi_id1":0 []

                -> "stream_cif_mipi_id2":0 []

                -> "stream_cif_mipi_id3":0 []

                -> "rkcif_scale_ch0":0 []

                -> "rkcif_scale_ch1":0 []

                -> "rkcif_scale_ch2":0 []

                -> "rkcif_scale_ch3":0 []

                -> "rkcif_tools_id0":0 []

                -> "rkcif_tools_id1":0 [ENABLED]

                -> "rkcif_tools_id2":0 []

        pad11: Source

                -> "stream_cif_mipi_id0":0 []

                -> "stream_cif_mipi_id1":0 []

                -> "stream_cif_mipi_id2":0 []

                -> "stream_cif_mipi_id3":0 []

                -> "rkcif_scale_ch0":0 []

                -> "rkcif_scale_ch1":0 []

                -> "rkcif_scale_ch2":0 []

                -> "rkcif_scale_ch3":0 []

                -> "rkcif_tools_id0":0 []

                -> "rkcif_tools_id1":0 []

                -> "rkcif_tools_id2":0 [ENABLED]

- entity 58: rockchip-csi2-dphy0 (2 pads, 2 links)

             type V4L2 subdev subtype Unknown flags 0

             device node name /dev/v4l-subdev1

        pad0: Sink

                [fmt:SBGGR8_1X8/2304x1296@10000/250000 field:none]

                <- "m00_b_sc3336 4-0030":0 [ENABLED]

        pad1: Source

                -> "rockchip-mipi-csi2":0 [ENABLED]

- entity 63: m00_b_sc3336 4-0030 (1 pad, 1 link)

             type V4L2 subdev subtype Sensor flags 0

             device node name /dev/v4l-subdev2

        pad0: Source

                [fmt:SBGGR8_1X8/2304x1296@10000/250000 field:none]

                -> "rockchip-csi2-dphy0":0 [ENABLED]

五:FPGA端MIPI CSI-2发送调试

确认FPGA端发送正常

六:图像VLC推流查看

FPGA发送动态图像模板显示效果

七:欢迎讨论交流

微:moning_hello

  • 23
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: MIPI CSI-2 RX是一种接口标准,用于手机、平板电脑和其他移动设备中摄像头和应用处理器之间的图像传输。 MIPI是移动行业处理器接口联盟(Mobile Industry Processor Interface)的缩写,它是移动设备行业制定的一系列接口标准。CSI-2代表Camera Serial Interface 2,是MIPI CSI的第二代接口标准。 MIPI CSI-2 RX(MIPI CSI-2 Receiver)是指实现MIPI CSI-2接口标准的接收设备。在移动设备中,摄像头通常会通过MIPI CSI-2接口将采集到的图像数据传输给应用处理器进行处理和显示。MIPI CSI-2 RX的作用就是接收和解析通过MIPI CSI-2接口传输的图像数据,并将其传递给应用处理器。 MIPI CSI-2 RX通常由硬件模块和驱动软件组成。硬件模块负责物理层接收和解析MIPI CSI-2接口的电信号,将其转换成数字图像数据。驱动软件则负责控制硬件模块的工作,管理图像数据的接收和传输。 MIPI CSI-2 RX不仅在移动设备中广泛应用,也在其他领域中得到了采用。例如,车载摄像头、工业相机等设备也可以采用MIPI CSI-2 RX接口进行图像数据传输。 总结来说,MIPI CSI-2 RX是一种实现MIPI CSI-2接口标准并用于接收和解析图像数据的设备。它在移动设备和其他领域中起到了关键性的作用,实现了摄像头和应用处理器之间的图像传输。 ### 回答2: MIPI CSI-2 RX是一种MIPI Camera Serial Interface 2 Receiver(MIPI CSI-2接收器)的技术。MIPI CSI-2 RX主要用于连接摄像头模块和处理器或图像传感器之间的通信。这个技术被广泛应用于移动设备、数字相机和其他具有图像和视频处理需求的电子设备中。 MIPI CSI-2 RX通常由两个主要组件组成:CSI-2接收器和PHY(物理层接口)。CSI-2接收器负责接收来自摄像头模块的数据,而PHY负责实现数据信号的传输和电气特性的匹配。 MIPI CSI-2 RX具有许多优点。首先,它支持高速数据传输,可以实现GBps级别的传输速率,确保了高质量的图像和视频传输。其次,它采用了差分数据传输和低压摆幅信号,减少了电磁干扰和功耗。此外,MIPI CSI-2 RX还提供了灵活的配置选项,可以根据具体需求进行配置和寄存器设置。 MIPI CSI-2 RX在图像和视频传输领域扮演着重要的角色。它不仅可以高效地传输高分辨率图像和视频数据,还提供了额外的功能,如自动对焦、自动曝光和图像处理功能。这使得MIPI CSI-2 RX成为许多电子设备的理想选择,包括智能手机、平板电脑、车载摄像头和工业相机等。 总之,MIPI CSI-2 RX是一种高效、可靠的图像和视频传输技术,在现代电子设备中发挥着关键作用。它的广泛应用和不断发展的特性使得它成为数字图像和视频处理领域的重要组成部分。 ### 回答3: MIPI CSI-2 RX指的是MIPI Camera Serial Interface 2 Receiver。MIPI CSI-2是一种数字串行接口协议,用于连接摄像头和图像处理器或显示设备之间的数据传输。RX代表接收器,指的是用于接收和解析来自摄像头的数据的设备或模块。 MIPI CSI-2 RX接收器通常用于移动设备、汽车行业和工业应用中的图像传输。它可以接收来自摄像头的高质量图像和视频数据,并将其传输到处理器或显示器以进行后续处理或展示。 MIPI CSI-2 RX的工作原理是通过一对多的差分信号传输图像数据。摄像头将数据通过串行方式传输到接收器,接收器通过解析和重构数据信号来还原图像。MIPI CSI-2 RX可以支持不同的像素格式、数据传输速率和分辨率,使其非常灵活和适应多种应用场景。 MIPI CSI-2 RX的优点包括高带宽、低功耗和低电压操作,这使其在移动设备中非常受欢迎。此外,它还支持块传输模式和流传输模式,以满足不同应用的需求。 总之,MIPI CSI-2 RX是一种用于接收和解析摄像头数据的接口协议和设备。它在移动设备和工业应用中起着重要作用,可以实现高质量的图像和视频传输

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

anhuihbo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值