VirtualBox

source: vbox/trunk/src/VBox/Devices/Storage/VSCSI/VSCSILun.cpp@ 64402

Last change on this file since 64402 was 64064, checked in by vboxsync, 8 years ago

VSCSI: Port missing commands over from the AHCI controller

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.1 KB
Line 
1/* $Id: VSCSILun.cpp 64064 2016-09-28 08:51:22Z vboxsync $ */
2/** @file
3 * Virtual SCSI driver: LUN handling
4 */
5
6/*
7 * Copyright (C) 2006-2016 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17#define LOG_GROUP LOG_GROUP_VSCSI
18#include <VBox/log.h>
19#include <VBox/err.h>
20#include <VBox/types.h>
21#include <VBox/vscsi.h>
22#include <iprt/assert.h>
23#include <iprt/mem.h>
24
25#include "VSCSIInternal.h"
26
27/** SBC descriptor */
28extern VSCSILUNDESC g_VScsiLunTypeSbc;
29/** MMC descriptor */
30extern VSCSILUNDESC g_VScsiLunTypeMmc;
31
32/**
33 * Array of supported SCSI LUN types.
34 */
35static PVSCSILUNDESC g_aVScsiLunTypesSupported[] =
36{
37 &g_VScsiLunTypeSbc,
38 &g_VScsiLunTypeMmc,
39};
40
41VBOXDDU_DECL(int) VSCSILunCreate(PVSCSILUN phVScsiLun, VSCSILUNTYPE enmLunType,
42 PVSCSILUNIOCALLBACKS pVScsiLunIoCallbacks,
43 void *pvVScsiLunUser)
44{
45 PVSCSILUNINT pVScsiLun = NULL;
46 PVSCSILUNDESC pVScsiLunDesc = NULL;
47
48 AssertPtrReturn(phVScsiLun, VERR_INVALID_POINTER);
49 AssertReturn( enmLunType > VSCSILUNTYPE_INVALID
50 && enmLunType < VSCSILUNTYPE_LAST, VERR_INVALID_PARAMETER);
51 AssertPtrReturn(pVScsiLunIoCallbacks, VERR_INVALID_PARAMETER);
52
53 for (unsigned idxLunType = 0; idxLunType < RT_ELEMENTS(g_aVScsiLunTypesSupported); idxLunType++)
54 {
55 if (g_aVScsiLunTypesSupported[idxLunType]->enmLunType == enmLunType)
56 {
57 pVScsiLunDesc = g_aVScsiLunTypesSupported[idxLunType];
58 break;
59 }
60 }
61
62 if (!pVScsiLunDesc)
63 return VERR_VSCSI_LUN_TYPE_NOT_SUPPORTED;
64
65 pVScsiLun = (PVSCSILUNINT)RTMemAllocZ(pVScsiLunDesc->cbLun);
66 if (!pVScsiLun)
67 return VERR_NO_MEMORY;
68
69 pVScsiLun->pVScsiDevice = NULL;
70 pVScsiLun->pvVScsiLunUser = pvVScsiLunUser;
71 pVScsiLun->pVScsiLunIoCallbacks = pVScsiLunIoCallbacks;
72 pVScsiLun->pVScsiLunDesc = pVScsiLunDesc;
73
74 int rc = vscsiIoReqInit(pVScsiLun);
75 if (RT_SUCCESS(rc))
76 {
77 rc = vscsiLunGetFeatureFlags(pVScsiLun, &pVScsiLun->fFeatures);
78 if (RT_SUCCESS(rc))
79 {
80 rc = pVScsiLunDesc->pfnVScsiLunInit(pVScsiLun);
81 if (RT_SUCCESS(rc))
82 {
83 *phVScsiLun = pVScsiLun;
84 return VINF_SUCCESS;
85 }
86 }
87 }
88
89 RTMemFree(pVScsiLun);
90
91 return rc;
92}
93
94/**
95 * Destroy virtual SCSI LUN.
96 *
97 * @returns VBox status code.
98 * @param hVScsiLun The virtual SCSI LUN handle to destroy.
99 */
100VBOXDDU_DECL(int) VSCSILunDestroy(VSCSILUN hVScsiLun)
101{
102 PVSCSILUNINT pVScsiLun = (PVSCSILUNINT)hVScsiLun;
103
104 AssertPtrReturn(pVScsiLun, VERR_INVALID_HANDLE);
105 AssertReturn(!pVScsiLun->pVScsiDevice, VERR_VSCSI_LUN_ATTACHED_TO_DEVICE);
106 AssertReturn(vscsiIoReqOutstandingCountGet(pVScsiLun) == 0, VERR_VSCSI_LUN_BUSY);
107
108 int rc = pVScsiLun->pVScsiLunDesc->pfnVScsiLunDestroy(pVScsiLun);
109 if (RT_FAILURE(rc))
110 return rc;
111
112 /* Make LUN invalid */
113 pVScsiLun->pvVScsiLunUser = NULL;
114 pVScsiLun->pVScsiLunIoCallbacks = NULL;
115 pVScsiLun->pVScsiLunDesc = NULL;
116
117 RTMemFree(pVScsiLun);
118
119 return VINF_SUCCESS;
120}
121
122/**
123 * Notify virtual SCSI LUN of media being mounted.
124 *
125 * @returns VBox status code.
126 * @param hVScsiLun The virtual SCSI LUN
127 * mounting the medium.
128 */
129VBOXDDU_DECL(int) VSCSILunMountNotify(VSCSILUN hVScsiLun)
130{
131 int rc = VINF_SUCCESS;
132 PVSCSILUNINT pVScsiLun = (PVSCSILUNINT)hVScsiLun;
133
134 LogFlowFunc(("hVScsiLun=%p\n", hVScsiLun));
135 AssertPtrReturn(pVScsiLun, VERR_INVALID_HANDLE);
136 AssertReturn(vscsiIoReqOutstandingCountGet(pVScsiLun) == 0, VERR_VSCSI_LUN_BUSY);
137
138 /* Mark the LUN as not ready so that LUN specific code can do its job. */
139 pVScsiLun->fReady = false;
140 pVScsiLun->fMediaPresent = true;
141 if (pVScsiLun->pVScsiLunDesc->pfnVScsiLunMediumInserted)
142 rc = pVScsiLun->pVScsiLunDesc->pfnVScsiLunMediumInserted(pVScsiLun);
143
144 return rc;
145}
146
147/**
148 * Notify virtual SCSI LUN of media being unmounted.
149 *
150 * @returns VBox status code.
151 * @param hVScsiLun The virtual SCSI LUN
152 * mounting the medium.
153 */
154VBOXDDU_DECL(int) VSCSILunUnmountNotify(VSCSILUN hVScsiLun)
155{
156 int rc = VINF_SUCCESS;
157 PVSCSILUNINT pVScsiLun = (PVSCSILUNINT)hVScsiLun;
158
159 LogFlowFunc(("hVScsiLun=%p\n", hVScsiLun));
160 AssertPtrReturn(pVScsiLun, VERR_INVALID_HANDLE);
161 AssertReturn(vscsiIoReqOutstandingCountGet(pVScsiLun) == 0, VERR_VSCSI_LUN_BUSY);
162
163 pVScsiLun->fReady = false;
164 pVScsiLun->fMediaPresent = false;
165 if (pVScsiLun->pVScsiLunDesc->pfnVScsiLunMediumRemoved)
166 rc = pVScsiLun->pVScsiLunDesc->pfnVScsiLunMediumRemoved(pVScsiLun);
167
168 return rc;
169}
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette