mirror of
https://github.com/samba-team/samba.git
synced 2025-03-27 22:50:26 +03:00
r15188: Restore svn rev. 15183, 15184 and 15185, which I inadvertantly clobbered
in r15186. I don't think I should be allowed to use quilt and svn at the same time any more :( (This used to be commit e0ca5ead27743c84f5d9310a05d6d718862ead1d)
This commit is contained in:
parent
9d9e5abdce
commit
7baa8a13aa
@ -939,6 +939,7 @@ NTSTATUS ntvfs_cifs_init(void)
|
||||
{
|
||||
NTSTATUS ret;
|
||||
struct ntvfs_ops ops;
|
||||
NTVFS_CURRENT_CRITICAL_SIZES(vers);
|
||||
|
||||
ZERO_STRUCT(ops);
|
||||
|
||||
@ -985,7 +986,7 @@ NTSTATUS ntvfs_cifs_init(void)
|
||||
|
||||
/* register ourselves with the NTVFS subsystem. We register
|
||||
under the name 'cifs'. */
|
||||
ret = ntvfs_register(&ops);
|
||||
ret = ntvfs_register(&ops, &vers);
|
||||
|
||||
if (!NT_STATUS_IS_OK(ret)) {
|
||||
DEBUG(0,("Failed to register CIFS backend!\n"));
|
||||
|
@ -777,6 +777,7 @@ NTSTATUS ntvfs_ipc_init(void)
|
||||
{
|
||||
NTSTATUS ret;
|
||||
struct ntvfs_ops ops;
|
||||
NTVFS_CURRENT_CRITICAL_SIZES(vers);
|
||||
|
||||
ZERO_STRUCT(ops);
|
||||
|
||||
@ -817,7 +818,7 @@ NTSTATUS ntvfs_ipc_init(void)
|
||||
ops.cancel = ipc_cancel;
|
||||
|
||||
/* register ourselves with the NTVFS subsystem. */
|
||||
ret = ntvfs_register(&ops);
|
||||
ret = ntvfs_register(&ops, &vers);
|
||||
|
||||
if (!NT_STATUS_IS_OK(ret)) {
|
||||
DEBUG(0,("Failed to register IPC backend!\n"));
|
||||
|
@ -884,6 +884,7 @@ NTSTATUS ntvfs_nbench_init(void)
|
||||
{
|
||||
NTSTATUS ret;
|
||||
struct ntvfs_ops ops;
|
||||
NTVFS_CURRENT_CRITICAL_SIZES(vers);
|
||||
|
||||
ZERO_STRUCT(ops);
|
||||
|
||||
@ -928,7 +929,7 @@ NTSTATUS ntvfs_nbench_init(void)
|
||||
ops.trans2 = NULL;
|
||||
|
||||
/* register ourselves with the NTVFS subsystem. */
|
||||
ret = ntvfs_register(&ops);
|
||||
ret = ntvfs_register(&ops, &vers);
|
||||
|
||||
if (!NT_STATUS_IS_OK(ret)) {
|
||||
DEBUG(0,("Failed to register nbench backend!\n"));
|
||||
|
@ -266,6 +266,17 @@ struct ntvfs_critical_sizes {
|
||||
int sizeof_ntvfs_request;
|
||||
};
|
||||
|
||||
#define NTVFS_CURRENT_CRITICAL_SIZES(c) \
|
||||
struct ntvfs_critical_sizes c = { \
|
||||
.interface_version = NTVFS_INTERFACE_VERSION, \
|
||||
.sizeof_ntvfs_critical_sizes = sizeof(struct ntvfs_critical_sizes), \
|
||||
.sizeof_ntvfs_context = sizeof(struct ntvfs_context), \
|
||||
.sizeof_ntvfs_module_context = sizeof(struct ntvfs_module_context), \
|
||||
.sizeof_ntvfs_ops = sizeof(struct ntvfs_ops), \
|
||||
.sizeof_ntvfs_async_state = sizeof(struct ntvfs_async_state), \
|
||||
.sizeof_ntvfs_request = sizeof(struct ntvfs_request), \
|
||||
}
|
||||
|
||||
struct messaging_context;
|
||||
#include "librpc/gen_ndr/security.h"
|
||||
#include "librpc/gen_ndr/notify.h"
|
||||
|
@ -44,11 +44,18 @@ static int num_backends;
|
||||
|
||||
The 'type' is used to specify whether this is for a disk, printer or IPC$ share
|
||||
*/
|
||||
_PUBLIC_ NTSTATUS ntvfs_register(const void *_ops)
|
||||
_PUBLIC_ NTSTATUS ntvfs_register(const struct ntvfs_ops *ops,
|
||||
const struct ntvfs_critical_sizes *const sizes)
|
||||
{
|
||||
const struct ntvfs_ops *ops = _ops;
|
||||
struct ntvfs_ops *new_ops;
|
||||
|
||||
|
||||
if (ntvfs_interface_differs(sizes)) {
|
||||
DEBUG(0, ("NTVFS backend '%s' for type %d "
|
||||
"failed version check\n",
|
||||
ops->name, (int)ops->type));
|
||||
return NT_STATUS_BAD_FUNCTION_TABLE;
|
||||
}
|
||||
|
||||
if (ntvfs_backend_byname(ops->name, ops->type) != NULL) {
|
||||
/* its already registered! */
|
||||
DEBUG(0,("NTVFS backend '%s' for type %d already registered\n",
|
||||
@ -98,21 +105,49 @@ _PUBLIC_ const struct ntvfs_ops *ntvfs_backend_byname(const char *name, enum ntv
|
||||
This can be used by backends to either detect compilation errors, or provide
|
||||
multiple implementations for different smbd compilation options in one module
|
||||
*/
|
||||
static const struct ntvfs_critical_sizes critical_sizes = {
|
||||
.interface_version = NTVFS_INTERFACE_VERSION,
|
||||
.sizeof_ntvfs_critical_sizes = sizeof(struct ntvfs_critical_sizes),
|
||||
.sizeof_ntvfs_context = sizeof(struct ntvfs_context),
|
||||
.sizeof_ntvfs_module_context = sizeof(struct ntvfs_module_context),
|
||||
.sizeof_ntvfs_ops = sizeof(struct ntvfs_ops),
|
||||
.sizeof_ntvfs_async_state = sizeof(struct ntvfs_async_state),
|
||||
.sizeof_ntvfs_request = sizeof(struct ntvfs_request),
|
||||
};
|
||||
|
||||
static const NTVFS_CURRENT_CRITICAL_SIZES(critical_sizes);
|
||||
|
||||
_PUBLIC_ const struct ntvfs_critical_sizes *ntvfs_interface_version(void)
|
||||
{
|
||||
return &critical_sizes;
|
||||
}
|
||||
|
||||
_PUBLIC_ BOOL ntvfs_interface_differs(const struct ntvfs_critical_sizes *const iface)
|
||||
{
|
||||
/* The comparison would be easier with memcmp, but compiler-interset
|
||||
* alignment padding is not guaranteed to be zeroed.
|
||||
*/
|
||||
|
||||
#define FIELD_DIFFERS(field) (iface->field != critical_sizes.field)
|
||||
|
||||
if (FIELD_DIFFERS(interface_version))
|
||||
return True;
|
||||
|
||||
if (FIELD_DIFFERS(sizeof_ntvfs_critical_sizes))
|
||||
return True;
|
||||
|
||||
if (FIELD_DIFFERS(sizeof_ntvfs_context))
|
||||
return True;
|
||||
|
||||
if (FIELD_DIFFERS(sizeof_ntvfs_module_context))
|
||||
return True;
|
||||
|
||||
if (FIELD_DIFFERS(sizeof_ntvfs_ops))
|
||||
return True;
|
||||
|
||||
if (FIELD_DIFFERS(sizeof_ntvfs_async_state))
|
||||
return True;
|
||||
|
||||
if (FIELD_DIFFERS(sizeof_ntvfs_request))
|
||||
return True;
|
||||
|
||||
/* Versions match. */
|
||||
return False;
|
||||
|
||||
#undef FIELD_DIFFERS
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
initialise a connection structure to point at a NTVFS backend
|
||||
|
@ -286,6 +286,7 @@ NTSTATUS ntvfs_posix_init(void)
|
||||
{
|
||||
NTSTATUS ret;
|
||||
struct ntvfs_ops ops;
|
||||
NTVFS_CURRENT_CRITICAL_SIZES(vers);
|
||||
|
||||
ZERO_STRUCT(ops);
|
||||
|
||||
@ -328,14 +329,14 @@ NTSTATUS ntvfs_posix_init(void)
|
||||
under the name 'default' as we wish to be the default
|
||||
backend, and also register as 'posix' */
|
||||
ops.name = "default";
|
||||
ret = ntvfs_register(&ops);
|
||||
ret = ntvfs_register(&ops, &vers);
|
||||
|
||||
if (!NT_STATUS_IS_OK(ret)) {
|
||||
DEBUG(0,("Failed to register POSIX backend as '%s'!\n", ops.name));
|
||||
}
|
||||
|
||||
ops.name = "posix";
|
||||
ret = ntvfs_register(&ops);
|
||||
ret = ntvfs_register(&ops, &vers);
|
||||
|
||||
if (!NT_STATUS_IS_OK(ret)) {
|
||||
DEBUG(0,("Failed to register POSIX backend as '%s'!\n", ops.name));
|
||||
|
@ -100,6 +100,7 @@ NTSTATUS ntvfs_print_init(void)
|
||||
{
|
||||
NTSTATUS ret;
|
||||
struct ntvfs_ops ops;
|
||||
NTVFS_CURRENT_CRITICAL_SIZES(vers);
|
||||
|
||||
ZERO_STRUCT(ops);
|
||||
|
||||
@ -115,7 +116,7 @@ NTSTATUS ntvfs_print_init(void)
|
||||
|
||||
/* register ourselves with the NTVFS subsystem. We register under the name 'default'
|
||||
as we wish to be the default backend */
|
||||
ret = ntvfs_register(&ops);
|
||||
ret = ntvfs_register(&ops, &vers);
|
||||
|
||||
if (!NT_STATUS_IS_OK(ret)) {
|
||||
DEBUG(0,("Failed to register PRINT backend!\n"));
|
||||
|
@ -969,6 +969,7 @@ NTSTATUS ntvfs_simple_init(void)
|
||||
{
|
||||
NTSTATUS ret;
|
||||
struct ntvfs_ops ops;
|
||||
NTVFS_CURRENT_CRITICAL_SIZES(vers);
|
||||
|
||||
ZERO_STRUCT(ops);
|
||||
|
||||
@ -1010,7 +1011,7 @@ NTSTATUS ntvfs_simple_init(void)
|
||||
|
||||
ops.type = NTVFS_DISK;
|
||||
ops.name = "simple";
|
||||
ret = ntvfs_register(&ops);
|
||||
ret = ntvfs_register(&ops, &vers);
|
||||
|
||||
if (!NT_STATUS_IS_OK(ret)) {
|
||||
DEBUG(0,("Failed to register simple backend with name: %s!\n",
|
||||
|
@ -639,6 +639,7 @@ NTSTATUS ntvfs_unixuid_init(void)
|
||||
{
|
||||
NTSTATUS ret;
|
||||
struct ntvfs_ops ops;
|
||||
NTVFS_CURRENT_CRITICAL_SIZES(vers);
|
||||
|
||||
ZERO_STRUCT(ops);
|
||||
|
||||
@ -679,15 +680,15 @@ NTSTATUS ntvfs_unixuid_init(void)
|
||||
|
||||
/* we register under all 3 backend types, as we are not type specific */
|
||||
ops.type = NTVFS_DISK;
|
||||
ret = ntvfs_register(&ops);
|
||||
ret = ntvfs_register(&ops, &vers);
|
||||
if (!NT_STATUS_IS_OK(ret)) goto failed;
|
||||
|
||||
ops.type = NTVFS_PRINT;
|
||||
ret = ntvfs_register(&ops);
|
||||
ret = ntvfs_register(&ops, &vers);
|
||||
if (!NT_STATUS_IS_OK(ret)) goto failed;
|
||||
|
||||
ops.type = NTVFS_IPC;
|
||||
ret = ntvfs_register(&ops);
|
||||
ret = ntvfs_register(&ops, &vers);
|
||||
if (!NT_STATUS_IS_OK(ret)) goto failed;
|
||||
|
||||
failed:
|
||||
|
Loading…
x
Reference in New Issue
Block a user