VirtualBox

source: vbox/trunk/src/VBox/Additions/linux/sharedfolders/vbsfmount.h@ 69310

Last change on this file since 69310 was 69149, checked in by vboxsync, 7 years ago

Additions/linux/shfl: stop supporting old host/mount.vboxsf versions.
bugref:4567: Linux kernel driver maintenance

Based on [PATCH] Remove support for old hosts and userspace mount.vboxsf
Signed-off-by: Hans de Goede <hdegoede@…>

Versions of VirtualBox many years ago used a different host/guest protocol
for accessing shared folders, as well as a different guest kernel to
user-space mount helper protocol. While we try to support old Additions
versions on the host side, we only aim to support old host versions in the
Additions to a limited extent, and the guest kernel interface is also only
fixed for a defined range of releases.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 2.5 KB
Line 
1/** @file
2 * vboxsf -- VirtualBox Guest Additions for Linux: mount(2) parameter structure.
3 */
4
5/*
6 * Copyright (C) 2006-2016 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 */
16
17#ifndef VBFS_MOUNT_H
18#define VBFS_MOUNT_H
19
20/* Linux constraints the size of data mount argument to PAGE_SIZE - 1. */
21#define MAX_HOST_NAME 256
22#define MAX_NLS_NAME 32
23
24#define VBSF_MOUNT_SIGNATURE_BYTE_0 '\377'
25#define VBSF_MOUNT_SIGNATURE_BYTE_1 '\376'
26#define VBSF_MOUNT_SIGNATURE_BYTE_2 '\375'
27
28struct vbsf_mount_info_new
29{
30 /*
31 * The old version of the mount_info struct started with a
32 * char name[MAX_HOST_NAME] field, where name cannot be '\0'.
33 * So the new version of the mount_info struct starts with a
34 * nullchar field which is always 0 so that we can detect and
35 * reject the old structure being passed.
36 */
37 char nullchar;
38 char signature[3]; /* signature */
39 int length; /* length of the whole structure */
40 char name[MAX_HOST_NAME]; /* share name */
41 char nls_name[MAX_NLS_NAME];/* name of an I/O charset */
42 int uid; /* user ID for all entries, default 0=root */
43 int gid; /* group ID for all entries, default 0=root */
44 int ttl; /* time to live */
45 int dmode; /* mode for directories if != 0xffffffff */
46 int fmode; /* mode for regular files if != 0xffffffff */
47 int dmask; /* umask applied to directories */
48 int fmask; /* umask applied to regular files */
49};
50
51struct vbsf_mount_opts
52{
53 int uid;
54 int gid;
55 int ttl;
56 int dmode;
57 int fmode;
58 int dmask;
59 int fmask;
60 int ronly;
61 int sloppy;
62 int noexec;
63 int nodev;
64 int nosuid;
65 int remount;
66 char nls_name[MAX_NLS_NAME];
67 char *convertcp;
68};
69
70/** Completes the mount operation by adding the new mount point to mtab if required. */
71int vbsfmount_complete(const char *host_name, const char *mount_point,
72 unsigned long flags, struct vbsf_mount_opts *opts);
73
74#endif /* vbsfmount.h */
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