linux查看网卡光强,LINUX OV5640驱动

LINUX OV5640驱动是为LINUX OV5640摄像头设计的一款专用驱动程序,主要用于摄像头和电脑的连接,如果电脑没有安装的话,摄像头插入将会出现无反应的问题,有购买此款摄像头的朋友可以下载此款驱动。

6f24857e40cb4e35bbb8c87830503ce7.png

软件特点

1.基于H3在Linux下驱动OV5640摄像头的方法,其特征在于,包括如下步骤:

S1打开OV5640摄像头所对应的设备文件/dev/videoX;

S2为OV5640摄像头驱动添加读写寄存器sys文件系统接口;

S3初始化OV5640摄像头,添加自动对焦功能;

S4读取OV5640摄像头的能力值;

S5设置视频输入源:设置VFE驱动默认输入源的初始值为0;

S6设置数据流类型和格式:设置VFE支持的视频格式为OV5640摄像头的格式;

S7初始化内存映射分配缓冲区;

S8查询缓冲区大小;

S9映射设备缓冲区到应用空间mmap;

S10添加缓冲区到输入队列;

S11启动视频流,开始采集数据,直至采集数据停止,停止视频流,停止采集数据;

S12释放内存映射;

S13关闭设备文件/dev/videoX。

2.根据权利要求1所述的方法,其特征在于,步骤S6中,VFE支持的视频格式的视频格式包括:

V4L2_MBUS_FMT_YUYV8_2X8;

V4L2_MBUS_FMT_YVYU8_2X8;

V4L2_MBUS_FMT_UYVY8_2X8;

V4L2_MBUS_FMT_VYUY8_2X8。

摄像头相关术语

黑电平校正 : 去除暗电流导致的噪声;

镜头校正 : 校正镜头导致的光强畸变 ;

坏点校正 : 掩盖静态和动态坏点

降噪 : 去除各种采集过程导致噪声

颜色校正 ; 校正到人眼响应曲线

Bayer还原 : RGB马赛克图像插值

自动对焦 : 计算对焦参考信息 控制对焦过程

自动白平衡(Automatic White Balance) : 目标是模拟人脑处理过程,实现彩色恒常性

自动曝光(Auto Exposure Control) : 选择合理曝光时间,和曝光增益,实现曝光度的自动调节

50/60Hz检测 : 解决白炽灯这类工频干扰

伽马校正 : 输出适合显示器显示图像

图像增强 : 分为宽动态处理,边缘增强,去雾等

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
全志R16平台 parrotv1.1(Android4.4.2) /* * Store information about the video data format. */ static struct sensor_format_struct { __u8 *desc; //__u32 pixelformat; enum v4l2_mbus_pixelcode mbus_code;//linux-3.0 struct regval_list *regs; int regs_size; int bpp; /* Bytes per pixel */ } sensor_formats[] = { //{ // .desc = "YUYV 4:2:2", // .mbus_code = V4L2_MBUS_FMT_YUYV8_2X8,//linux-3.0 // .regs = sensor_fmt_yuv422_yuyv, // .regs_size = ARRAY_SIZE(sensor_fmt_yuv422_yuyv), // .bpp = 2, //}, //{ // .desc = "YVYU 4:2:2", // .mbus_code = V4L2_MBUS_FMT_YVYU8_2X8,//linux-3.0 // .regs = sensor_fmt_yuv422_yvyu, // .regs_size = ARRAY_SIZE(sensor_fmt_yuv422_yvyu), // .bpp = 2, //}, { .desc = "UYVY 4:2:2", .mbus_code = V4L2_MBUS_FMT_UYVY8_2X8,//linux-3.0 .regs = sensor_fmt_yuv422_uyvy, .regs_size = ARRAY_SIZE(sensor_fmt_yuv422_uyvy), .bpp = 2, }, //{ // .desc = "VYUY 4:2:2", // .mbus_code = V4L2_MBUS_FMT_VYUY8_2X8,//linux-3.0 // .regs = sensor_fmt_yuv422_vyuy, // .regs_size = ARRAY_SIZE(sensor_fmt_yuv422_vyuy), // .bpp = 2, //}, //{ // .desc = "Raw RGB Bayer", // .mbus_code = V4L2_MBUS_FMT_SBGGR8_1X8,//linux-3.0 // .regs = sensor_fmt_raw, // .regs_size = ARRAY_SIZE(sensor_fmt_raw), // .bpp = 1 //}, }; #define N_FMTS ARRAY_SIZE(sensor_formats) /* * Then there is the issue of window sizes. Try to capture the info here. */ static struct sensor_win_size sensor_win_sizes[] = { // /* UXGA */ // { // .width = UXGA_WIDTH, // .height = UXGA_HEIGHT, // .hoffset = 0, // .voffset = 0, // .regs = sensor_uxga_regs, // .regs_size = ARRAY_SIZE(sensor_uxga_regs), // .set_size = NULL, // }, //// /* 720p */ //// { //// .width = HD720_WIDTH, //// .height = HD720_HEIGHT, //// .hoffset = 0, //// .voffset = 0, //// .regs = Gc2015_sensor_hd720_regs, //// .regs_size = ARRAY_SIZE(Gc2015_sensor_hd720_regs), //// .set_size = NULL, //// }, // /* SVGA */ // { // .width = SVGA_WIDTH, // .height = SVGA_HEIGHT, // .hoffset = 0, // .voffset = 0, // .regs = sensor_svga_regs, // .regs_size = ARRAY_SIZE(sensor_svga_regs), // .set_size = NULL, // }, // /* VGA */ // { // .width = VGA_WIDTH, // .height = VGA_HEIGHT, // .hoffset = 0, // .voffset = 0, // .regs = sensor_vga_regs, // .regs_size = ARRAY_SIZE(sensor_vga_regs), // .set_size = NULL, // }, /* VGA */ { .width = VGA_WIDTH, .height = VGA_HEIGHT, .hoffset = 0, .voffset = 0, .regs = sensor_default_regs, .regs_size = ARRAY_SIZE(sensor_default_regs), .set_size = NULL, }, };

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值