VirtualBox

source: vbox/trunk/src/VBox/Main/SystemPropertiesImpl.cpp@ 13958

Last change on this file since 13958 was 13837, checked in by vboxsync, 16 years ago

s/%Vr\([acfs]\)/%Rr\1/g - since I'm upsetting everyone anyway, better make the most of it...

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 15.8 KB
Line 
1/* $Id: SystemPropertiesImpl.cpp 13837 2008-11-05 02:54:02Z vboxsync $ */
2
3/** @file
4 *
5 * VirtualBox COM class implementation
6 */
7
8/*
9 * Copyright (C) 2006-2008 Sun Microsystems, Inc.
10 *
11 * This file is part of VirtualBox Open Source Edition (OSE), as
12 * available from http://www.virtualbox.org. This file is free software;
13 * you can redistribute it and/or modify it under the terms of the GNU
14 * General Public License (GPL) as published by the Free Software
15 * Foundation, in version 2 as it comes in the "COPYING" file of the
16 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
17 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
18 *
19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
20 * Clara, CA 95054 USA or visit http://www.sun.com if you need
21 * additional information or have any questions.
22 */
23
24#include "SystemPropertiesImpl.h"
25#include "VirtualBoxImpl.h"
26#include "MachineImpl.h"
27#include "Logging.h"
28
29// generated header
30#include "SchemaDefs.h"
31
32#include <iprt/path.h>
33#include <iprt/dir.h>
34#include <VBox/param.h>
35#include <VBox/err.h>
36
37// defines
38/////////////////////////////////////////////////////////////////////////////
39
40// constructor / destructor
41/////////////////////////////////////////////////////////////////////////////
42
43DEFINE_EMPTY_CTOR_DTOR (SystemProperties)
44
45HRESULT SystemProperties::FinalConstruct()
46{
47 return S_OK;
48}
49
50void SystemProperties::FinalRelease()
51{
52 uninit ();
53}
54
55// public methods only for internal purposes
56/////////////////////////////////////////////////////////////////////////////
57
58/**
59 * Initializes the system information object.
60 *
61 * @returns COM result indicator
62 */
63HRESULT SystemProperties::init (VirtualBox *aParent)
64{
65 LogFlowThisFunc (("aParent=%p\n", aParent));
66
67 ComAssertRet (aParent, E_FAIL);
68
69 /* Enclose the state transition NotReady->InInit->Ready */
70 AutoInitSpan autoInitSpan (this);
71 AssertReturn (autoInitSpan.isOk(), E_UNEXPECTED);
72
73 unconst (mParent) = aParent;
74
75 setDefaultMachineFolder (NULL);
76 setDefaultHardDiskFolder (NULL);
77 setRemoteDisplayAuthLibrary (NULL);
78
79 mHWVirtExEnabled = false;
80 mLogHistoryCount = 3;
81
82 HRESULT rc = S_OK;
83
84 /* Fetch info of all available hd backends. */
85
86 /// @todo NEWMEDIA VDBackendInfo needs to be improved to let us enumerate
87 /// any number of backends
88
89 /// @todo We currently leak memory because it's not actually clear what to
90 /// free in structures returned by VDBackendInfo. Must be fixed ASAP!
91
92 VDBACKENDINFO aVDInfo [100];
93 unsigned cEntries;
94 int vrc = VDBackendInfo (RT_ELEMENTS (aVDInfo), aVDInfo, &cEntries);
95 AssertRC (vrc);
96 if (RT_SUCCESS (vrc))
97 {
98 for (unsigned i = 0; i < cEntries; ++ i)
99 {
100 ComObjPtr <HardDiskFormat> hdf;
101 rc = hdf.createObject();
102 CheckComRCBreakRC (rc);
103
104 rc = hdf->init (&aVDInfo [i]);
105 CheckComRCBreakRC (rc);
106
107 mHardDiskFormats.push_back (hdf);
108 }
109 }
110
111 /* Confirm a successful initialization */
112 if (SUCCEEDED (rc))
113 autoInitSpan.setSucceeded();
114
115 return rc;
116}
117
118/**
119 * Uninitializes the instance and sets the ready flag to FALSE.
120 * Called either from FinalRelease() or by the parent when it gets destroyed.
121 */
122void SystemProperties::uninit()
123{
124 LogFlowThisFunc (("\n"));
125
126 /* Enclose the state transition Ready->InUninit->NotReady */
127 AutoUninitSpan autoUninitSpan (this);
128 if (autoUninitSpan.uninitDone())
129 return;
130
131 unconst (mParent).setNull();
132}
133
134// ISystemProperties properties
135/////////////////////////////////////////////////////////////////////////////
136
137
138STDMETHODIMP SystemProperties::COMGETTER(MinGuestRAM)(ULONG *minRAM)
139{
140 if (!minRAM)
141 return E_POINTER;
142
143 AutoCaller autoCaller (this);
144 CheckComRCReturnRC (autoCaller.rc());
145
146 /* no need to lock, this is const */
147 *minRAM = SchemaDefs::MinGuestRAM;
148
149 return S_OK;
150}
151
152STDMETHODIMP SystemProperties::COMGETTER(MaxGuestRAM)(ULONG *maxRAM)
153{
154 if (!maxRAM)
155 return E_POINTER;
156
157 AutoCaller autoCaller (this);
158 CheckComRCReturnRC (autoCaller.rc());
159
160 /* no need to lock, this is const */
161 *maxRAM = SchemaDefs::MaxGuestRAM;
162
163 return S_OK;
164}
165
166STDMETHODIMP SystemProperties::COMGETTER(MinGuestVRAM)(ULONG *minVRAM)
167{
168 if (!minVRAM)
169 return E_POINTER;
170
171 AutoCaller autoCaller (this);
172 CheckComRCReturnRC (autoCaller.rc());
173
174 /* no need to lock, this is const */
175 *minVRAM = SchemaDefs::MinGuestVRAM;
176
177 return S_OK;
178}
179
180STDMETHODIMP SystemProperties::COMGETTER(MaxGuestVRAM)(ULONG *maxVRAM)
181{
182 if (!maxVRAM)
183 return E_POINTER;
184
185 AutoCaller autoCaller (this);
186 CheckComRCReturnRC (autoCaller.rc());
187
188 /* no need to lock, this is const */
189 *maxVRAM = SchemaDefs::MaxGuestVRAM;
190
191 return S_OK;
192}
193
194STDMETHODIMP SystemProperties::COMGETTER(MaxGuestMonitors)(ULONG *maxMonitors)
195{
196 if (!maxMonitors)
197 return E_POINTER;
198
199 AutoCaller autoCaller (this);
200 CheckComRCReturnRC (autoCaller.rc());
201
202 /* no need to lock, this is const */
203 *maxMonitors = SchemaDefs::MaxGuestMonitors;
204
205 return S_OK;
206}
207
208STDMETHODIMP SystemProperties::COMGETTER(MaxVDISize)(ULONG64 *maxVDISize)
209{
210 if (!maxVDISize)
211 return E_POINTER;
212
213 AutoCaller autoCaller (this);
214 CheckComRCReturnRC (autoCaller.rc());
215
216 /** The BIOS supports currently 32 bit LBA numbers (implementing the full
217 * 48 bit range is in theory trivial, but the crappy compiler makes things
218 * more difficult). This translates to almost 2 TBytes (to be on the safe
219 * side, the reported limit is 1 MiByte less than that, as the total number
220 * of sectors should fit in 32 bits, too), which should bei enough for
221 * the moment. The virtual ATA disks support complete LBA48 (although for
222 * example iSCSI is also currently limited to 32 bit LBA), so the
223 * theoretical maximum disk size is 128 PiByte. The user interface cannot
224 * cope with this in a reasonable way yet. */
225 /* no need to lock, this is const */
226 *maxVDISize = 2048 * 1024 - 1;
227
228 return S_OK;
229}
230
231STDMETHODIMP SystemProperties::COMGETTER(NetworkAdapterCount)(ULONG *count)
232{
233 if (!count)
234 return E_POINTER;
235
236 AutoCaller autoCaller (this);
237 CheckComRCReturnRC (autoCaller.rc());
238
239 /* no need to lock, this is const */
240 *count = SchemaDefs::NetworkAdapterCount;
241
242 return S_OK;
243}
244
245STDMETHODIMP SystemProperties::COMGETTER(SerialPortCount)(ULONG *count)
246{
247 if (!count)
248 return E_POINTER;
249
250 AutoCaller autoCaller (this);
251 CheckComRCReturnRC (autoCaller.rc());
252
253 /* no need to lock, this is const */
254 *count = SchemaDefs::SerialPortCount;
255
256 return S_OK;
257}
258
259STDMETHODIMP SystemProperties::COMGETTER(ParallelPortCount)(ULONG *count)
260{
261 if (!count)
262 return E_POINTER;
263
264 AutoCaller autoCaller (this);
265 CheckComRCReturnRC (autoCaller.rc());
266
267 /* no need to lock, this is const */
268 *count = SchemaDefs::ParallelPortCount;
269
270 return S_OK;
271}
272
273STDMETHODIMP SystemProperties::COMGETTER(MaxBootPosition)(ULONG *aMaxBootPosition)
274{
275 if (!aMaxBootPosition)
276 return E_POINTER;
277
278 AutoCaller autoCaller (this);
279 CheckComRCReturnRC (autoCaller.rc());
280
281 /* no need to lock, this is const */
282 *aMaxBootPosition = SchemaDefs::MaxBootPosition;
283
284 return S_OK;
285}
286
287STDMETHODIMP SystemProperties::COMGETTER(DefaultMachineFolder) (BSTR *aDefaultMachineFolder)
288{
289 if (!aDefaultMachineFolder)
290 return E_POINTER;
291
292 AutoCaller autoCaller (this);
293 CheckComRCReturnRC (autoCaller.rc());
294
295 AutoReadLock alock (this);
296
297 mDefaultMachineFolderFull.cloneTo (aDefaultMachineFolder);
298
299 return S_OK;
300}
301
302STDMETHODIMP SystemProperties::COMSETTER(DefaultMachineFolder) (INPTR BSTR aDefaultMachineFolder)
303{
304 AutoCaller autoCaller (this);
305 CheckComRCReturnRC (autoCaller.rc());
306
307 /* VirtualBox::saveSettings() needs a write lock */
308 AutoMultiWriteLock2 alock (mParent, this);
309
310 HRESULT rc = setDefaultMachineFolder (aDefaultMachineFolder);
311 if (SUCCEEDED (rc))
312 rc = mParent->saveSettings();
313
314 return rc;
315}
316
317STDMETHODIMP SystemProperties::COMGETTER(DefaultHardDiskFolder) (BSTR *aDefaultHardDiskFolder)
318{
319 if (!aDefaultHardDiskFolder)
320 return E_POINTER;
321
322 AutoCaller autoCaller (this);
323 CheckComRCReturnRC (autoCaller.rc());
324
325 AutoReadLock alock (this);
326
327 mDefaultHardDiskFolderFull.cloneTo (aDefaultHardDiskFolder);
328
329 return S_OK;
330}
331
332STDMETHODIMP SystemProperties::COMSETTER(DefaultHardDiskFolder) (INPTR BSTR aDefaultHardDiskFolder)
333{
334 AutoCaller autoCaller (this);
335 CheckComRCReturnRC (autoCaller.rc());
336
337 /* VirtualBox::saveSettings() needs a write lock */
338 AutoMultiWriteLock2 alock (mParent, this);
339
340 HRESULT rc = setDefaultHardDiskFolder (aDefaultHardDiskFolder);
341 if (SUCCEEDED (rc))
342 rc = mParent->saveSettings();
343
344 return rc;
345}
346
347STDMETHODIMP SystemProperties::
348COMGETTER(HardDiskFormats) (ComSafeArrayOut (IHardDiskFormat *, aHardDiskFormats))
349{
350 if (ComSafeArrayOutIsNull (aHardDiskFormats))
351 return E_POINTER;
352
353 AutoCaller autoCaller (this);
354 CheckComRCReturnRC (autoCaller.rc());
355
356 AutoReadLock alock (this);
357
358 SafeIfaceArray <IHardDiskFormat> hardDiskFormats (mHardDiskFormats);
359 hardDiskFormats.detachTo (ComSafeArrayOutArg (aHardDiskFormats));
360
361 return S_OK;
362}
363
364STDMETHODIMP SystemProperties::COMGETTER(RemoteDisplayAuthLibrary) (BSTR *aRemoteDisplayAuthLibrary)
365{
366 if (!aRemoteDisplayAuthLibrary)
367 return E_POINTER;
368
369 AutoCaller autoCaller (this);
370 CheckComRCReturnRC (autoCaller.rc());
371
372 AutoReadLock alock (this);
373
374 mRemoteDisplayAuthLibrary.cloneTo (aRemoteDisplayAuthLibrary);
375
376 return S_OK;
377}
378
379STDMETHODIMP SystemProperties::COMSETTER(RemoteDisplayAuthLibrary) (INPTR BSTR aRemoteDisplayAuthLibrary)
380{
381 AutoCaller autoCaller (this);
382 CheckComRCReturnRC (autoCaller.rc());
383
384 /* VirtualBox::saveSettings() needs a write lock */
385 AutoMultiWriteLock2 alock (mParent, this);
386
387 HRESULT rc = setRemoteDisplayAuthLibrary (aRemoteDisplayAuthLibrary);
388 if (SUCCEEDED (rc))
389 rc = mParent->saveSettings();
390
391 return rc;
392}
393
394STDMETHODIMP SystemProperties::COMGETTER(WebServiceAuthLibrary) (BSTR *aWebServiceAuthLibrary)
395{
396 if (!aWebServiceAuthLibrary)
397 return E_POINTER;
398
399 AutoCaller autoCaller (this);
400 CheckComRCReturnRC (autoCaller.rc());
401
402 AutoReadLock alock (this);
403
404 mWebServiceAuthLibrary.cloneTo (aWebServiceAuthLibrary);
405
406 return S_OK;
407}
408
409STDMETHODIMP SystemProperties::COMSETTER(WebServiceAuthLibrary) (INPTR BSTR aWebServiceAuthLibrary)
410{
411 AutoCaller autoCaller (this);
412 CheckComRCReturnRC (autoCaller.rc());
413
414 /* VirtualBox::saveSettings() needs a write lock */
415 AutoMultiWriteLock2 alock (mParent, this);
416
417 HRESULT rc = setWebServiceAuthLibrary (aWebServiceAuthLibrary);
418 if (SUCCEEDED (rc))
419 rc = mParent->saveSettings();
420
421 return rc;
422}
423
424STDMETHODIMP SystemProperties::COMGETTER(HWVirtExEnabled) (BOOL *enabled)
425{
426 if (!enabled)
427 return E_POINTER;
428
429 AutoCaller autoCaller (this);
430 CheckComRCReturnRC (autoCaller.rc());
431
432 AutoReadLock alock (this);
433
434 *enabled = mHWVirtExEnabled;
435
436 return S_OK;
437}
438
439STDMETHODIMP SystemProperties::COMSETTER(HWVirtExEnabled) (BOOL enabled)
440{
441 AutoCaller autoCaller (this);
442 CheckComRCReturnRC (autoCaller.rc());
443
444 /* VirtualBox::saveSettings() needs a write lock */
445 AutoMultiWriteLock2 alock (mParent, this);
446
447 mHWVirtExEnabled = enabled;
448
449 HRESULT rc = mParent->saveSettings();
450
451 return rc;
452}
453
454STDMETHODIMP SystemProperties::COMGETTER(LogHistoryCount) (ULONG *count)
455{
456 if (!count)
457 return E_POINTER;
458
459 AutoCaller autoCaller (this);
460 CheckComRCReturnRC (autoCaller.rc());
461
462 AutoReadLock alock (this);
463
464 *count = mLogHistoryCount;
465
466 return S_OK;
467}
468
469STDMETHODIMP SystemProperties::COMSETTER(LogHistoryCount) (ULONG count)
470{
471 AutoCaller autoCaller (this);
472 CheckComRCReturnRC (autoCaller.rc());
473
474 /* VirtualBox::saveSettings() needs a write lock */
475 AutoMultiWriteLock2 alock (mParent, this);
476
477 mLogHistoryCount = count;
478
479 HRESULT rc = mParent->saveSettings();
480
481 return rc;
482}
483
484// public methods only for internal purposes
485/////////////////////////////////////////////////////////////////////////////
486
487HRESULT SystemProperties::loadSettings (const settings::Key &aGlobal)
488{
489 using namespace settings;
490
491 AutoCaller autoCaller (this);
492 CheckComRCReturnRC (autoCaller.rc());
493
494 AutoWriteLock alock (this);
495
496 AssertReturn (!aGlobal.isNull(), E_FAIL);
497
498 HRESULT rc = S_OK;
499
500 Key properties = aGlobal.key ("SystemProperties");
501
502 Bstr bstr;
503
504 bstr = properties.stringValue ("defaultMachineFolder");
505 rc = setDefaultMachineFolder (bstr);
506 CheckComRCReturnRC (rc);
507
508 bstr = properties.stringValue ("defaultHardDiskFolder");
509 rc = setDefaultHardDiskFolder (bstr);
510 CheckComRCReturnRC (rc);
511
512 bstr = properties.stringValue ("remoteDisplayAuthLibrary");
513 rc = setRemoteDisplayAuthLibrary (bstr);
514 CheckComRCReturnRC (rc);
515
516 bstr = properties.stringValue ("webServiceAuthLibrary");
517 rc = setWebServiceAuthLibrary (bstr);
518 CheckComRCReturnRC (rc);
519
520 /* Note: not <BOOL> because Win32 defines BOOL as int */
521 mHWVirtExEnabled = properties.valueOr <bool> ("HWVirtExEnabled", false);
522
523 mLogHistoryCount = properties.valueOr <ULONG> ("LogHistoryCount", 3);
524
525 return S_OK;
526}
527
528HRESULT SystemProperties::saveSettings (settings::Key &aGlobal)
529{
530 using namespace settings;
531
532 AutoCaller autoCaller (this);
533 CheckComRCReturnRC (autoCaller.rc());
534
535 AutoReadLock alock (this);
536
537 ComAssertRet (!aGlobal.isNull(), E_FAIL);
538
539 /* first, delete the entry */
540 Key properties = aGlobal.findKey ("SystemProperties");
541 if (!properties.isNull())
542 properties.zap();
543 /* then, recreate it */
544 properties = aGlobal.createKey ("SystemProperties");
545
546 if (mDefaultMachineFolder)
547 properties.setValue <Bstr> ("defaultMachineFolder", mDefaultMachineFolder);
548
549 if (mDefaultHardDiskFolder)
550 properties.setValue <Bstr> ("defaultHardDiskFolder", mDefaultHardDiskFolder);
551
552 if (mRemoteDisplayAuthLibrary)
553 properties.setValue <Bstr> ("remoteDisplayAuthLibrary", mRemoteDisplayAuthLibrary);
554
555 if (mWebServiceAuthLibrary)
556 properties.setValue <Bstr> ("webServiceAuthLibrary", mWebServiceAuthLibrary);
557
558 properties.setValue <bool> ("HWVirtExEnabled", !!mHWVirtExEnabled);
559
560 properties.setValue <ULONG> ("LogHistoryCount", mLogHistoryCount);
561
562 return S_OK;
563}
564
565// private methods
566/////////////////////////////////////////////////////////////////////////////
567
568HRESULT SystemProperties::setDefaultMachineFolder (const BSTR aPath)
569{
570 Utf8Str path;
571 if (aPath && *aPath)
572 path = aPath;
573 else
574 path = "Machines";
575
576 /* get the full file name */
577 Utf8Str folder;
578 int vrc = mParent->calculateFullPath (path, folder);
579 if (RT_FAILURE (vrc))
580 return setError (E_FAIL,
581 tr ("Invalid default machine folder '%ls' (%Rrc)"),
582 path.raw(), vrc);
583
584 mDefaultMachineFolder = path;
585 mDefaultMachineFolderFull = folder;
586
587 return S_OK;
588}
589
590HRESULT SystemProperties::setDefaultHardDiskFolder (const BSTR aPath)
591{
592 Utf8Str path;
593 if (aPath && *aPath)
594 path = aPath;
595 else
596 path = "HardDisks";
597
598 /* get the full file name */
599 Utf8Str folder;
600 int vrc = mParent->calculateFullPath (path, folder);
601 if (RT_FAILURE (vrc))
602 return setError (E_FAIL,
603 tr ("Invalid default hard disk folder '%ls' (%Rrc)"),
604 path.raw(), vrc);
605
606 mDefaultHardDiskFolder = path;
607 mDefaultHardDiskFolderFull = folder;
608
609 return S_OK;
610}
611
612HRESULT SystemProperties::setRemoteDisplayAuthLibrary (const BSTR aPath)
613{
614 Utf8Str path;
615 if (aPath && *aPath)
616 path = aPath;
617 else
618 path = "VRDPAuth";
619
620 mRemoteDisplayAuthLibrary = path;
621
622 return S_OK;
623}
624
625HRESULT SystemProperties::setWebServiceAuthLibrary (const BSTR aPath)
626{
627 Utf8Str path;
628 if (aPath && *aPath)
629 path = aPath;
630 else
631 path = "VRDPAuth";
632
633 mWebServiceAuthLibrary = path;
634
635 return S_OK;
636}
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