1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-11 05:18:09 +03:00

tdb: Speed up tdb_oob()

This is common between both implementations of tdb_oob(). It's
faster if we don't have to dereference function pointers.

Signed-off-by: Volker Lendecke <vl@samba.org>
Reviewed-by: Jeremy Allison <jra@samba.org>
This commit is contained in:
Volker Lendecke 2019-08-04 12:18:19 +02:00 committed by Jeremy Allison
parent 5a388453e0
commit 897bffa816
2 changed files with 17 additions and 1 deletions

View File

@ -150,6 +150,11 @@ static int tdb_notrans_oob(
return -1;
}
/*
* This duplicates functionality from tdb_oob(). Don't remove:
* we still have direct callers of tdb->methods->tdb_oob()
* inside transaction.c.
*/
if (off + len <= tdb->map_size)
return 0;
if (tdb->flags & TDB_INTERNAL) {
@ -664,7 +669,13 @@ int tdb_expand(struct tdb_context *tdb, tdb_off_t size)
int tdb_oob(struct tdb_context *tdb, tdb_off_t off, tdb_len_t len, int probe)
{
int ret = tdb->methods->tdb_oob(tdb, off, len, probe);
int ret;
if (likely((off + len >= off) && (off + len <= tdb->map_size))) {
return 0;
}
ret = tdb->methods->tdb_oob(tdb, off, len, probe);
return ret;
}

View File

@ -378,6 +378,11 @@ static void transaction_next_hash_chain(struct tdb_context *tdb, uint32_t *chain
static int transaction_oob(struct tdb_context *tdb, tdb_off_t off,
tdb_len_t len, int probe)
{
/*
* This duplicates functionality from tdb_oob(). Don't remove:
* we still have direct callers of tdb->methods->tdb_oob()
* inside transaction.c.
*/
if (off + len >= off && off + len <= tdb->map_size) {
return 0;
}