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

📄 dscore.c

📁 LINUX 2.6.17.4的源码
💻 C
📖 第 1 页 / 共 2 页
字号:
{	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;}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;}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);}#if 0int 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;}#endif  /*  0  */static 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, le16_to_cpu(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;}static 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)) {		printk(KERN_INFO "Waiting for DS to become free: refcnt=%d.\n",				atomic_read(&dev->refcnt));		if (msleep_interruptible(1000))			flush_signals(current);	}	usb_put_dev(dev->udev);	kfree(dev);	ds_dev = NULL;}static 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;}static 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_reset);EXPORT_SYMBOL(ds_get_device);EXPORT_SYMBOL(ds_put_device);/* * This functions can be used for EEPROM programming, * when driver will be included into mainline this will * require uncommenting. */#if 0EXPORT_SYMBOL(ds_start_pulse);EXPORT_SYMBOL(ds_set_speed);EXPORT_SYMBOL(ds_detect);EXPORT_SYMBOL(ds_stop_pulse);EXPORT_SYMBOL(ds_search);#endif

⌨️ 快捷键说明

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