kfree(info);
                return -ENOMEM;
        }
+       info->hardware_device = hardware_device;
        comedi_device_init(info->device);
        spin_lock(&comedi_file_info_table_lock);
        for (i = 0; i < COMEDI_NUM_BOARD_MINORS; ++i) {
        }
 }
 
+int comedi_find_board_minor(struct device *hardware_device)
+{
+       int minor;
+       struct comedi_device_file_info *info;
+
+       for (minor = 0; minor < COMEDI_NUM_BOARD_MINORS; minor++) {
+               spin_lock(&comedi_file_info_table_lock);
+               info = comedi_file_info_table[minor];
+               if (info && info->hardware_device == hardware_device) {
+                       spin_unlock(&comedi_file_info_table_lock);
+                       return minor;
+               }
+               spin_unlock(&comedi_file_info_table_lock);
+       }
+       return -ENODEV;
+}
+
 int comedi_alloc_subdevice_minor(struct comedi_device *dev,
                                 struct comedi_subdevice *s)
 {
 
        int minor;
        struct comedi_device_file_info *dev_file_info;
        int retval;
-       unsigned *private_data = NULL;
 
-       if (!comedi_autoconfig) {
-               dev_set_drvdata(hardware_device, NULL);
+       if (!comedi_autoconfig)
                return 0;
-       }
 
        minor = comedi_alloc_board_minor(hardware_device);
        if (minor < 0)
                return minor;
 
-       private_data = kmalloc(sizeof(unsigned), GFP_KERNEL);
-       if (private_data == NULL) {
-               retval = -ENOMEM;
-               goto cleanup;
-       }
-       *private_data = minor;
-       dev_set_drvdata(hardware_device, private_data);
-
        dev_file_info = comedi_get_device_file_info(minor);
 
        memset(&it, 0, sizeof(it));
        retval = comedi_device_attach(dev_file_info->device, &it);
        mutex_unlock(&dev_file_info->device->mutex);
 
-cleanup:
-       if (retval < 0) {
-               kfree(private_data);
+       if (retval < 0)
                comedi_free_board_minor(minor);
-       }
        return retval;
 }
 
 static void comedi_auto_unconfig(struct device *hardware_device)
 {
-       unsigned *minor = (unsigned *)dev_get_drvdata(hardware_device);
-       if (minor == NULL)
-               return;
-
-       BUG_ON(*minor >= COMEDI_NUM_BOARD_MINORS);
+       int minor;
 
-       comedi_free_board_minor(*minor);
-       dev_set_drvdata(hardware_device, NULL);
-       kfree(minor);
+       if (hardware_device == NULL)
+               return;
+       minor = comedi_find_board_minor(hardware_device);
+       if (minor < 0)
+               return;
+       BUG_ON(minor >= COMEDI_NUM_BOARD_MINORS);
+       comedi_free_board_minor(minor);
 }
 
 int comedi_pci_auto_config(struct pci_dev *pcidev, struct comedi_driver *driver)
 
               struct comedi_insn *insn, unsigned int *data);
 int comedi_alloc_board_minor(struct device *hardware_device);
 void comedi_free_board_minor(unsigned minor);
+int comedi_find_board_minor(struct device *hardware_device);
 void comedi_reset_async_buf(struct comedi_async *async);
 int comedi_buf_alloc(struct comedi_device *dev, struct comedi_subdevice *s,
                     unsigned long new_size);