亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ipu_prp_vf_sdc.c

?? LINUX下的ov2640驅(qū)動程序
?? C
字號:
/* * Copyright 2004-2007 Freescale Semiconductor, Inc. All Rights Reserved. *//* * The code contained herein is licensed under the GNU General Public * License. You may obtain a copy of the GNU General Public License * Version 2 or later at the following locations: * * http://www.opensource.org/licenses/gpl-license.html * http://www.gnu.org/copyleft/gpl.html *//*! * @file ipu_prp_vf_sdc.c * * @brief IPU Use case for PRP-VF * * @ingroup IPU */#include "mxc_v4l2_capture.h"#include <asm/arch/ipu.h>#include "ipu_prp_sw.h"#include <linux/dma-mapping.h>/* * Function definitions *//*! * prpvf_start - start the vf task * * @param private    cam_data * mxc v4l2 main structure * */static int prpvf_start(void *private){	cam_data *cam = (cam_data *) private;	ipu_channel_params_t vf;	u32 format = IPU_PIX_FMT_RGB565;	u32 size = 2;	int err = 0;	if (!cam) {		printk(KERN_ERR "private is NULL\n");		return -EIO;	}	if (cam->overlay_active == true) {		pr_debug("already started.\n");		return 0;	}	memset(&vf, 0, sizeof(ipu_channel_params_t));	ipu_csi_get_window_size(&vf.csi_prp_vf_mem.in_width,				&vf.csi_prp_vf_mem.in_height);	vf.csi_prp_vf_mem.in_pixel_fmt = IPU_PIX_FMT_UYVY;	vf.csi_prp_vf_mem.out_width = cam->win.w.width;	vf.csi_prp_vf_mem.out_height = cam->win.w.height;	if (cam->rotation >= IPU_ROTATE_90_RIGHT) {		vf.csi_prp_vf_mem.out_width = cam->win.w.height;		vf.csi_prp_vf_mem.out_height = cam->win.w.width;	}	vf.csi_prp_vf_mem.out_pixel_fmt = format;	size = cam->win.w.width * cam->win.w.height * size;	//ipu_uninit_channel(CSI_PRP_VF_MEM);	err = ipu_init_channel(CSI_PRP_VF_MEM, &vf);	if (err != 0)		goto out_4;	ipu_csi_enable_mclk(CSI_MCLK_VF, true, true);	if (cam->vf_bufs_vaddr[0]) {		dma_free_coherent(0, cam->vf_bufs_size[0],				  cam->vf_bufs_vaddr[0],				  (dma_addr_t) cam->vf_bufs[0]);	}	if (cam->vf_bufs_vaddr[1]) {		dma_free_coherent(0, cam->vf_bufs_size[1],				  cam->vf_bufs_vaddr[1],				  (dma_addr_t) cam->vf_bufs[1]);	}	cam->vf_bufs_size[0] = size;	cam->vf_bufs_vaddr[0] = (void *)dma_alloc_coherent(0,							   cam->vf_bufs_size[0],							   (dma_addr_t *) &							   cam->vf_bufs[0],							   GFP_DMA |							   GFP_KERNEL);	if (cam->vf_bufs_vaddr[0] == NULL) {		printk(KERN_ERR "Error to allocate vf buffer\n");		err = -ENOMEM;		goto out_3;	}	cam->vf_bufs_size[1] = size;	cam->vf_bufs_vaddr[1] = (void *)dma_alloc_coherent(0,							   cam->vf_bufs_size[1],							   (dma_addr_t *) &							   cam->vf_bufs[1],							   GFP_DMA |							   GFP_KERNEL);	if (cam->vf_bufs_vaddr[1] == NULL) {		printk(KERN_ERR "Error to allocate vf buffer\n");		err = -ENOMEM;		goto out_3;	}	pr_debug("vf_bufs %x %x\n", cam->vf_bufs[0], cam->vf_bufs[1]);	if (cam->rotation >= IPU_ROTATE_90_RIGHT) {		err = ipu_init_channel_buffer(CSI_PRP_VF_MEM, IPU_OUTPUT_BUFFER,					      format,					      vf.csi_prp_vf_mem.out_width,					      vf.csi_prp_vf_mem.out_height,					      vf.csi_prp_vf_mem.out_width,					      IPU_ROTATE_NONE, cam->vf_bufs[0],					      cam->vf_bufs[1], 0, 0);		if (err != 0) {			goto out_3;		}		if (cam->rot_vf_bufs[0]) {			dma_free_coherent(0, cam->rot_vf_buf_size[0],					  cam->rot_vf_bufs_vaddr[0],					  (dma_addr_t) cam->rot_vf_bufs[0]);			cam->rot_vf_bufs_vaddr[0] = NULL;			cam->rot_vf_bufs[0] = 0;		}		if (cam->rot_vf_bufs[1]) {			dma_free_coherent(0, cam->rot_vf_buf_size[1],					  cam->rot_vf_bufs_vaddr[1],					  (dma_addr_t) cam->rot_vf_bufs[1]);			cam->rot_vf_bufs_vaddr[1] = NULL;			cam->rot_vf_bufs[1] = 0;		}		cam->rot_vf_buf_size[0] = PAGE_ALIGN(size);		cam->rot_vf_bufs_vaddr[0] = (void *)dma_alloc_coherent(0,								       cam->								       rot_vf_buf_size								       [0],								       &cam->								       rot_vf_bufs								       [0],								       GFP_DMA |								       GFP_KERNEL);		if (cam->rot_vf_bufs_vaddr[0] == NULL) {			printk(KERN_ERR "alloc rot_vf_bufs.\n");			err = -ENOMEM;			goto out_3;		}		cam->rot_vf_buf_size[1] = PAGE_ALIGN(size);		cam->rot_vf_bufs_vaddr[1] = (void *)dma_alloc_coherent(0,								       cam->								       rot_vf_buf_size								       [0],								       &cam->								       rot_vf_bufs								       [1],								       GFP_DMA |								       GFP_KERNEL);		if (cam->rot_vf_bufs_vaddr[1] == NULL) {			printk(KERN_ERR "alloc rot_vf_bufs.\n");			err = -ENOMEM;			goto out_3;		}		pr_debug("rot_vf_bufs %x %x\n", cam->rot_vf_bufs[0],			 cam->rot_vf_bufs[1]);		//ipu_uninit_channel(MEM_ROT_VF_MEM);		err = ipu_init_channel(MEM_ROT_VF_MEM, NULL);		if (err != 0) {			printk(KERN_ERR "Error MEM_ROT_VF_MEM channel\n");			goto out_3;		}		err = ipu_init_channel_buffer(MEM_ROT_VF_MEM, IPU_INPUT_BUFFER,					      format,					      vf.csi_prp_vf_mem.out_width,					      vf.csi_prp_vf_mem.out_height,					      vf.csi_prp_vf_mem.out_width,					      cam->rotation, cam->vf_bufs[0],					      cam->vf_bufs[1], 0, 0);		if (err != 0) {			printk(KERN_ERR "Error MEM_ROT_VF_MEM input buffer\n");			goto out_3;		}		err = ipu_init_channel_buffer(MEM_ROT_VF_MEM, IPU_OUTPUT_BUFFER,					      format,					      vf.csi_prp_vf_mem.out_height,					      vf.csi_prp_vf_mem.out_width,					      vf.csi_prp_vf_mem.out_height,					      IPU_ROTATE_NONE,					      cam->rot_vf_bufs[0],					      cam->rot_vf_bufs[1], 0, 0);		if (err != 0) {			printk(KERN_ERR "Error MEM_ROT_VF_MEM output buffer\n");			goto out_2;		}		err = ipu_link_channels(CSI_PRP_VF_MEM, MEM_ROT_VF_MEM);		if (err < 0) {			printk(KERN_ERR			       "Error link CSI_PRP_VF_MEM-MEM_ROT_VF_MEM\n");			goto out_2;		}		//ipu_uninit_channel(MEM_SDC_FG);		err = ipu_init_channel(MEM_SDC_FG, NULL);		if (err != 0)			goto out_2;		ipu_sdc_set_window_pos(MEM_SDC_FG, cam->win.w.left,				       cam->win.w.top);		err = ipu_init_channel_buffer(MEM_SDC_FG, IPU_INPUT_BUFFER,					      format,					      vf.csi_prp_vf_mem.out_height,					      vf.csi_prp_vf_mem.out_width,					      vf.csi_prp_vf_mem.out_height,					      IPU_ROTATE_NONE,					      cam->rot_vf_bufs[0],					      cam->rot_vf_bufs[1], 0, 0);		if (err != 0) {			printk(KERN_ERR "Error initializing SDC FG buffer\n");			goto out_2;		}		err = ipu_link_channels(MEM_ROT_VF_MEM, MEM_SDC_FG);		if (err < 0) {			printk(KERN_ERR			       "Error link MEM_ROT_VF_MEM-MEM_SDC_FG\n");			goto out_1;		}		ipu_enable_channel(CSI_PRP_VF_MEM);		ipu_enable_channel(MEM_ROT_VF_MEM);		ipu_enable_channel(MEM_SDC_FG);		ipu_select_buffer(CSI_PRP_VF_MEM, IPU_OUTPUT_BUFFER, 0);		ipu_select_buffer(CSI_PRP_VF_MEM, IPU_OUTPUT_BUFFER, 1);		ipu_select_buffer(MEM_ROT_VF_MEM, IPU_OUTPUT_BUFFER, 0);		ipu_select_buffer(MEM_ROT_VF_MEM, IPU_OUTPUT_BUFFER, 1);	} else {		err = ipu_init_channel_buffer(CSI_PRP_VF_MEM, IPU_OUTPUT_BUFFER,					      format, cam->win.w.width,					      cam->win.w.height,					      cam->win.w.width, cam->rotation,					      cam->vf_bufs[0], cam->vf_bufs[1],					      0, 0);		if (err != 0) {			printk(KERN_ERR "Error initializing CSI_PRP_VF_MEM\n");			goto out_4;		}		//ipu_uninit_channel(MEM_SDC_FG);		err = ipu_init_channel(MEM_SDC_FG, NULL);		if (err != 0)			goto out_3;		ipu_sdc_set_window_pos(MEM_SDC_FG, cam->win.w.left,				       cam->win.w.top);		err = ipu_init_channel_buffer(MEM_SDC_FG,					      IPU_INPUT_BUFFER, format,					      cam->win.w.width,					      cam->win.w.height,					      cam->win.w.width, IPU_ROTATE_NONE,					      cam->vf_bufs[0], cam->vf_bufs[1],					      0, 0);		if (err != 0) {			printk(KERN_ERR "Error initializing SDC FG buffer\n");			goto out_1;		}		err = ipu_link_channels(CSI_PRP_VF_MEM, MEM_SDC_FG);		if (err < 0) {			printk(KERN_ERR "Error linking ipu channels\n");			goto out_1;		}		ipu_enable_channel(CSI_PRP_VF_MEM);		ipu_enable_channel(MEM_SDC_FG);		ipu_select_buffer(CSI_PRP_VF_MEM, IPU_OUTPUT_BUFFER, 0);		ipu_select_buffer(CSI_PRP_VF_MEM, IPU_OUTPUT_BUFFER, 1);	}	cam->overlay_active = true;	return err;      out_1:	ipu_uninit_channel(MEM_SDC_FG);      out_2:	if (cam->rotation >= IPU_ROTATE_90_RIGHT) {		ipu_uninit_channel(MEM_ROT_VF_MEM);	}      out_3:	ipu_uninit_channel(CSI_PRP_VF_MEM);      out_4:	if (cam->vf_bufs_vaddr[0]) {		dma_free_coherent(0, cam->vf_bufs_size[0],				  cam->vf_bufs_vaddr[0],				  (dma_addr_t) cam->vf_bufs[0]);		cam->vf_bufs_vaddr[0] = NULL;		cam->vf_bufs[0] = 0;	}	if (cam->vf_bufs_vaddr[1]) {		dma_free_coherent(0, cam->vf_bufs_size[1],				  cam->vf_bufs_vaddr[1],				  (dma_addr_t) cam->vf_bufs[1]);		cam->vf_bufs_vaddr[1] = NULL;		cam->vf_bufs[1] = 0;	}	if (cam->rot_vf_bufs_vaddr[0]) {		dma_free_coherent(0, cam->rot_vf_buf_size[0],				  cam->rot_vf_bufs_vaddr[0],				  (dma_addr_t) cam->rot_vf_bufs[0]);		cam->rot_vf_bufs_vaddr[0] = NULL;		cam->rot_vf_bufs[0] = 0;	}	if (cam->rot_vf_bufs_vaddr[1]) {		dma_free_coherent(0, cam->rot_vf_buf_size[1],				  cam->rot_vf_bufs_vaddr[1],				  (dma_addr_t) cam->rot_vf_bufs[1]);		cam->rot_vf_bufs_vaddr[1] = NULL;		cam->rot_vf_bufs[1] = 0;	}	return err;}/*! * prpvf_stop - stop the vf task * * @param private    cam_data * mxc v4l2 main structure * */static int prpvf_stop(void *private){	cam_data *cam = (cam_data *) private;	int err = 0;	if (cam->overlay_active == false)		return 0;	if (cam->rotation >= IPU_ROTATE_90_RIGHT) {		ipu_unlink_channels(CSI_PRP_VF_MEM, MEM_ROT_VF_MEM);		ipu_unlink_channels(MEM_ROT_VF_MEM, MEM_SDC_FG);	} else {		ipu_unlink_channels(CSI_PRP_VF_MEM, MEM_SDC_FG);	}	ipu_disable_channel(MEM_SDC_FG, true);	ipu_disable_channel(CSI_PRP_VF_MEM, true);	ipu_uninit_channel(CSI_PRP_VF_MEM);	if (cam->rotation >= IPU_ROTATE_90_RIGHT) {		ipu_uninit_channel(MEM_ROT_VF_MEM);	}	ipu_uninit_channel(MEM_SDC_FG);	ipu_csi_enable_mclk(CSI_MCLK_VF, false, false);	if (cam->rotation >= IPU_ROTATE_90_RIGHT) {		ipu_disable_channel(MEM_ROT_VF_MEM, true);	}	if (cam->vf_bufs_vaddr[0]) {		dma_free_coherent(0, cam->vf_bufs_size[0],				  cam->vf_bufs_vaddr[0],				  (dma_addr_t) cam->vf_bufs[0]);		cam->vf_bufs_vaddr[0] = NULL;		cam->vf_bufs[0] = 0;	}	if (cam->vf_bufs_vaddr[1]) {		dma_free_coherent(0, cam->vf_bufs_size[1],				  cam->vf_bufs_vaddr[1],				  (dma_addr_t) cam->vf_bufs[1]);		cam->vf_bufs_vaddr[1] = NULL;		cam->vf_bufs[1] = 0;	}	if (cam->rot_vf_bufs_vaddr[0]) {		dma_free_coherent(0, cam->rot_vf_buf_size[0],				  cam->rot_vf_bufs_vaddr[0],				  (dma_addr_t) cam->rot_vf_bufs[0]);		cam->rot_vf_bufs_vaddr[0] = NULL;		cam->rot_vf_bufs[0] = 0;	}	if (cam->rot_vf_bufs_vaddr[1]) {		dma_free_coherent(0, cam->rot_vf_buf_size[1],				  cam->rot_vf_bufs_vaddr[1],				  (dma_addr_t) cam->rot_vf_bufs[1]);		cam->rot_vf_bufs_vaddr[1] = NULL;		cam->rot_vf_bufs[1] = 0;	}	cam->overlay_active = false;	return err;}/*! * function to select PRP-VF as the working path * * @param private    cam_data * mxc v4l2 main structure * * @return  status */int prp_vf_sdc_select(void *private){	cam_data *cam;	int err = 0;	if (private) {		cam = (cam_data *) private;		cam->vf_start_sdc = prpvf_start;		cam->vf_stop_sdc = prpvf_stop;		cam->overlay_active = false;	} else		err = -EIO;	return err;}/*! * function to de-select PRP-VF as the working path * * @param private    cam_data * mxc v4l2 main structure * * @return  int */int prp_vf_sdc_deselect(void *private){	cam_data *cam;	int err = 0;	err = prpvf_stop(private);	if (private) {		cam = (cam_data *) private;		cam->vf_start_sdc = NULL;		cam->vf_stop_sdc = NULL;	}	return err;}/*! * Init viewfinder task. * * @return  Error code indicating success or failure */__init int prp_vf_sdc_init(void){	return 0;}/*! * Deinit viewfinder task. * * @return  Error code indicating success or failure */void __exit prp_vf_sdc_exit(void){}module_init(prp_vf_sdc_init);module_exit(prp_vf_sdc_exit);EXPORT_SYMBOL(prp_vf_sdc_select);EXPORT_SYMBOL(prp_vf_sdc_deselect);MODULE_AUTHOR("Freescale Semiconductor, Inc.");MODULE_DESCRIPTION("IPU PRP VF SDC Driver");MODULE_LICENSE("GPL");

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线看日本不卡| 一区二区三区国产精品| 欧美a级一区二区| 日韩一级片在线播放| 美国av一区二区| 久久久久久99久久久精品网站| 国产福利一区二区| 亚洲免费在线看| 欧美日韩一区二区三区高清| 日韩国产一区二| 久久久国产综合精品女国产盗摄| 豆国产96在线|亚洲| 一区二区三区国产精华| 欧美一区二区三区不卡| 国产99久久久国产精品潘金 | 久久99精品一区二区三区三区| 精品国产99国产精品| 不卡av免费在线观看| 亚洲一二三四在线| 欧美v国产在线一区二区三区| 成人亚洲一区二区一| 亚洲成人av免费| 国产日韩av一区| 91福利精品视频| 狠狠久久亚洲欧美| 亚洲黄色尤物视频| 精品欧美一区二区三区精品久久| 不卡的av中国片| 美国欧美日韩国产在线播放| 中文字幕亚洲一区二区av在线 | 成人黄色一级视频| 天天综合天天综合色| 国产女人18毛片水真多成人如厕 | 国产成人亚洲综合a∨婷婷| 亚洲图片激情小说| 欧美成人艳星乳罩| 在线精品观看国产| 懂色av中文一区二区三区| 偷拍一区二区三区四区| 欧美国产精品久久| 91精品国产aⅴ一区二区| 99精品欧美一区二区蜜桃免费 | 免费精品99久久国产综合精品| 亚洲国产精品精华液ab| 91精品国产高清一区二区三区| 99国产精品久久久| 国产精品资源站在线| 日本视频在线一区| 一区二区三区在线不卡| 亚洲国产精品av| ww亚洲ww在线观看国产| 欧美日韩综合在线免费观看| 国产a区久久久| 激情文学综合网| 男男gaygay亚洲| 亚洲成人久久影院| 一区二区三区在线高清| 中文字幕一区二区视频| 久久亚洲二区三区| 日韩精品中文字幕一区二区三区| 欧美色图一区二区三区| 91丨porny丨中文| 成熟亚洲日本毛茸茸凸凹| 韩国一区二区视频| 美国十次综合导航| 男人的j进女人的j一区| 三级不卡在线观看| 午夜日韩在线观看| 偷拍一区二区三区| 图片区日韩欧美亚洲| 亚洲18影院在线观看| 亚洲国产欧美在线| 亚洲国产精品久久人人爱| 亚洲男女一区二区三区| 一区二区三区中文免费| 亚洲最新在线观看| 一级日本不卡的影视| 夜夜嗨av一区二区三区中文字幕| 有坂深雪av一区二区精品| 亚洲免费在线视频| 亚洲一区二区三区四区不卡| 亚洲国产精品久久久久婷婷884 | 青青青爽久久午夜综合久久午夜| 亚洲第一成人在线| 天天爽夜夜爽夜夜爽精品视频| 午夜精品久久久久久久久久| 日本午夜精品视频在线观看| 蜜桃视频一区二区三区| 狠狠色狠狠色合久久伊人| 精品综合免费视频观看| 国产高清亚洲一区| www.亚洲色图.com| 在线亚洲一区二区| 这里是久久伊人| 久久亚区不卡日本| 亚洲欧洲精品成人久久奇米网| 亚洲精品视频观看| 日韩国产在线观看一区| 国产又黄又大久久| 91亚洲精品乱码久久久久久蜜桃| 91久久精品网| 欧美成人官网二区| 中文字幕亚洲不卡| 日韩黄色在线观看| 国产成人午夜精品影院观看视频| 91亚洲国产成人精品一区二区三| 欧美日韩免费视频| 久久久久国产精品人| 亚洲精品ww久久久久久p站| 午夜视频在线观看一区| 国产成人丝袜美腿| 欧洲色大大久久| 精品精品国产高清一毛片一天堂| 1024精品合集| 麻豆91精品91久久久的内涵| 99视频有精品| 欧美成人一区二区| 亚洲男人的天堂av| 国产真实乱子伦精品视频| 色婷婷综合五月| 欧美精品一区二区三区蜜臀 | 国产欧美日韩激情| 亚洲在线一区二区三区| 国产美女主播视频一区| 欧美三级电影网| 中文字幕在线一区| 免费在线看成人av| 91国产免费看| 国产欧美精品一区二区色综合朱莉 | 日韩精品一二三四| av网站一区二区三区| 欧美一级理论片| 亚洲免费观看在线观看| 国产乱人伦偷精品视频不卡| 欧美日韩一区国产| 国产精品免费丝袜| 久久99国产精品久久99| 欧美日韩久久久久久| 成人欧美一区二区三区| 国产盗摄视频一区二区三区| 91精品国产欧美一区二区18| 亚洲人快播电影网| 成人免费视频视频| 亚洲精品一区二区三区福利| 日韩激情在线观看| 欧美色偷偷大香| 亚洲激情图片qvod| 99re在线精品| 中文字幕乱码日本亚洲一区二区| 久久疯狂做爰流白浆xx| 91精品婷婷国产综合久久| 亚洲成人资源网| 欧美亚洲一区三区| 一区二区三区日本| 91久久精品日日躁夜夜躁欧美| 国产精品久久久久影院色老大| 国产呦精品一区二区三区网站| 欧美一区二区三区公司| 日韩高清不卡在线| 制服丝袜亚洲网站| 亚洲va在线va天堂| 欧美系列亚洲系列| 亚洲图片欧美综合| 欧美日韩免费观看一区二区三区| 夜夜亚洲天天久久| 欧美综合一区二区| 亚洲国产一区二区在线播放| 久久国产婷婷国产香蕉| 精品国产伦一区二区三区观看体验| 日韩成人伦理电影在线观看| 91精品在线免费| 看电影不卡的网站| 国产亚洲综合在线| 成人精品亚洲人成在线| 综合久久久久久| 在线观看日韩电影| 污片在线观看一区二区| 日韩欧美另类在线| 国产一区在线不卡| 国产精品丝袜在线| 色婷婷综合久久久中文一区二区| 一区二区三区免费网站| 欧美视频在线观看一区二区| 日韩av电影免费观看高清完整版 | 国内久久精品视频| 国产亚洲成av人在线观看导航 | 有坂深雪av一区二区精品| 在线观看av一区| 美女看a上一区| 久久久www免费人成精品| 99视频在线精品| 日韩中文字幕一区二区三区| 欧美大片一区二区| www..com久久爱| 亚洲第一二三四区| 久久精品日产第一区二区三区高清版| 成人av电影在线| 肉色丝袜一区二区| 中文在线资源观看网站视频免费不卡| 色综合中文综合网|