mirror of
https://github.com/samba-team/samba.git
synced 2025-01-25 06:04:04 +03:00
r19668: Convert the locking params to use struct share_param instead of snum
(This used to be commit 609dbec600048718b86cd1ecdc2ce49bbdeb803c)
This commit is contained in:
parent
5f3a692748
commit
b6b84f98c0
@ -333,7 +333,7 @@ static NTSTATUS brl_lock_windows(struct byte_range_lock *br_lck,
|
|||||||
be mapped into a lower level POSIX one, and if so can
|
be mapped into a lower level POSIX one, and if so can
|
||||||
we get it ? */
|
we get it ? */
|
||||||
|
|
||||||
if (!IS_PENDING_LOCK(plock->lock_type) && lp_posix_locking(SNUM(fsp->conn))) {
|
if (!IS_PENDING_LOCK(plock->lock_type) && lp_posix_locking(fsp->conn->params)) {
|
||||||
int errno_ret;
|
int errno_ret;
|
||||||
if (!set_posix_lock_windows_flavour(fsp,
|
if (!set_posix_lock_windows_flavour(fsp,
|
||||||
plock->start,
|
plock->start,
|
||||||
@ -654,7 +654,7 @@ static NTSTATUS brl_lock_posix(struct byte_range_lock *br_lck,
|
|||||||
be mapped into a lower level POSIX one, and if so can
|
be mapped into a lower level POSIX one, and if so can
|
||||||
we get it ? */
|
we get it ? */
|
||||||
|
|
||||||
if (!IS_PENDING_LOCK(plock->lock_type) && lp_posix_locking(SNUM(br_lck->fsp->conn))) {
|
if (!IS_PENDING_LOCK(plock->lock_type) && lp_posix_locking(br_lck->fsp->conn->params)) {
|
||||||
int errno_ret;
|
int errno_ret;
|
||||||
|
|
||||||
/* The lower layer just needs to attempt to
|
/* The lower layer just needs to attempt to
|
||||||
@ -829,7 +829,7 @@ static BOOL brl_unlock_windows(struct byte_range_lock *br_lck, const struct lock
|
|||||||
br_lck->modified = True;
|
br_lck->modified = True;
|
||||||
|
|
||||||
/* Unlock the underlying POSIX regions. */
|
/* Unlock the underlying POSIX regions. */
|
||||||
if(lp_posix_locking(SNUM(br_lck->fsp->conn))) {
|
if(lp_posix_locking(br_lck->fsp->conn->params)) {
|
||||||
release_posix_lock_windows_flavour(br_lck->fsp,
|
release_posix_lock_windows_flavour(br_lck->fsp,
|
||||||
plock->start,
|
plock->start,
|
||||||
plock->size,
|
plock->size,
|
||||||
@ -978,7 +978,7 @@ static BOOL brl_unlock_posix(struct byte_range_lock *br_lck, const struct lock_s
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Unlock any POSIX regions. */
|
/* Unlock any POSIX regions. */
|
||||||
if(lp_posix_locking(SNUM(br_lck->fsp->conn))) {
|
if(lp_posix_locking(br_lck->fsp->conn->params)) {
|
||||||
release_posix_lock_posix_flavour(br_lck->fsp,
|
release_posix_lock_posix_flavour(br_lck->fsp,
|
||||||
plock->start,
|
plock->start,
|
||||||
plock->size,
|
plock->size,
|
||||||
@ -1103,7 +1103,7 @@ BOOL brl_locktest(struct byte_range_lock *br_lck,
|
|||||||
* This only conflicts with Windows locks, not POSIX locks.
|
* This only conflicts with Windows locks, not POSIX locks.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if(lp_posix_locking(SNUM(fsp->conn)) && (lock_flav == WINDOWS_LOCK)) {
|
if(lp_posix_locking(fsp->conn->params) && (lock_flav == WINDOWS_LOCK)) {
|
||||||
ret = is_posix_locked(fsp, &start, &size, &lock_type, WINDOWS_LOCK);
|
ret = is_posix_locked(fsp, &start, &size, &lock_type, WINDOWS_LOCK);
|
||||||
|
|
||||||
DEBUG(10,("brl_locktest: posix start=%.0f len=%.0f %s for fnum %d file %s\n",
|
DEBUG(10,("brl_locktest: posix start=%.0f len=%.0f %s for fnum %d file %s\n",
|
||||||
@ -1169,7 +1169,7 @@ NTSTATUS brl_lockquery(struct byte_range_lock *br_lck,
|
|||||||
* see if there is a POSIX lock from a UNIX or NFS process.
|
* see if there is a POSIX lock from a UNIX or NFS process.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if(lp_posix_locking(SNUM(fsp->conn))) {
|
if(lp_posix_locking(fsp->conn->params)) {
|
||||||
BOOL ret = is_posix_locked(fsp, pstart, psize, plock_type, POSIX_LOCK);
|
BOOL ret = is_posix_locked(fsp, pstart, psize, plock_type, POSIX_LOCK);
|
||||||
|
|
||||||
DEBUG(10,("brl_lockquery: posix start=%.0f len=%.0f %s for fnum %d file %s\n",
|
DEBUG(10,("brl_lockquery: posix start=%.0f len=%.0f %s for fnum %d file %s\n",
|
||||||
@ -1252,7 +1252,7 @@ void brl_close_fnum(struct byte_range_lock *br_lck)
|
|||||||
struct process_id pid = procid_self();
|
struct process_id pid = procid_self();
|
||||||
BOOL unlock_individually = False;
|
BOOL unlock_individually = False;
|
||||||
|
|
||||||
if(lp_posix_locking(SNUM(fsp->conn))) {
|
if(lp_posix_locking(fsp->conn->params)) {
|
||||||
|
|
||||||
/* Check if there are any Windows locks associated with this dev/ino
|
/* Check if there are any Windows locks associated with this dev/ino
|
||||||
pair that are not this fnum. If so we need to call unlock on each
|
pair that are not this fnum. If so we need to call unlock on each
|
||||||
@ -1358,7 +1358,7 @@ void brl_close_fnum(struct byte_range_lock *br_lck)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(lp_posix_locking(SNUM(fsp->conn)) && num_deleted_windows_locks) {
|
if(lp_posix_locking(fsp->conn->params) && num_deleted_windows_locks) {
|
||||||
/* Reduce the Windows lock POSIX reference count on this dev/ino pair. */
|
/* Reduce the Windows lock POSIX reference count on this dev/ino pair. */
|
||||||
reduce_windows_lock_ref_count(fsp, num_deleted_windows_locks);
|
reduce_windows_lock_ref_count(fsp, num_deleted_windows_locks);
|
||||||
}
|
}
|
||||||
|
@ -80,8 +80,7 @@ BOOL is_locked(files_struct *fsp,
|
|||||||
SMB_BIG_UINT offset,
|
SMB_BIG_UINT offset,
|
||||||
enum brl_type lock_type)
|
enum brl_type lock_type)
|
||||||
{
|
{
|
||||||
int snum = SNUM(fsp->conn);
|
int strict_locking = lp_strict_locking(fsp->conn->params);
|
||||||
int strict_locking = lp_strict_locking(snum);
|
|
||||||
enum brl_flavour lock_flav = lp_posix_cifsu_locktype();
|
enum brl_flavour lock_flav = lp_posix_cifsu_locktype();
|
||||||
BOOL ret = True;
|
BOOL ret = True;
|
||||||
|
|
||||||
@ -89,7 +88,7 @@ BOOL is_locked(files_struct *fsp,
|
|||||||
return False;
|
return False;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!lp_locking(snum) || !strict_locking) {
|
if (!lp_locking(fsp->conn->params) || !strict_locking) {
|
||||||
return False;
|
return False;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -156,7 +155,7 @@ NTSTATUS query_lock(files_struct *fsp,
|
|||||||
return fsp->is_directory ? NT_STATUS_INVALID_DEVICE_REQUEST : NT_STATUS_INVALID_HANDLE;
|
return fsp->is_directory ? NT_STATUS_INVALID_DEVICE_REQUEST : NT_STATUS_INVALID_HANDLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!lp_locking(SNUM(fsp->conn))) {
|
if (!lp_locking(fsp->conn->params)) {
|
||||||
return NT_STATUS_OK;
|
return NT_STATUS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -197,7 +196,7 @@ struct byte_range_lock *do_lock(files_struct *fsp,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!lp_locking(SNUM(fsp->conn))) {
|
if (!lp_locking(fsp->conn->params)) {
|
||||||
*perr = NT_STATUS_OK;
|
*perr = NT_STATUS_OK;
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@ -243,7 +242,7 @@ NTSTATUS do_unlock(files_struct *fsp,
|
|||||||
return fsp->is_directory ? NT_STATUS_INVALID_DEVICE_REQUEST : NT_STATUS_INVALID_HANDLE;
|
return fsp->is_directory ? NT_STATUS_INVALID_DEVICE_REQUEST : NT_STATUS_INVALID_HANDLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!lp_locking(SNUM(fsp->conn))) {
|
if (!lp_locking(fsp->conn->params)) {
|
||||||
return NT_STATUS_OK;
|
return NT_STATUS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -290,7 +289,7 @@ NTSTATUS do_lock_cancel(files_struct *fsp,
|
|||||||
NT_STATUS_INVALID_DEVICE_REQUEST : NT_STATUS_INVALID_HANDLE;
|
NT_STATUS_INVALID_DEVICE_REQUEST : NT_STATUS_INVALID_HANDLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!lp_locking(SNUM(fsp->conn))) {
|
if (!lp_locking(fsp->conn->params)) {
|
||||||
return NT_STATUS_DOS(ERRDOS, ERRcancelviolation);
|
return NT_STATUS_DOS(ERRDOS, ERRcancelviolation);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -327,7 +326,7 @@ void locking_close_file(files_struct *fsp)
|
|||||||
{
|
{
|
||||||
struct byte_range_lock *br_lck;
|
struct byte_range_lock *br_lck;
|
||||||
|
|
||||||
if (!lp_locking(SNUM(fsp->conn))) {
|
if (!lp_locking(fsp->conn->params)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -643,7 +643,7 @@ int fd_close_posix(struct connection_struct *conn, files_struct *fsp)
|
|||||||
int *fd_array = NULL;
|
int *fd_array = NULL;
|
||||||
size_t count, i;
|
size_t count, i;
|
||||||
|
|
||||||
if (!lp_locking(SNUM(fsp->conn)) || !lp_posix_locking(SNUM(conn))) {
|
if (!lp_locking(fsp->conn->params) || !lp_posix_locking(conn->params)) {
|
||||||
/*
|
/*
|
||||||
* No locking or POSIX to worry about or we want POSIX semantics
|
* No locking or POSIX to worry about or we want POSIX semantics
|
||||||
* which will lose all locks on all fd's open on this dev/inode,
|
* which will lose all locks on all fd's open on this dev/inode,
|
||||||
|
@ -1752,6 +1752,8 @@ static char *lp_string(const char *s)
|
|||||||
|
|
||||||
#define FN_LOCAL_PARM_BOOL(fn_name,val) \
|
#define FN_LOCAL_PARM_BOOL(fn_name,val) \
|
||||||
BOOL fn_name(const struct share_params *p) {return(LP_SNUM_OK(p->service)? ServicePtrs[(p->service)]->val : sDefault.val);}
|
BOOL fn_name(const struct share_params *p) {return(LP_SNUM_OK(p->service)? ServicePtrs[(p->service)]->val : sDefault.val);}
|
||||||
|
#define FN_LOCAL_PARM_INTEGER(fn_name,val) \
|
||||||
|
int fn_name(const struct share_params *p) {return(LP_SNUM_OK(p->service)? ServicePtrs[(p->service)]->val : sDefault.val);}
|
||||||
#define FN_LOCAL_PARM_STRING(fn_name,val) \
|
#define FN_LOCAL_PARM_STRING(fn_name,val) \
|
||||||
char *fn_name(const struct share_params *p) {return(lp_string((LP_SNUM_OK(p->service) && ServicePtrs[(p->service)]->val) ? ServicePtrs[(p->service)]->val : sDefault.val));}
|
char *fn_name(const struct share_params *p) {return(lp_string((LP_SNUM_OK(p->service) && ServicePtrs[(p->service)]->val) ? ServicePtrs[(p->service)]->val : sDefault.val));}
|
||||||
#define FN_LOCAL_CHAR(fn_name,val) \
|
#define FN_LOCAL_CHAR(fn_name,val) \
|
||||||
@ -2020,9 +2022,9 @@ FN_LOCAL_BOOL(lp_map_hidden, bMap_hidden)
|
|||||||
FN_LOCAL_BOOL(lp_map_archive, bMap_archive)
|
FN_LOCAL_BOOL(lp_map_archive, bMap_archive)
|
||||||
FN_LOCAL_BOOL(lp_store_dos_attributes, bStoreDosAttributes)
|
FN_LOCAL_BOOL(lp_store_dos_attributes, bStoreDosAttributes)
|
||||||
FN_LOCAL_BOOL(lp_dmapi_support, bDmapiSupport)
|
FN_LOCAL_BOOL(lp_dmapi_support, bDmapiSupport)
|
||||||
FN_LOCAL_BOOL(lp_locking, bLocking)
|
FN_LOCAL_PARM_BOOL(lp_locking, bLocking)
|
||||||
FN_LOCAL_INTEGER(lp_strict_locking, iStrictLocking)
|
FN_LOCAL_PARM_INTEGER(lp_strict_locking, iStrictLocking)
|
||||||
FN_LOCAL_BOOL(lp_posix_locking, bPosixLocking)
|
FN_LOCAL_PARM_BOOL(lp_posix_locking, bPosixLocking)
|
||||||
FN_LOCAL_BOOL(lp_share_modes, bShareModes)
|
FN_LOCAL_BOOL(lp_share_modes, bShareModes)
|
||||||
FN_LOCAL_BOOL(lp_oplocks, bOpLocks)
|
FN_LOCAL_BOOL(lp_oplocks, bOpLocks)
|
||||||
FN_LOCAL_BOOL(lp_level2_oplocks, bLevel2OpLocks)
|
FN_LOCAL_BOOL(lp_level2_oplocks, bLevel2OpLocks)
|
||||||
|
@ -53,6 +53,11 @@ END {
|
|||||||
printf "BOOL %s(const struct share_params *p );\n", a[2]
|
printf "BOOL %s(const struct share_params *p );\n", a[2]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/^FN_LOCAL_PARM_INTEGER/ {
|
||||||
|
split($0,a,"[,()]")
|
||||||
|
printf "int %s(const struct share_params *p );\n", a[2]
|
||||||
|
}
|
||||||
|
|
||||||
/^FN_LOCAL_LIST/ {
|
/^FN_LOCAL_LIST/ {
|
||||||
split($0,a,"[,()]")
|
split($0,a,"[,()]")
|
||||||
printf "const char **%s(int );\n", a[2]
|
printf "const char **%s(int );\n", a[2]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user