as it is applied consistently.
*/
+struct brl_context;
/*
the lock context contains the elements that define whether one
lock is the same as another lock
struct lock_context {
uint32_t server;
uint16_t smbpid;
- int snum;
+ struct brl_context *ctx;
};
/* The data in brlock records is an unsorted linear array of these
struct brl_context {
struct tdb_wrap *w;
uint32_t server;
- int snum;
struct messaging_context *messaging_ctx;
struct lock_struct last_lock;
};
talloc_free(). We need the messaging_ctx to allow for
pending lock notifications.
*/
-struct brl_context *brl_init(TALLOC_CTX *mem_ctx, uint32_t server, int snum,
+struct brl_context *brl_init(TALLOC_CTX *mem_ctx, uint32_t server,
struct messaging_context *messaging_ctx)
{
char *path;
}
brl->server = server;
- brl->snum = snum;
brl->messaging_ctx = messaging_ctx;
ZERO_STRUCT(brl->last_lock);
{
return (ctx1->server == ctx2->server &&
ctx1->smbpid == ctx2->smbpid &&
- ctx1->snum == ctx2->snum);
+ ctx1->ctx == ctx2->ctx);
}
/*
static NTSTATUS brl_lock_failed(struct brl_context *brl, struct lock_struct *lock)
{
if (lock->context.server == brl->last_lock.context.server &&
- lock->context.snum == brl->last_lock.context.snum &&
+ lock->context.ctx == brl->last_lock.context.ctx &&
lock->fnum == brl->last_lock.fnum &&
lock->start == brl->last_lock.start &&
lock->size == brl->last_lock.size) {
lock.context.smbpid = smbpid;
lock.context.server = brl->server;
- lock.context.snum = brl->snum;
+ lock.context.ctx = brl;
lock.start = start;
lock.size = size;
lock.fnum = fnum;
context.smbpid = smbpid;
context.server = brl->server;
- context.snum = brl->snum;
+ context.ctx = brl;
/* there are existing locks - find a match */
locks = (struct lock_struct *)dbuf.dptr;
lock.context.smbpid = smbpid;
lock.context.server = brl->server;
- lock.context.snum = brl->snum;
+ lock.context.ctx = brl;
lock.start = start;
lock.size = size;
lock.fnum = fnum;
for (i=0; i<count; i++) {
struct lock_struct *lock = &locks[i];
- if (lock->context.snum == brl->snum &&
+ if (lock->context.ctx == brl &&
lock->context.server == brl->server &&
lock->fnum == fnum) {
/* found it - delete it */
ntvfs->private_data = pvfs;
pvfs->brl_context = brl_init(pvfs,
- pvfs->ntvfs->ctx->server_id,
- pvfs->ntvfs->ctx->config.snum,
+ pvfs->ntvfs->ctx->server_id,
pvfs->ntvfs->ctx->msg_ctx);
if (pvfs->brl_context == NULL) {
return NT_STATUS_INTERNAL_DB_CORRUPTION;