CLOUDSTACK-7072. Volume attachment fails with 'A specified parameter was not 
correct' error.
[VMware] While attaching a new disk to an instance, the unit number on the 
controller key should be the lowest unit number on the key that is not in use.
Instead of a number that is 1 digit higher the highest unit number that is 
currently in use.


Project: http://git-wip-us.apache.org/repos/asf/cloudstack/repo
Commit: http://git-wip-us.apache.org/repos/asf/cloudstack/commit/4be369c9
Tree: http://git-wip-us.apache.org/repos/asf/cloudstack/tree/4be369c9
Diff: http://git-wip-us.apache.org/repos/asf/cloudstack/diff/4be369c9

Branch: refs/heads/vpc-toolkit-hugo
Commit: 4be369c94c4c9a2609f922fa414178191753c8bd
Parents: 8e11285
Author: Likitha Shetty <likitha.she...@citrix.com>
Authored: Mon Jun 23 15:30:37 2014 +0530
Committer: Likitha Shetty <likitha.she...@citrix.com>
Committed: Mon Jul 7 17:40:06 2014 +0530

----------------------------------------------------------------------
 .../cloud/hypervisor/vmware/mo/VirtualMachineMO.java | 15 ++++++++++-----
 1 file changed, 10 insertions(+), 5 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/cloudstack/blob/4be369c9/vmware-base/src/com/cloud/hypervisor/vmware/mo/VirtualMachineMO.java
----------------------------------------------------------------------
diff --git 
a/vmware-base/src/com/cloud/hypervisor/vmware/mo/VirtualMachineMO.java 
b/vmware-base/src/com/cloud/hypervisor/vmware/mo/VirtualMachineMO.java
index 263c656..b5b9a5e 100644
--- a/vmware-base/src/com/cloud/hypervisor/vmware/mo/VirtualMachineMO.java
+++ b/vmware-base/src/com/cloud/hypervisor/vmware/mo/VirtualMachineMO.java
@@ -2295,17 +2295,22 @@ public class VirtualMachineMO extends BaseMO {
     public int getNextDeviceNumber(int controllerKey) throws Exception {
         List<VirtualDevice> devices = 
_context.getVimClient().getDynamicProperty(_mor, "config.hardware.device");
 
-        int deviceNumber = -1;
+        List<Integer> existingUnitNumbers = new ArrayList<Integer>();
+        int deviceNumber = 0;
         if (devices != null && devices.size() > 0) {
             for (VirtualDevice device : devices) {
                 if (device.getControllerKey() != null && 
device.getControllerKey().intValue() == controllerKey) {
-                    if (device.getUnitNumber() != null && 
device.getUnitNumber().intValue() > deviceNumber) {
-                        deviceNumber = device.getUnitNumber().intValue();
-                    }
+                    existingUnitNumbers.add(device.getUnitNumber());
                 }
             }
         }
-        return ++deviceNumber;
+        while (true) {
+            if (!existingUnitNumbers.contains(Integer.valueOf(deviceNumber))) {
+                break;
+            }
+            ++deviceNumber;
+        }
+        return deviceNumber;
     }
 
     private List<VirtualDevice> getNicDevices(boolean sorted) throws Exception 
{

Reply via email to