diff options
author | Lorry Tar Creator <lorry-tar-importer@baserock.org> | 2014-03-26 19:21:20 +0000 |
---|---|---|
committer | <> | 2014-05-08 15:03:54 +0000 |
commit | fb123f93f9f5ce42c8e5785d2f8e0edaf951740e (patch) | |
tree | c2103d76aec5f1f10892cd1d3a38e24f665ae5db /src/VBox/Installer/solaris/VBoxZoneAccess.c | |
parent | 58ed4748338f9466599adfc8a9171280ed99e23f (diff) | |
download | VirtualBox-master.tar.gz |
Imported from /home/lorry/working-area/delta_VirtualBox/VirtualBox-4.3.10.tar.bz2.HEADVirtualBox-4.3.10master
Diffstat (limited to 'src/VBox/Installer/solaris/VBoxZoneAccess.c')
-rw-r--r-- | src/VBox/Installer/solaris/VBoxZoneAccess.c | 23 |
1 files changed, 20 insertions, 3 deletions
diff --git a/src/VBox/Installer/solaris/VBoxZoneAccess.c b/src/VBox/Installer/solaris/VBoxZoneAccess.c index a77f32cb..5ec8c309 100644 --- a/src/VBox/Installer/solaris/VBoxZoneAccess.c +++ b/src/VBox/Installer/solaris/VBoxZoneAccess.c @@ -4,7 +4,7 @@ */ /* - * Copyright (C) 2006-2007 Oracle Corporation + * Copyright (C) 2006-2012 Oracle Corporation * * This file is part of VirtualBox Open Source Edition (OSE), as * available from http://www.virtualbox.org. This file is free software; @@ -26,11 +26,16 @@ #include <iprt/process.h> -#define DEVICE_NAME "/dev/vboxdrv" +/******************************************************************************* +* Defined Constants And Macros * +*******************************************************************************/ +#define DEVICE_NAME "/devices/pseudo/vboxdrv@0:vboxdrv" +#define DEVICE_NAME_USR "/devices/pseudo/vboxdrv@0:vboxdrvu" int main(int argc, char *argv[]) { int hDevice = -1; + int hDeviceUsr = -1; /* Check root permissions. */ if (geteuid() != 0) @@ -52,11 +57,22 @@ int main(int argc, char *argv[]) return errno; } + /* Open the user device. */ + hDeviceUsr = open(DEVICE_NAME_USR, O_RDWR, 0); + if (hDeviceUsr < 0) + { + fprintf(stderr, "Failed to open '%s'. errno=%d\n", DEVICE_NAME_USR, errno); + close(hDevice); + return errno; + } + /* Mark the file handle close on exec. */ - if (fcntl(hDevice, F_SETFD, FD_CLOEXEC) != 0) + if ( fcntl(hDevice, F_SETFD, FD_CLOEXEC) != 0 + || fcntl(hDeviceUsr, F_SETFD, FD_CLOEXEC) != 0) { fprintf(stderr, "Failed to set close on exec. errno=%d\n", errno); close(hDevice); + close(hDeviceUsr); return errno; } @@ -65,6 +81,7 @@ int main(int argc, char *argv[]) sleep(500000000U); close(hDevice); + close(hDeviceUsr); return 0; } |