VSCSILun.cpp revision 65697a26b524640b83828b715160c798c43a0424
fd9abdda70912b99b24e3bf1a38f26fde908a74cnd * Virtual SCSI driver: LUN handling
a78048ccbdb6256da15e6b0e7e95355e480c2301nd * Copyright (C) 2006-2010 Oracle Corporation
a78048ccbdb6256da15e6b0e7e95355e480c2301nd * This file is part of VirtualBox Open Source Edition (OSE), as
96ad5d81ee4a2cc66a4ae19893efc8aa6d06fae7jailletc * available from http://www.virtualbox.org. This file is free software;
a78048ccbdb6256da15e6b0e7e95355e480c2301nd * you can redistribute it and/or modify it under the terms of the GNU
a78048ccbdb6256da15e6b0e7e95355e480c2301nd * General Public License (GPL) as published by the Free Software
d29d9ab4614ff992b0e8de6e2b88d52b6f1f153erbowen * Foundation, in version 2 as it comes in the "COPYING" file of the
2e545ce2450a9953665f701bb05350f0d3f26275nd * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
d29d9ab4614ff992b0e8de6e2b88d52b6f1f153erbowen * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
a78048ccbdb6256da15e6b0e7e95355e480c2301nd/** SBC descriptor */
a78048ccbdb6256da15e6b0e7e95355e480c2301nd/** MMC descriptor */
81785f72c9d133aef57ad6b02f248345d90239aapoirier//extern PVSCSILUNDESC g_pVScsiLunTypeMmc;
a78048ccbdb6256da15e6b0e7e95355e480c2301nd * Array of supported SCSI LUN types.
a78048ccbdb6256da15e6b0e7e95355e480c2301ndVBOXDDU_DECL(int) VSCSILunCreate(PVSCSILUN phVScsiLun, VSCSILUNTYPE enmLunType,
a78048ccbdb6256da15e6b0e7e95355e480c2301nd && enmLunType < VSCSILUNTYPE_LAST, VERR_INVALID_PARAMETER);
a78048ccbdb6256da15e6b0e7e95355e480c2301nd AssertPtrReturn(pVScsiLunIoCallbacks, VERR_INVALID_PARAMETER);
a78048ccbdb6256da15e6b0e7e95355e480c2301nd for (unsigned idxLunType = 0; idxLunType < RT_ELEMENTS(g_aVScsiLunTypesSupported); idxLunType++)
6aadbc6fd703e73d1d419e9f06b84a4338c898f1maczniak if (g_aVScsiLunTypesSupported[idxLunType]->enmLunType == enmLunType)
6aadbc6fd703e73d1d419e9f06b84a4338c898f1maczniak pVScsiLunDesc = g_aVScsiLunTypesSupported[idxLunType];
a78048ccbdb6256da15e6b0e7e95355e480c2301nd pVScsiLun = (PVSCSILUNINT)RTMemAllocZ(pVScsiLunDesc->cbLun);
1f1b6bf13313fdd14a45e52e553d3ff28689b717coar pVScsiLun->pVScsiLunIoCallbacks = pVScsiLunIoCallbacks;
1f1b6bf13313fdd14a45e52e553d3ff28689b717coar int rc = vscsiLunGetFeatureFlags(pVScsiLun, &pVScsiLun->fFeatures);
1f1b6bf13313fdd14a45e52e553d3ff28689b717coar * Destroy virtual SCSI LUN.
1f1b6bf13313fdd14a45e52e553d3ff28689b717coar * @returns VBox status code.
1f1b6bf13313fdd14a45e52e553d3ff28689b717coar * @param hVScsiLun The virtual SCSI LUN handle to destroy.
1f1b6bf13313fdd14a45e52e553d3ff28689b717coar AssertReturn(!pVScsiLun->pVScsiDevice, VERR_VSCSI_LUN_ATTACHED_TO_DEVICE);
1f1b6bf13313fdd14a45e52e553d3ff28689b717coar AssertReturn(vscsiIoReqOutstandingCountGet(pVScsiLun) == 0, VERR_VSCSI_LUN_BUSY);
1f1b6bf13313fdd14a45e52e553d3ff28689b717coar int rc = pVScsiLun->pVScsiLunDesc->pfnVScsiLunDestroy(pVScsiLun);
1f1b6bf13313fdd14a45e52e553d3ff28689b717coar /* Make LUN invalid */