#![allow(unused_imports)] #![allow(unused_variables)] use clap::{App, Arg}; use himpp::{ hifb, himipi::{ComboDevAttrBuilder, DataType as MipiDataType, LaneDivideMode, MipiReceiver}, mpi::hdmi::{HdmiCore, HdmiId, HdmiPortBuilder}, mpi::sys::{SysBinder, SysManager, ViVpssMode}, mpi::types::{ DynamicRange, FrameInterruptAttr, FrameInterruptType, PixelFormat, Rect, Size, VideoInterface, VideoStandard, WdrMode, }, mpi::vb::{VbConfigBuilder, VbManager, VbRemapMode}, mpi::vi::{ ViChn, ViChnAttrBuilder, ViDev, ViDevAttrBuilder, ViDumpType, ViPipe, ViPipeAttrBuilder, ViRephaseMode, }, mpi::vo::{ VoBorder, VoChn, VoChnAttrBuilder, VoDev, VoLayer, VoPubAttrBuilder, VoVideoLayerAttrBuilder, }, mpi::vpss::{ VpssChn, VpssChnAttrBuilder, VpssChnMode, VpssCropInfo, VpssGrp, VpssGrpAttrBuilder, }, mpi::{sys, vb}, }; use pavo_traits::AlignUpwards; use poller::{EventContext, Events, Poller}; use std::fs::{File, OpenOptions}; use std::io::prelude::*; use std::path::Path; use std::sync::Arc; fn sysfs_write>(path: P, data: &[u8]) -> std::io::Result<()> { let mut file = OpenOptions::new().write(true).open(path)?; file.write(data)?; Ok(()) } fn main() -> Result<(), Box> { let matches = App::new("vi-vpss-vo-4ahd-4cvbs") .version("1.0") .author("Varphone Wong ") .about("The example of pipeline: VI -> VPSS -> VO") .arg( Arg::with_name("framerate") .short("f") .long("framerate") .help("Set the Video Framerate") .takes_value(true), ) .arg( Arg::with_name("ahd-size") .short("a") .long("ahd-size") .help("Set the AHD Video Input Size") .takes_value(true), ) .arg( Arg::with_name("cvbs-size") .short("c") .long("cvbs-size") .help("Set the CVBS Video Input Size") .takes_value(true), ) .get_matches(); let fps: u32 = matches .value_of("framerate") .unwrap_or("25") .parse() .unwrap(); let ahd_size = Size::from(matches.value_of("ahd-size").unwrap_or("1280x720")); let cvbs_size = Size::from(matches.value_of("cvbs-size").unwrap_or("720x576")); let vb_pool1 = (ahd_size.width * ahd_size.height * 3 / 2).align_upwards(64); let vb_pool2 = (cvbs_size.width * cvbs_size.height * 3 / 2).align_upwards(64); let vb_pool3 = (ahd_size.width * ahd_size.height * 2).align_upwards(64); let vb_pool4 = (cvbs_size.width * cvbs_size.height * 2).align_upwards(64); let vb_pool5: u32 = (1920 * 1080 * 3 / 2).align_upwards(64); let vb_conf = VbConfigBuilder::new() .pool(vb_pool1.into(), 16, VbRemapMode::None, "") .pool(vb_pool2.into(), 4, VbRemapMode::None, "") .pool(vb_pool3.into(), 16, VbRemapMode::None, "") .pool(vb_pool4.into(), 8, VbRemapMode::None, "") .pool(vb_pool5.into(), 3, VbRemapMode::None, "") .build(); let _vb_mgr = VbManager::new(&vb_conf, &[]); let _sys_mgr = SysManager::with_align(64, Some(_vb_mgr)); let vi_vpss_modes = [ ViVpssMode::BothOffline, // OnlineOffline ViVpssMode::BothOffline, ViVpssMode::BothOffline, ViVpssMode::BothOffline, ViVpssMode::BothOffline, ViVpssMode::BothOffline, ViVpssMode::BothOffline, ViVpssMode::BothOffline, ]; _sys_mgr.set_vi_vpss_mode(&vi_vpss_modes).unwrap(); let vo_attr = VoPubAttrBuilder::new() .with_bg_color(0x0000ffff) .with_video_interface(VideoInterface::Hdmi) .with_video_standard(VideoStandard::Hd1080p60) .build(); let vo_dev0 = Arc::new(VoDev::new(0, &vo_attr)); let vo_vl_attr = VoVideoLayerAttrBuilder::with_current(0) .with_disp_rect(Rect::new(0, 0, 1920, 1080)) .with_image_size(Size::new(1920, 1080)) .with_disp_framerate(60) .with_pixel_format(PixelFormat::YvuSemiPlanar420) .with_double_frame(false) .with_cluster_mode(false) .with_dynamic_range(DynamicRange::Sdr8) .build(); let vo_vl0 = Arc::new(VoLayer::new(0, &vo_vl_attr, Arc::clone(&vo_dev0))); vo_vl0.set_buf_len(3).unwrap(); vo_vl0.enable().unwrap(); let vo_chn_border = VoBorder::with_box(2, 0xffffff00); let vo_chn0_attr = VoChnAttrBuilder::with_current(0, &vo_vl0) .with_priority(0) .with_disp_rect(Rect::new(0, 0, 640, 360)) .build(); let vo_chn0 = Arc::new(VoChn::new(0, &vo_chn0_attr, Arc::clone(&vo_vl0))); vo_chn0.set_border(&vo_chn_border)?; vo_chn0.show()?; let vo_chn1_attr = VoChnAttrBuilder::with_current(1, &vo_vl0) .with_priority(0) .with_disp_rect(Rect::new(640, 0, 640, 360)) .build(); let vo_chn1 = Arc::new(VoChn::new(1, &vo_chn1_attr, Arc::clone(&vo_vl0))); vo_chn1.set_border(&vo_chn_border)?; vo_chn1.show()?; let vo_chn2_attr = VoChnAttrBuilder::with_current(2, &vo_vl0) .with_priority(0) .with_disp_rect(Rect::new(1280, 0, 640, 360)) .build(); let vo_chn2 = Arc::new(VoChn::new(2, &vo_chn2_attr, Arc::clone(&vo_vl0))); vo_chn2.set_border(&vo_chn_border)?; vo_chn2.show()?; let vo_chn3_attr = VoChnAttrBuilder::with_current(3, &vo_vl0) .with_priority(0) .with_disp_rect(Rect::new(0, 360, 640, 360)) .build(); let vo_chn3 = Arc::new(VoChn::new(3, &vo_chn3_attr, Arc::clone(&vo_vl0))); vo_chn3.set_border(&vo_chn_border)?; vo_chn3.show()?; let vo_chn4_attr = VoChnAttrBuilder::with_current(4, &vo_vl0) .with_priority(0) .with_disp_rect(Rect::new(640, 360, 640, 360)) .build(); let vo_chn4 = Arc::new(VoChn::new(4, &vo_chn4_attr, Arc::clone(&vo_vl0))); vo_chn4.set_border(&vo_chn_border)?; vo_chn4.show()?; let vo_chn5_attr = VoChnAttrBuilder::with_current(5, &vo_vl0) .with_priority(0) .with_disp_rect(Rect::new(1280, 360, 640, 360)) .build(); let vo_chn5 = Arc::new(VoChn::new(5, &vo_chn5_attr, Arc::clone(&vo_vl0))); vo_chn5.set_border(&vo_chn_border)?; vo_chn5.show()?; let vo_chn6_attr = VoChnAttrBuilder::with_current(6, &vo_vl0) .with_priority(0) .with_disp_rect(Rect::new(0, 720, 640, 360)) .build(); let vo_chn6 = Arc::new(VoChn::new(6, &vo_chn6_attr, Arc::clone(&vo_vl0))); vo_chn6.set_border(&vo_chn_border)?; vo_chn6.show()?; let vo_chn7_attr = VoChnAttrBuilder::with_current(7, &vo_vl0) .with_priority(0) .with_disp_rect(Rect::new(640, 720, 640, 360)) .build(); let vo_chn7 = Arc::new(VoChn::new(7, &vo_chn7_attr, Arc::clone(&vo_vl0))); vo_chn7.set_border(&vo_chn_border)?; vo_chn7.show()?; let vo_chn8_attr = VoChnAttrBuilder::with_current(8, &vo_vl0) .with_priority(0) .with_disp_rect(Rect::new(1280, 720, 640, 360)) .build(); let vo_chn8 = Arc::new(VoChn::new(8, &vo_chn8_attr, Arc::clone(&vo_vl0))); vo_chn8.set_border(&vo_chn_border)?; vo_chn8.show()?; let hdmi_core = Arc::new(HdmiCore::new()); let hdmi_port = HdmiPortBuilder::with_dvi_1080p60(HdmiId::Hdmi0, Arc::clone(&hdmi_core)).build(); hdmi_port.start().unwrap(); assert_eq!(Arc::strong_count(&hdmi_core), 2); let mut fb = hifb::FrameBuffer::new("/dev/fb0").unwrap(); assert_eq!( fb.set_pixel_format(hifb::PixelFormat::Argb8888).is_ok(), true ); assert_eq!(fb.set_resolution(1920, 1080).is_ok(), true); assert_eq!(fb.resolution(), (1920, 1080)); assert_eq!(fb.set_num_buffers(2).is_ok(), true); assert_eq!(fb.num_buffers(), 2); assert_eq!(fb.show().is_ok(), true); let mipi_rx = MipiReceiver::new(); assert!(mipi_rx.clear_all()); assert!(mipi_rx.set_hs_mode(LaneDivideMode::ModeA)); // 4+2+2+2+2+2+2 // AHD_0 assert!(mipi_rx.enable_mipi_clock(0)); assert!(mipi_rx.reset_mipi(0)); assert!(mipi_rx.enable_sensor_clock(0)); // assert!(mipi_rx.reset_sensor(0)); let mipi_attr = ComboDevAttrBuilder::new(0) .with_mipi() .with_size(ahd_size.width, ahd_size.height) .with_data_type(MipiDataType::Yuv4228Bit) .with_lanes([0, 1, 2, 3, -1, -1, -1, -1]) .build(); assert!(mipi_rx.set_dev_attr(&mipi_attr)); assert!(mipi_rx.unreset_mipi(0)); // assert!(mipi_rx.unreset_sensor(0)); // CVBS_2 assert!(mipi_rx.enable_mipi_clock(2)); assert!(mipi_rx.reset_mipi(2)); // assert!(mipi_rx.enable_sensor_clock(2)); // assert!(mipi_rx.reset_sensor(2)); let mipi_attr = ComboDevAttrBuilder::new(2) .with_mipi() .with_size(cvbs_size.width, cvbs_size.height) .with_data_type(MipiDataType::Yuv4228Bit) .with_lanes([4, -1, -1, -1, -1, -1, -1, -1]) .build(); assert!(mipi_rx.set_dev_attr(&mipi_attr)); assert!(mipi_rx.unreset_mipi(2)); // assert!(mipi_rx.unreset_sensor(2)); sysfs_write("/sys/class/misc/adv7280m-2-0/reset", b"1")?; // CVBS_3 assert!(mipi_rx.enable_mipi_clock(3)); assert!(mipi_rx.reset_mipi(3)); // assert!(mipi_rx.enable_sensor_clock(3)); // assert!(mipi_rx.reset_sensor(3)); let mipi_attr = ComboDevAttrBuilder::new(3) .with_mipi() .with_size(cvbs_size.width, cvbs_size.height) .with_data_type(MipiDataType::Yuv4228Bit) .with_lanes([5, -1, -1, -1, -1, -1, -1, -1]) .build(); assert!(mipi_rx.set_dev_attr(&mipi_attr)); assert!(mipi_rx.unreset_mipi(3)); // assert!(mipi_rx.unreset_sensor(3)); sysfs_write("/sys/class/misc/adv7280m-3-0/reset", b"1")?; // AHD_4 assert!(mipi_rx.enable_mipi_clock(4)); assert!(mipi_rx.reset_mipi(4)); // assert!(mipi_rx.enable_sensor_clock(4)); // assert!(mipi_rx.reset_sensor(4)); let mipi_attr = ComboDevAttrBuilder::new(4) .with_mipi() .with_size(ahd_size.width, ahd_size.height) .with_data_type(MipiDataType::Yuv4228Bit) .with_lanes([8, 10, -1, -1, -1, -1, -1, -1]) .build(); assert!(mipi_rx.set_dev_attr(&mipi_attr)); assert!(mipi_rx.unreset_mipi(4)); // assert!(mipi_rx.unreset_sensor(4)); // CVBS_6 assert!(mipi_rx.enable_mipi_clock(6)); assert!(mipi_rx.reset_mipi(6)); // assert!(mipi_rx.enable_sensor_clock(6)); // assert!(mipi_rx.reset_sensor(6)); let mipi_attr = ComboDevAttrBuilder::new(6) .with_mipi() .with_size(cvbs_size.width, cvbs_size.height) .with_data_type(MipiDataType::Yuv4228Bit) .with_lanes([12, -1, -1, -1, -1, -1, -1, -1]) .build(); assert!(mipi_rx.set_dev_attr(&mipi_attr)); assert!(mipi_rx.unreset_mipi(6)); // assert!(mipi_rx.unreset_sensor(6)); sysfs_write("/sys/class/misc/adv7280m-6-0/reset", b"1")?; // CVBS_7 assert!(mipi_rx.enable_mipi_clock(7)); assert!(mipi_rx.reset_mipi(7)); // assert!(mipi_rx.enable_sensor_clock(7)); // assert!(mipi_rx.reset_sensor(7)); let mipi_attr = ComboDevAttrBuilder::new(7) .with_mipi() .with_size(cvbs_size.width, cvbs_size.height) .with_data_type(MipiDataType::Yuv4228Bit) .with_lanes([13, -1, -1, -1, -1, -1, -1, -1]) .build(); assert!(mipi_rx.set_dev_attr(&mipi_attr)); assert!(mipi_rx.unreset_mipi(7)); // assert!(mipi_rx.unreset_sensor(7)); sysfs_write("/sys/class/misc/adv7280m-7-0/reset", b"1")?; let vi_dev_ahd_attr = ViDevAttrBuilder::new() .with_mipi_yuv422() .with_multiplex(1) .with_component_mask([0xff000000, 0x00ff0000]) .with_progressive() .with_yuv() .with_yuv_uyvy() .with_size(ahd_size) .with_bas_scale(ahd_size) .with_bas_rephase(ViRephaseMode::None, ViRephaseMode::None) .with_wdr(WdrMode::None, ahd_size.height) .build(); let vi_dev0 = Arc::new(ViDev::new(0, Some(&vi_dev_ahd_attr))); #[cfg(not(feature = "hi3559av100"))] vi_dev0.bind_mipi(0).unwrap(); vi_dev0.bind_pipes(&[0, 1]).unwrap(); let vi_dev4 = Arc::new(ViDev::new(4, Some(&vi_dev_ahd_attr))); #[cfg(not(feature = "hi3559av100"))] vi_dev4.bind_mipi(4).unwrap(); vi_dev4.bind_pipes(&[4, 5]).unwrap(); let vi_dev_cvbs_attr = ViDevAttrBuilder::new() .with_mipi_yuv422() .with_multiplex(1) .with_component_mask([0xff000000, 0x00ff0000]) .with_progressive() .with_yuv() .with_yuv_uyvy() .with_size(cvbs_size) .with_bas_scale(cvbs_size) .with_bas_rephase(ViRephaseMode::None, ViRephaseMode::None) .with_wdr(WdrMode::None, cvbs_size.height) .build(); let vi_dev2 = Arc::new(ViDev::new(2, Some(&vi_dev_cvbs_attr))); #[cfg(not(feature = "hi3559av100"))] vi_dev2.bind_mipi(2).unwrap(); vi_dev2.bind_pipes(&[2]).unwrap(); let vi_dev3 = Arc::new(ViDev::new(3, Some(&vi_dev_cvbs_attr))); #[cfg(not(feature = "hi3559av100"))] vi_dev3.bind_mipi(3).unwrap(); vi_dev3.bind_pipes(&[3]).unwrap(); let vi_dev6 = Arc::new(ViDev::new(6, Some(&vi_dev_cvbs_attr))); #[cfg(not(feature = "hi3559av100"))] vi_dev6.bind_mipi(6).unwrap(); vi_dev6.bind_pipes(&[6]).unwrap(); let vi_dev7 = Arc::new(ViDev::new(7, Some(&vi_dev_cvbs_attr))); #[cfg(not(feature = "hi3559av100"))] vi_dev7.bind_mipi(7).unwrap(); vi_dev7.bind_pipes(&[7]).unwrap(); let vi_pipe_ahd_attr = ViPipeAttrBuilder::new_yuv422_3dnr_rfr() .with_max_size(ahd_size) .build(); let vi_pipe0 = Arc::new(ViPipe::new(0, &vi_pipe_ahd_attr)); let vi_pipe1 = Arc::new(ViPipe::new(1, &vi_pipe_ahd_attr)); let vi_pipe4 = Arc::new(ViPipe::new(4, &vi_pipe_ahd_attr)); let vi_pipe5 = Arc::new(ViPipe::new(5, &vi_pipe_ahd_attr)); let vi_pipe_cvbs_attr = ViPipeAttrBuilder::new_yuv422_3dnr_rfr() .with_max_size(cvbs_size) .build(); let vi_pipe2 = Arc::new(ViPipe::new(2, &vi_pipe_cvbs_attr)); let vi_pipe3 = Arc::new(ViPipe::new(3, &vi_pipe_cvbs_attr)); let vi_pipe6 = Arc::new(ViPipe::new(6, &vi_pipe_cvbs_attr)); let vi_pipe7 = Arc::new(ViPipe::new(7, &vi_pipe_cvbs_attr)); let vi_chn_ahd_attr = ViChnAttrBuilder::new_yuv422_sdr8_linear() .with_size(ahd_size) .build(); let vi_chn0 = ViChn::new(0, Some(&vi_chn_ahd_attr), Arc::clone(&vi_pipe0)); let vi_chn1 = ViChn::new(0, Some(&vi_chn_ahd_attr), Arc::clone(&vi_pipe1)); let vi_chn4 = ViChn::new(0, Some(&vi_chn_ahd_attr), Arc::clone(&vi_pipe4)); let vi_chn5 = ViChn::new(0, Some(&vi_chn_ahd_attr), Arc::clone(&vi_pipe5)); let vi_chn_cvbs_attr = ViChnAttrBuilder::new_yuv422_sdr8_linear() .with_size(cvbs_size) .build(); let vi_chn2 = ViChn::new(0, Some(&vi_chn_cvbs_attr), Arc::clone(&vi_pipe2)); let vi_chn3 = ViChn::new(0, Some(&vi_chn_cvbs_attr), Arc::clone(&vi_pipe3)); let vi_chn6 = ViChn::new(0, Some(&vi_chn_cvbs_attr), Arc::clone(&vi_pipe6)); let vi_chn7 = ViChn::new(0, Some(&vi_chn_cvbs_attr), Arc::clone(&vi_pipe7)); let cvbs_frame_int_attr = FrameInterruptAttr::new(FrameInterruptType::Start, 0); // vi_pipe0.set_dump_attr(true, 3, ViDumpType::Yuv); vi_pipe0.set_vc_number(0).unwrap(); vi_pipe0.start().unwrap(); // vi_pipe1.set_dump_attr(true, 3, ViDumpType::Yuv); vi_pipe1.set_vc_number(1).unwrap(); vi_pipe1.start().unwrap(); // vi_pipe2.set_dump_attr(true, 3, ViDumpType::Yuv); vi_pipe2.set_vc_number(0).unwrap(); vi_pipe2 .set_frame_interrupt_attr(&cvbs_frame_int_attr) .unwrap(); vi_pipe2.start().unwrap(); // vi_pipe3.set_dump_attr(true, 3, ViDumpType::Yuv); vi_pipe3.set_vc_number(0).unwrap(); vi_pipe3 .set_frame_interrupt_attr(&cvbs_frame_int_attr) .unwrap(); vi_pipe3.start().unwrap(); // vi_pipe4.set_dump_attr(true, 3, ViDumpType::Yuv); vi_pipe4.set_vc_number(0).unwrap(); vi_pipe4.start().unwrap(); // vi_pipe5.set_dump_attr(true, 3, ViDumpType::Yuv); vi_pipe5.set_vc_number(1).unwrap(); vi_pipe5.start().unwrap(); // vi_pipe6.set_dump_attr(true, 3, ViDumpType::Yuv); vi_pipe6.set_vc_number(0).unwrap(); vi_pipe6 .set_frame_interrupt_attr(&cvbs_frame_int_attr) .unwrap(); vi_pipe6.start().unwrap(); // vi_pipe7.set_dump_attr(true, 3, ViDumpType::Yuv); vi_pipe7.set_vc_number(0).unwrap(); vi_pipe7 .set_frame_interrupt_attr(&cvbs_frame_int_attr) .unwrap(); vi_pipe7.start().unwrap(); let vpss_grp_ahd_attr = VpssGrpAttrBuilder::new().with_max_size(ahd_size).build(); let vpss_grp0 = Arc::new(VpssGrp::new(0, &vpss_grp_ahd_attr)); let vpss_grp1 = Arc::new(VpssGrp::new(1, &vpss_grp_ahd_attr)); let vpss_grp4 = Arc::new(VpssGrp::new(4, &vpss_grp_ahd_attr)); let vpss_grp5 = Arc::new(VpssGrp::new(5, &vpss_grp_ahd_attr)); let vpss_grp_cvbs_attr = VpssGrpAttrBuilder::new().with_max_size(cvbs_size).build(); let vpss_grp2 = Arc::new(VpssGrp::new(2, &vpss_grp_cvbs_attr)); let vpss_grp3 = Arc::new(VpssGrp::new(3, &vpss_grp_cvbs_attr)); let vpss_grp6 = Arc::new(VpssGrp::new(6, &vpss_grp_cvbs_attr)); let vpss_grp7 = Arc::new(VpssGrp::new(7, &vpss_grp_cvbs_attr)); let vpss_grp_ahd_crop = VpssCropInfo::with_abs(Rect::with_size(ahd_size)); vpss_grp0.set_crop(&vpss_grp_ahd_crop).unwrap(); vpss_grp1.set_crop(&vpss_grp_ahd_crop).unwrap(); vpss_grp4.set_crop(&vpss_grp_ahd_crop).unwrap(); vpss_grp5.set_crop(&vpss_grp_ahd_crop).unwrap(); let vpss_grp_cvbs_crop = VpssCropInfo::with_abs(Rect::with_size(cvbs_size)); vpss_grp2.set_crop(&vpss_grp_cvbs_crop).unwrap(); vpss_grp3.set_crop(&vpss_grp_cvbs_crop).unwrap(); vpss_grp6.set_crop(&vpss_grp_cvbs_crop).unwrap(); vpss_grp7.set_crop(&vpss_grp_cvbs_crop).unwrap(); let vpss_chn_ahd_attr = VpssChnAttrBuilder::new() .with_mode(VpssChnMode::User) .with_size(ahd_size) .build(); let vpss_chn0 = Arc::new(VpssChn::new(0, &vpss_chn_ahd_attr, Arc::clone(&vpss_grp0))); let vpss_chn1 = Arc::new(VpssChn::new(0, &vpss_chn_ahd_attr, Arc::clone(&vpss_grp1))); let vpss_chn4 = Arc::new(VpssChn::new(0, &vpss_chn_ahd_attr, Arc::clone(&vpss_grp4))); let vpss_chn5 = Arc::new(VpssChn::new(0, &vpss_chn_ahd_attr, Arc::clone(&vpss_grp5))); let vpss_chn_cvbs_attr = VpssChnAttrBuilder::new() .with_mode(VpssChnMode::User) .with_size(cvbs_size) .build(); let vpss_chn2 = Arc::new(VpssChn::new(0, &vpss_chn_cvbs_attr, Arc::clone(&vpss_grp2))); let vpss_chn3 = Arc::new(VpssChn::new(0, &vpss_chn_cvbs_attr, Arc::clone(&vpss_grp3))); let vpss_chn6 = Arc::new(VpssChn::new(0, &vpss_chn_cvbs_attr, Arc::clone(&vpss_grp6))); let vpss_chn7 = Arc::new(VpssChn::new(0, &vpss_chn_cvbs_attr, Arc::clone(&vpss_grp7))); vpss_grp0.start().unwrap(); vpss_grp1.start().unwrap(); vpss_grp2.start().unwrap(); vpss_grp3.start().unwrap(); vpss_grp4.start().unwrap(); vpss_grp5.start().unwrap(); vpss_grp6.start().unwrap(); vpss_grp7.start().unwrap(); let _b10 = SysBinder::new(&vi_pipe0, &vpss_grp0); let _b11 = SysBinder::new(&vi_pipe1, &vpss_grp1); let _b12 = SysBinder::new(&vi_pipe2, &vpss_grp2); let _b13 = SysBinder::new(&vi_pipe3, &vpss_grp3); let _b14 = SysBinder::new(&vi_pipe4, &vpss_grp4); let _b15 = SysBinder::new(&vi_pipe5, &vpss_grp5); let _b16 = SysBinder::new(&vi_pipe6, &vpss_grp6); let _b17 = SysBinder::new(&vi_pipe7, &vpss_grp7); let _b20 = SysBinder::new(&vpss_chn0, &vo_chn0); let _b21 = SysBinder::new(&vpss_chn1, &vo_chn1); let _b22 = SysBinder::new(&vpss_chn2, &vo_chn2); let _b23 = SysBinder::new(&vpss_chn3, &vo_chn3); let _b24 = SysBinder::new(&vpss_chn4, &vo_chn4); let _b25 = SysBinder::new(&vpss_chn5, &vo_chn5); let _b26 = SysBinder::new(&vpss_chn6, &vo_chn6); let _b27 = SysBinder::new(&vpss_chn7, &vo_chn7); let mut poller = Poller::new()?; poller.add(0, Events::new().read(), None).unwrap(); poller .add( vpss_chn0.get_fd().unwrap(), Events::new().read(), Some(Arc::clone(&vpss_chn0) as EventContext), ) .unwrap(); poller .add( vpss_chn1.get_fd().unwrap(), Events::new().read(), Some(Arc::clone(&vpss_chn1) as EventContext), ) .unwrap(); poller .add( vpss_chn2.get_fd().unwrap(), Events::new().read(), Some(Arc::clone(&vpss_chn2) as EventContext), ) .unwrap(); poller .add( vpss_chn3.get_fd().unwrap(), Events::new().read(), Some(Arc::clone(&vpss_chn3) as EventContext), ) .unwrap(); println!("Press enter to exit ..."); 'outer: loop { let events = poller.pull_events(1000).unwrap(); for (_fd, _events, ctx) in events.iter() { match ctx { Some(v) => { if let Some(chn) = v.downcast_ref::() { let info = chn.get_frame(0).unwrap(); let vf = info.video_frame(); if chn.group_id() == 9 { // let mut file = File::create("/tmp/foo.yuv").unwrap(); // let planes = vf.plane_memories(); // println!( // "New Frame: chn={}, size={}, pts={}", // chn, // vf.size(), // vf.pts() // ); // println!("New Frame planes={:#?}", planes); // for a in 0..planes.len() { // file.write(planes[a].as_bytes()).unwrap(); // } } } } None => { if _fd == &0 { break 'outer; } } } } } Ok(()) }