Dmsg1(200, "Device %s is not an autochanger\n", dev->print_name());
return 0;
}
+
+ /* An empty ChangerCommand => virtual disk autochanger */
+ if (dcr->device->changer_command && dcr->device->changer_command[0] == 0) {
+ return 1; /* nothing to load */
+ }
+
slot = dcr->VolCatInfo.InChanger ? dcr->VolCatInfo.Slot : 0;
/*
* Handle autoloaders here. If we cannot autoload it, we
Jmsg(jcr, M_FATAL, 0, _("3992 Missing Changer command.\n"));
return -1;
}
- if (dev->Slot >0) {
+ if (dev->Slot > 0) {
return dev->Slot;
}
+ /* Virtual disk autochanger */
+ if (dcr->device->changer_command[0] ==0) {
+ return 1;
+ }
/* Find out what is loaded, zero means device is unloaded */
changer = get_pool_memory(PM_FNAME);
}
break;
}
- P(dev->mutex);
+ dev->lock();
if (dev->is_busy()) {
Jmsg(jcr, M_WARNING, 0, _("Volume \"%s\" is in use by device %s\n"),
dcr->VolumeName, dev->print_name());
Dmsg4(100, "Vol %s for dev=%s is busy dev=%s slot=%d\n",
dcr->VolumeName, dcr->dev->print_name(), dev->print_name(), slot);
Dmsg2(100, "num_writ=%d reserv=%d\n", dev->num_writers, dev->reserved_device);
- V(dev->mutex);
+ dev->unlock();
return false;
}
Dmsg0(100, "Slot unloaded\n");
}
unlock_changer(dcr);
- V(dev->mutex);
+ dev->unlock();
free_pool_memory(changer_cmd);
return ok;
}