dscore.c

来自「Linux Kernel 2.6.9 for OMAP1710」· C语言 代码 · 共 784 行 · 第 1/2 页

C
784
字号
	mdelay(delay);	ds_wait_status(dev, &st);		return err;}int ds_touch_bit(struct ds_device *dev, u8 bit, u8 *tbit){	int err, count;	struct ds_status st;	u16 value = (COMM_BIT_IO | COMM_IM) | ((bit) ? COMM_D : 0);	u16 cmd;		err = ds_send_control(dev, value, 0);	if (err)		return err;	count = 0;	do {		err = ds_wait_status(dev, &st);		if (err)			return err;		cmd = st.command0 | (st.command1 << 8);	} while (cmd != value && ++count < 10);	if (err < 0 || count >= 10) {		printk(KERN_ERR "Failed to obtain status.\n");		return -EINVAL;	}	err = ds_recv_data(dev, tbit, sizeof(*tbit));	if (err < 0)		return err;	return 0;}int ds_write_bit(struct ds_device *dev, u8 bit){	int err;	struct ds_status st;		err = ds_send_control(dev, COMM_BIT_IO | COMM_IM | (bit) ? COMM_D : 0, 0);	if (err)		return err;	ds_wait_status(dev, &st);	return 0;}int ds_write_byte(struct ds_device *dev, u8 byte){	int err;	struct ds_status st;	u8 rbyte;		err = ds_send_control(dev, COMM_BYTE_IO | COMM_IM | COMM_SPU, byte);	if (err)		return err;	err = ds_wait_status(dev, &st);	if (err)		return err;			err = ds_recv_data(dev, &rbyte, sizeof(rbyte));	if (err < 0)		return err;		ds_start_pulse(dev, PULLUP_PULSE_DURATION);	return !(byte == rbyte);}int ds_read_bit(struct ds_device *dev, u8 *bit){	int err;	err = ds_send_control_mode(dev, MOD_PULSE_EN, PULSE_SPUE);	if (err)		return err;		err = ds_send_control(dev, COMM_BIT_IO | COMM_IM | COMM_SPU | COMM_D, 0);	if (err)		return err;		err = ds_recv_data(dev, bit, sizeof(*bit));	if (err < 0)		return err;	return 0;}int ds_read_byte(struct ds_device *dev, u8 *byte){	int err;	struct ds_status st;	err = ds_send_control(dev, COMM_BYTE_IO | COMM_IM , 0xff);	if (err)		return err;	ds_wait_status(dev, &st);		err = ds_recv_data(dev, byte, sizeof(*byte));	if (err < 0)		return err;	return 0;}inline int ds_read_block(struct ds_device *dev, u8 *buf, int len){	struct ds_status st;	int err;	if (len > 64*1024)		return -E2BIG;	memset(buf, 0xFF, len);		err = ds_send_data(dev, buf, len);	if (err < 0)		return err;		err = ds_send_control(dev, COMM_BLOCK_IO | COMM_IM | COMM_SPU, len);	if (err)		return err;	ds_wait_status(dev, &st);		memset(buf, 0x00, len);	err = ds_recv_data(dev, buf, len);	return err;}inline int ds_write_block(struct ds_device *dev, u8 *buf, int len){	int err;	struct ds_status st;		err = ds_send_data(dev, buf, len);	if (err < 0)		return err;		ds_wait_status(dev, &st);	err = ds_send_control(dev, COMM_BLOCK_IO | COMM_IM | COMM_SPU, len);	if (err)		return err;	ds_wait_status(dev, &st);	err = ds_recv_data(dev, buf, len);	if (err < 0)		return err;	ds_start_pulse(dev, PULLUP_PULSE_DURATION);		return !(err == len);}int ds_search(struct ds_device *dev, u64 init, u64 *buf, u8 id_number, int conditional_search){	int err;	u16 value, index;	struct ds_status st;	memset(buf, 0, sizeof(buf));		err = ds_send_data(ds_dev, (unsigned char *)&init, 8);	if (err)		return err;		ds_wait_status(ds_dev, &st);	value = COMM_SEARCH_ACCESS | COMM_IM | COMM_SM | COMM_F | COMM_RTS;	index = (conditional_search ? 0xEC : 0xF0) | (id_number << 8);	err = ds_send_control(ds_dev, value, index);	if (err)		return err;	ds_wait_status(ds_dev, &st);	err = ds_recv_data(ds_dev, (unsigned char *)buf, 8*id_number);	if (err < 0)		return err;	return err/8;}int ds_match_access(struct ds_device *dev, u64 init){	int err;	struct ds_status st;	err = ds_send_data(dev, (unsigned char *)&init, sizeof(init));	if (err)		return err;		ds_wait_status(dev, &st);	err = ds_send_control(dev, COMM_MATCH_ACCESS | COMM_IM | COMM_RST, 0x0055);	if (err)		return err;	ds_wait_status(dev, &st);	return 0;}int ds_set_path(struct ds_device *dev, u64 init){	int err;	struct ds_status st;	u8 buf[9];	memcpy(buf, &init, 8);	buf[8] = BRANCH_MAIN;		err = ds_send_data(dev, buf, sizeof(buf));	if (err)		return err;		ds_wait_status(dev, &st);	err = ds_send_control(dev, COMM_SET_PATH | COMM_IM | COMM_RST, 0);	if (err)		return err;	ds_wait_status(dev, &st);	return 0;}int ds_probe(struct usb_interface *intf, const struct usb_device_id *udev_id){	struct usb_device *udev = interface_to_usbdev(intf);	struct usb_endpoint_descriptor *endpoint;	struct usb_host_interface *iface_desc;	int i, err;	ds_dev = kmalloc(sizeof(struct ds_device), GFP_KERNEL);	if (!ds_dev) {		printk(KERN_INFO "Failed to allocate new DS9490R structure.\n");		return -ENOMEM;	}	ds_dev->udev = usb_get_dev(udev);	usb_set_intfdata(intf, ds_dev);	err = usb_set_interface(ds_dev->udev, intf->altsetting[0].desc.bInterfaceNumber, 3);	if (err) {		printk(KERN_ERR "Failed to set alternative setting 3 for %d interface: err=%d.\n",				intf->altsetting[0].desc.bInterfaceNumber, err);		return err;	}	err = usb_reset_configuration(ds_dev->udev);	if (err) {		printk(KERN_ERR "Failed to reset configuration: err=%d.\n", err);		return err;	}		iface_desc = &intf->altsetting[0];	if (iface_desc->desc.bNumEndpoints != NUM_EP-1) {		printk(KERN_INFO "Num endpoints=%d. It is not DS9490R.\n", iface_desc->desc.bNumEndpoints);		return -ENODEV;	}	atomic_set(&ds_dev->refcnt, 0);	memset(ds_dev->ep, 0, sizeof(ds_dev->ep));		/*	 * This loop doesn'd show control 0 endpoint, 	 * so we will fill only 1-3 endpoints entry.	 */	for (i = 0; i < iface_desc->desc.bNumEndpoints; ++i) {		endpoint = &iface_desc->endpoint[i].desc;		ds_dev->ep[i+1] = endpoint->bEndpointAddress;				printk("%d: addr=%x, size=%d, dir=%s, type=%x\n",			i, endpoint->bEndpointAddress, endpoint->wMaxPacketSize,			(endpoint->bEndpointAddress & USB_DIR_IN)?"IN":"OUT",			endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK);	}	#if 0	{		int err, i;		u64 buf[3];		u64 init=0xb30000002078ee81ull;		struct ds_status st;				ds_reset(ds_dev, &st);		err = ds_search(ds_dev, init, buf, 3, 0);		if (err < 0)			return err;		for (i=0; i<err; ++i)			printk("%d: %llx\n", i, buf[i]);				printk("Resetting...\n");			ds_reset(ds_dev, &st);		printk("Setting path for %llx.\n", init);		err = ds_set_path(ds_dev, init);		if (err)			return err;		printk("Calling MATCH_ACCESS.\n");		err = ds_match_access(ds_dev, init);		if (err)			return err;		printk("Searching the bus...\n");		err = ds_search(ds_dev, init, buf, 3, 0);		printk("ds_search() returned %d\n", err);				if (err < 0)			return err;		for (i=0; i<err; ++i)			printk("%d: %llx\n", i, buf[i]);				return 0;	}#endif	return 0;}void ds_disconnect(struct usb_interface *intf){	struct ds_device *dev;		dev = usb_get_intfdata (intf);	usb_set_intfdata (intf, NULL);	while(atomic_read(&dev->refcnt))		schedule_timeout(HZ);	usb_put_dev(dev->udev);	kfree(dev);	ds_dev = NULL;}int ds_init(void){	int err;	err = usb_register(&ds_driver);	if (err) {		printk(KERN_INFO "Failed to register DS9490R USB device: err=%d.\n", err);		return err;	}	return 0;}void ds_fini(void){	usb_deregister(&ds_driver);}module_init(ds_init);module_exit(ds_fini);MODULE_LICENSE("GPL");MODULE_AUTHOR("Evgeniy Polyakov <johnpol@2ka.mipt.ru>");EXPORT_SYMBOL(ds_touch_bit);EXPORT_SYMBOL(ds_read_byte);EXPORT_SYMBOL(ds_read_bit);EXPORT_SYMBOL(ds_read_block);EXPORT_SYMBOL(ds_write_byte);EXPORT_SYMBOL(ds_write_bit);EXPORT_SYMBOL(ds_write_block);EXPORT_SYMBOL(ds_start_pulse);EXPORT_SYMBOL(ds_set_speed);EXPORT_SYMBOL(ds_reset);EXPORT_SYMBOL(ds_detect);EXPORT_SYMBOL(ds_stop_pulse);EXPORT_SYMBOL(ds_send_data);EXPORT_SYMBOL(ds_recv_data);EXPORT_SYMBOL(ds_recv_status);EXPORT_SYMBOL(ds_search);EXPORT_SYMBOL(ds_get_device);EXPORT_SYMBOL(ds_put_device);

⌨️ 快捷键说明

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