⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cpia.c

📁 优龙2410linux2.6.8内核源代码
💻 C
📖 第 1 页 / 共 5 页
字号:
		if((command_flags & COMMAND_SETEXPOSURE) &&		   new_params.exposure.expMode == 2)			cam->exposure_status = EXPOSURE_NORMAL;		memcpy(&cam->params, &new_params, sizeof(struct cam_params));		cam->mainsFreq = new_mains;		cam->cmd_queue |= command_flags;		retval = size;	} else		DBG("error: %d\n", retval);		up(&cam->param_lock);	out:	free_page((unsigned long)page); 	return retval;}static void create_proc_cpia_cam(struct cam_data *cam){	char name[7];	struct proc_dir_entry *ent;		if (!cpia_proc_root || !cam)		return;	sprintf(name, "video%d", cam->vdev.minor);		ent = create_proc_entry(name, S_IFREG|S_IRUGO|S_IWUSR, cpia_proc_root);	if (!ent)		return;	ent->data = cam;	ent->read_proc = cpia_read_proc;	ent->write_proc = cpia_write_proc;	/* 	   size of the proc entry is 3736 bytes for the standard webcam; 	   the extra features of the QX3 microscope add 189 bytes.	   (we have not yet probed the camera to see which type it is).	*/	ent->size = 3736 + 189;	cam->proc_entry = ent;}static void destroy_proc_cpia_cam(struct cam_data *cam){	char name[7];		if (!cam || !cam->proc_entry)		return;		sprintf(name, "video%d", cam->vdev.minor);	remove_proc_entry(name, cpia_proc_root);	cam->proc_entry = NULL;}static void proc_cpia_create(void){	cpia_proc_root = create_proc_entry("cpia", S_IFDIR, NULL);	if (cpia_proc_root)		cpia_proc_root->owner = THIS_MODULE;	else		LOG("Unable to initialise /proc/cpia\n");}static void __exit proc_cpia_destroy(void){	remove_proc_entry("cpia", NULL);}#endif /* CONFIG_PROC_FS *//* ----------------------- debug functions ---------------------- */#define printstatus(cam) \  DBG("%02x %02x %02x %02x %02x %02x %02x %02x\n",\	cam->params.status.systemState, cam->params.status.grabState, \	cam->params.status.streamState, cam->params.status.fatalError, \	cam->params.status.cmdError, cam->params.status.debugFlags, \	cam->params.status.vpStatus, cam->params.status.errorCode);/* ----------------------- v4l helpers -------------------------- *//* supported frame palettes and depths */static inline int valid_mode(u16 palette, u16 depth){	return (palette == VIDEO_PALETTE_GREY && depth == 8) ||	       (palette == VIDEO_PALETTE_RGB555 && depth == 16) ||	       (palette == VIDEO_PALETTE_RGB565 && depth == 16) ||	       (palette == VIDEO_PALETTE_RGB24 && depth == 24) ||	       (palette == VIDEO_PALETTE_RGB32 && depth == 32) ||	       (palette == VIDEO_PALETTE_YUV422 && depth == 16) ||	       (palette == VIDEO_PALETTE_YUYV && depth == 16) ||	       (palette == VIDEO_PALETTE_UYVY && depth == 16);}static int match_videosize( int width, int height ){	/* return the best match, where 'best' is as always	 * the largest that is not bigger than what is requested. */	if (width>=352 && height>=288)		return VIDEOSIZE_352_288; /* CIF */	if (width>=320 && height>=240)		return VIDEOSIZE_320_240; /* SIF */	if (width>=288 && height>=216)		return VIDEOSIZE_288_216;	if (width>=256 && height>=192)		return VIDEOSIZE_256_192;	if (width>=224 && height>=168)		return VIDEOSIZE_224_168;	if (width>=192 && height>=144)		return VIDEOSIZE_192_144;	if (width>=176 && height>=144)		return VIDEOSIZE_176_144; /* QCIF */	if (width>=160 && height>=120)		return VIDEOSIZE_160_120; /* QSIF */	if (width>=128 && height>=96)		return VIDEOSIZE_128_96;	if (width>=88 && height>=72)		return VIDEOSIZE_88_72;	if (width>=64 && height>=48)		return VIDEOSIZE_64_48;	if (width>=48 && height>=48)		return VIDEOSIZE_48_48;	return -1;}/* these are the capture sizes we support */static void set_vw_size(struct cam_data *cam){	/* the col/row/start/end values are the result of simple math    */	/* study the SetROI-command in cpia developers guide p 2-22      */	/* streamStartLine is set to the recommended value in the cpia   */	/*  developers guide p 3-37                                      */	switch(cam->video_size) {	case VIDEOSIZE_CIF:		cam->vw.width = 352;		cam->vw.height = 288;		cam->params.format.videoSize=VIDEOSIZE_CIF;		cam->params.roi.colStart=0;		cam->params.roi.rowStart=0;		cam->params.streamStartLine = 120;		break;	case VIDEOSIZE_SIF:		cam->vw.width = 320;		cam->vw.height = 240;		cam->params.format.videoSize=VIDEOSIZE_CIF;		cam->params.roi.colStart=2;		cam->params.roi.rowStart=6;		cam->params.streamStartLine = 120;		break;	case VIDEOSIZE_288_216:		cam->vw.width = 288;		cam->vw.height = 216;		cam->params.format.videoSize=VIDEOSIZE_CIF;		cam->params.roi.colStart=4;		cam->params.roi.rowStart=9;		cam->params.streamStartLine = 120;		break;	case VIDEOSIZE_256_192:		cam->vw.width = 256;		cam->vw.height = 192;		cam->params.format.videoSize=VIDEOSIZE_CIF;		cam->params.roi.colStart=6;		cam->params.roi.rowStart=12;		cam->params.streamStartLine = 120;		break;	case VIDEOSIZE_224_168:		cam->vw.width = 224;		cam->vw.height = 168;		cam->params.format.videoSize=VIDEOSIZE_CIF;		cam->params.roi.colStart=8;		cam->params.roi.rowStart=15;		cam->params.streamStartLine = 120;		break;	case VIDEOSIZE_192_144:		cam->vw.width = 192;		cam->vw.height = 144;		cam->params.format.videoSize=VIDEOSIZE_CIF;		cam->params.roi.colStart=10;		cam->params.roi.rowStart=18;		cam->params.streamStartLine = 120;		break;	case VIDEOSIZE_QCIF:		cam->vw.width = 176;		cam->vw.height = 144;		cam->params.format.videoSize=VIDEOSIZE_QCIF;		cam->params.roi.colStart=0;		cam->params.roi.rowStart=0;		cam->params.streamStartLine = 60;		break;	case VIDEOSIZE_QSIF:		cam->vw.width = 160;		cam->vw.height = 120;		cam->params.format.videoSize=VIDEOSIZE_QCIF;		cam->params.roi.colStart=1;		cam->params.roi.rowStart=3;		cam->params.streamStartLine = 60;		break;	case VIDEOSIZE_128_96:		cam->vw.width = 128;		cam->vw.height = 96;		cam->params.format.videoSize=VIDEOSIZE_QCIF;		cam->params.roi.colStart=3;		cam->params.roi.rowStart=6;		cam->params.streamStartLine = 60;		break;	case VIDEOSIZE_88_72:		cam->vw.width = 88;		cam->vw.height = 72;		cam->params.format.videoSize=VIDEOSIZE_QCIF;		cam->params.roi.colStart=5;		cam->params.roi.rowStart=9;		cam->params.streamStartLine = 60;		break;	case VIDEOSIZE_64_48:		cam->vw.width = 64;		cam->vw.height = 48;		cam->params.format.videoSize=VIDEOSIZE_QCIF;		cam->params.roi.colStart=7;		cam->params.roi.rowStart=12;		cam->params.streamStartLine = 60;		break;	case VIDEOSIZE_48_48:		cam->vw.width = 48;		cam->vw.height = 48;		cam->params.format.videoSize=VIDEOSIZE_QCIF;		cam->params.roi.colStart=8;		cam->params.roi.rowStart=6;		cam->params.streamStartLine = 60;		break;	default:		LOG("bad videosize value: %d\n", cam->video_size);		return;	}	if(cam->vc.width == 0)		cam->vc.width = cam->vw.width;	if(cam->vc.height == 0)		cam->vc.height = cam->vw.height;		cam->params.roi.colStart += cam->vc.x >> 3;	cam->params.roi.colEnd = cam->params.roi.colStart +	                         (cam->vc.width >> 3);	cam->params.roi.rowStart += cam->vc.y >> 2;	cam->params.roi.rowEnd = cam->params.roi.rowStart +	                         (cam->vc.height >> 2);	return;}static int allocate_frame_buf(struct cam_data *cam){	int i;	cam->frame_buf = rvmalloc(FRAME_NUM * CPIA_MAX_FRAME_SIZE);	if (!cam->frame_buf)		return -ENOBUFS;	for (i = 0; i < FRAME_NUM; i++)		cam->frame[i].data = cam->frame_buf + i * CPIA_MAX_FRAME_SIZE;	return 0;}static int free_frame_buf(struct cam_data *cam){	int i;		rvfree(cam->frame_buf, FRAME_NUM*CPIA_MAX_FRAME_SIZE);	cam->frame_buf = NULL;	for (i=0; i < FRAME_NUM; i++)		cam->frame[i].data = NULL;	return 0;}static inline void free_frames(struct cpia_frame frame[FRAME_NUM]){	int i;	for (i=0; i < FRAME_NUM; i++)		frame[i].state = FRAME_UNUSED;	return;}/********************************************************************** * * General functions * **********************************************************************//* send an arbitrary command to the camera */static int do_command(struct cam_data *cam, u16 command, u8 a, u8 b, u8 c, u8 d){	int retval, datasize;	u8 cmd[8], data[8];	switch(command) {	case CPIA_COMMAND_GetCPIAVersion:	case CPIA_COMMAND_GetPnPID:	case CPIA_COMMAND_GetCameraStatus:	case CPIA_COMMAND_GetVPVersion:		datasize=8;		break;	case CPIA_COMMAND_GetColourParams:	case CPIA_COMMAND_GetColourBalance:	case CPIA_COMMAND_GetExposure:		down(&cam->param_lock);		datasize=8;		break;	case CPIA_COMMAND_ReadMCPorts: 	case CPIA_COMMAND_ReadVCRegs:		datasize = 4;		break;	default:		datasize=0;		break;	}	cmd[0] = command>>8;	cmd[1] = command&0xff;	cmd[2] = a;	cmd[3] = b;	cmd[4] = c;	cmd[5] = d;	cmd[6] = datasize;	cmd[7] = 0;	retval = cam->ops->transferCmd(cam->lowlevel_data, cmd, data);	if (retval) {		DBG("%x - failed, retval=%d\n", command, retval);		if (command == CPIA_COMMAND_GetColourParams ||		    command == CPIA_COMMAND_GetColourBalance ||		    command == CPIA_COMMAND_GetExposure)			up(&cam->param_lock);	} else {		switch(command) {		case CPIA_COMMAND_GetCPIAVersion:			cam->params.version.firmwareVersion = data[0];			cam->params.version.firmwareRevision = data[1];			cam->params.version.vcVersion = data[2];			cam->params.version.vcRevision = data[3];			break;		case CPIA_COMMAND_GetPnPID:			cam->params.pnpID.vendor = data[0]+(((u16)data[1])<<8);			cam->params.pnpID.product = data[2]+(((u16)data[3])<<8);			cam->params.pnpID.deviceRevision =				data[4]+(((u16)data[5])<<8);			break;		case CPIA_COMMAND_GetCameraStatus:			cam->params.status.systemState = data[0];			cam->params.status.grabState = data[1];			cam->params.status.streamState = data[2];			cam->params.status.fatalError = data[3];			cam->params.status.cmdError = data[4];			cam->params.status.debugFlags = data[5];			cam->params.status.vpStatus = data[6];			cam->params.status.errorCode = data[7];			break;		case CPIA_COMMAND_GetVPVersion:			cam->params.vpVersion.vpVersion = data[0];			cam->params.vpVersion.vpRevision = data[1];			cam->params.vpVersion.cameraHeadID =				data[2]+(((u16)data[3])<<8);			break;		case CPIA_COMMAND_GetColourParams:			cam->params.colourParams.brightness = data[0];			cam->params.colourParams.contrast = data[1];			cam->params.colourParams.saturation = data[2];			up(&cam->param_lock);			break;		case CPIA_COMMAND_GetColourBalance:			cam->params.colourBalance.redGain = data[0];			cam->params.colourBalance.greenGain = data[1];			cam->params.colourBalance.blueGain = data[2];			up(&cam->param_lock);			break;		case CPIA_COMMAND_GetExposure:			cam->params.exposure.gain = data[0];			cam->params.exposure.fineExp = data[1];			cam->params.exposure.coarseExpLo = data[2];			cam->params.exposure.coarseExpHi = data[3];			cam->params.exposure.redComp = data[4];			cam->params.exposure.green1Comp = data[5];			cam->params.exposure.green2Comp = data[6];			cam->params.exposure.blueComp = data[7];			up(&cam->param_lock);			break;		case CPIA_COMMAND_ReadMCPorts: 			if (!cam->params.qx3.qx3_detected) 				break;			/* test button press */ 			cam->params.qx3.button = ((data[1] & 0x02) == 0);			if (cam->params.qx3.button) {				/* button pressed - unlock the latch */				do_command(cam,CPIA_COMMAND_WriteMCPort,3,0xDF,0xDF,0);				do_command(cam,CPIA_COMMAND_WriteMCPort,3,0xFF,0xFF,0);			}			/* test whether microscope is cradled */			cam->params.qx3.cradled = ((data[2] & 0x40) == 0);			break;		default:			break;		}	}	return retval;}/* send a command  to the camera with an additional data transaction */static int do_command_extended(struct cam_data *cam, u16 command,                               u8 a, u8 b, u8 c, u8 d,                               u8 e, u8 f, u8 g, u8 h,                               u8 i, u8 j, u8 k, u8 l){	int retval;	u8 cmd[8], data[8];	cmd[0] = command>>8;	cmd[1] = command&0xff;	cmd[2] = a;	cmd[3] = b;	cmd[4] = c;	cmd[5] = d;	cmd[6] = 8;	cmd[7] = 0;	data[0] = e;	data[1] = f;	data[2] = g;	data[3] = h;	data[4] = i;	data[5] = j;	data[6] = k;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -