summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeremy Allison <jra@samba.org>2006-04-12 23:00:58 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 11:16:00 -0500
commitfdd55885da4e3270c9bb5c4a682c1cd980a6040a (patch)
treeae6d1de9ac0465034dd32137cfd7a96bbacc31f3
parent1014fa19b53b2bd0cc3533a5c54447433376d3e6 (diff)
downloadsamba-fdd55885da4e3270c9bb5c4a682c1cd980a6040a.tar.gz
samba-fdd55885da4e3270c9bb5c4a682c1cd980a6040a.tar.bz2
samba-fdd55885da4e3270c9bb5c4a682c1cd980a6040a.zip
r15060: The brlock code gets called a lot. Ensure we keep the
key around while we're using it - saves many calls to locking_key() (now deleted). Jeremy. (This used to be commit 2f8b527dcf4a36fbb933ce79c720c0425de76b4a)
-rw-r--r--source3/include/smb.h8
-rw-r--r--source3/locking/brlock.c42
2 files changed, 21 insertions, 29 deletions
diff --git a/source3/include/smb.h b/source3/include/smb.h
index 9531ae2903..be994a9fdd 100644
--- a/source3/include/smb.h
+++ b/source3/include/smb.h
@@ -836,10 +836,18 @@ struct parm_struct {
enum brl_type {READ_LOCK, WRITE_LOCK, PENDING_LOCK, UNLOCK_LOCK};
enum brl_flavour {WINDOWS_LOCK = 0, POSIX_LOCK = 1};
+/* The key used in the brlock database. */
+
+struct lock_key {
+ SMB_DEV_T device;
+ SMB_INO_T inode;
+};
+
struct byte_range_lock {
files_struct *fsp;
unsigned int num_locks;
BOOL modified;
+ struct lock_key key;
void *lock_data;
};
diff --git a/source3/locking/brlock.c b/source3/locking/brlock.c
index 5d64e66448..60c94c2b98 100644
--- a/source3/locking/brlock.c
+++ b/source3/locking/brlock.c
@@ -55,13 +55,6 @@ struct lock_struct {
enum brl_flavour lock_flav;
};
-/* The key used in the brlock database. */
-
-struct lock_key {
- SMB_DEV_T device;
- SMB_INO_T inode;
-};
-
/* The open brlock.tdb database. */
static TDB_CONTEXT *tdb;
@@ -87,23 +80,6 @@ static void print_lock_struct(unsigned int i, struct lock_struct *pls)
}
/****************************************************************************
- Create a locking key - ensuring zero filled for pad purposes.
-****************************************************************************/
-
-static TDB_DATA locking_key(SMB_DEV_T dev, SMB_INO_T inode)
-{
- static struct lock_key key;
- TDB_DATA kbuf;
-
- memset(&key, '\0', sizeof(key));
- key.device = dev;
- key.inode = inode;
- kbuf.dptr = (char *)&key;
- kbuf.dsize = sizeof(key);
- return kbuf;
-}
-
-/****************************************************************************
See if two locking contexts are equal.
****************************************************************************/
@@ -1332,7 +1308,10 @@ static int byte_range_lock_destructor(void *p)
{
struct byte_range_lock *br_lck =
talloc_get_type_abort(p, struct byte_range_lock);
- TDB_DATA key = locking_key(br_lck->fsp->dev, br_lck->fsp->inode);
+ TDB_DATA key;
+
+ key.dptr = (char *)&br_lck->key;
+ key.dsize = sizeof(struct lock_key);
if (!br_lck->modified) {
goto done;
@@ -1355,8 +1334,8 @@ static int byte_range_lock_destructor(void *p)
done:
- SAFE_FREE(br_lck->lock_data);
tdb_chainunlock(tdb, key);
+ SAFE_FREE(br_lck->lock_data);
return 0;
}
@@ -1368,11 +1347,10 @@ static int byte_range_lock_destructor(void *p)
struct byte_range_lock *brl_get_locks(TALLOC_CTX *mem_ctx,
files_struct *fsp)
{
- TDB_DATA key = locking_key(fsp->dev, fsp->inode);
+ TDB_DATA key;
TDB_DATA data;
- struct byte_range_lock *br_lck;
+ struct byte_range_lock *br_lck = TALLOC_P(mem_ctx, struct byte_range_lock);
- br_lck = TALLOC_P(mem_ctx, struct byte_range_lock);
if (br_lck == NULL) {
return NULL;
}
@@ -1380,6 +1358,12 @@ struct byte_range_lock *brl_get_locks(TALLOC_CTX *mem_ctx,
br_lck->fsp = fsp;
br_lck->num_locks = 0;
br_lck->modified = False;
+ memset(&br_lck->key, '\0', sizeof(struct lock_key));
+ br_lck->key.device = fsp->dev;
+ br_lck->key.inode = fsp->inode;
+
+ key.dptr = (char *)&br_lck->key;
+ key.dsize = sizeof(struct lock_key);
if (tdb_chainlock(tdb, key) != 0) {
DEBUG(3, ("Could not lock byte range lock entry\n"));