X-Git-Url: https://git.ozlabs.org/?a=blobdiff_plain;f=ccan%2Ftdb2%2Ftdb.c;h=09333a26801380fb232a2fc444eb11473de8805e;hb=f1069e4a2d5a8115695fb8ea3e78dbdcf389aead;hp=254aac5f25a94e1daae9692ea03a9c42b1a6ddce;hpb=f6067e4cbd7b7415571f12438aec00faec5657fb;p=ccan diff --git a/ccan/tdb2/tdb.c b/ccan/tdb2/tdb.c index 254aac5f..09333a26 100644 --- a/ccan/tdb2/tdb.c +++ b/ccan/tdb2/tdb.c @@ -422,7 +422,6 @@ enum TDB_ERROR tdb_parse_record_(struct tdb_context *tdb, tdb_off_t off; struct tdb_used_record rec; struct hash_info h; - TDB_DATA data; enum TDB_ERROR ecode; off = find_and_lock(tdb, key, F_RDLCK, &h, &rec, NULL); @@ -433,16 +432,16 @@ enum TDB_ERROR tdb_parse_record_(struct tdb_context *tdb, if (!off) { ecode = TDB_ERR_NOEXIST; } else { - data.dsize = rec_data_length(&rec); - data.dptr = (void *)tdb_access_read(tdb, - off + sizeof(rec) - + key.dsize, - data.dsize, false); - if (TDB_PTR_IS_ERR(data.dptr)) { - ecode = TDB_PTR_ERR(data.dptr); + const void *dptr; + dptr = tdb_access_read(tdb, off + sizeof(rec) + key.dsize, + rec_data_length(&rec), false); + if (TDB_PTR_IS_ERR(dptr)) { + ecode = TDB_PTR_ERR(dptr); } else { + TDB_DATA data = tdb_mkdata(dptr, rec_data_length(&rec)); + ecode = parse(key, data, p); - tdb_access_release(tdb, data.dptr); + tdb_access_release(tdb, dptr); } }