Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/ufs/ext2fs sync with hrishi's git
details: https://anonhg.NetBSD.org/src/rev/260ed7f3c698
branches: trunk
changeset: 347085:260ed7f3c698
user: christos <christos%NetBSD.org@localhost>
date: Sat Aug 13 07:25:29 2016 +0000
description:
sync with hrishi's git
diffstat:
sys/ufs/ext2fs/ext2fs_lookup.c | 59 +++++++++++++++++++++++++----------------
1 files changed, 36 insertions(+), 23 deletions(-)
diffs (94 lines):
diff -r c7991fc2f020 -r 260ed7f3c698 sys/ufs/ext2fs/ext2fs_lookup.c
--- a/sys/ufs/ext2fs/ext2fs_lookup.c Fri Aug 12 20:45:05 2016 +0000
+++ b/sys/ufs/ext2fs/ext2fs_lookup.c Sat Aug 13 07:25:29 2016 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ext2fs_lookup.c,v 1.82 2016/08/09 20:18:08 christos Exp $ */
+/* $NetBSD: ext2fs_lookup.c,v 1.83 2016/08/13 07:25:29 christos Exp $ */
/*
* Modified for NetBSD 1.2E
@@ -48,7 +48,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ext2fs_lookup.c,v 1.82 2016/08/09 20:18:08 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ext2fs_lookup.c,v 1.83 2016/08/13 07:25:29 christos Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -389,7 +389,7 @@
* If we got an error or we want to find '.' or '..' entry,
* we will fall back to linear search.
*/
- if (ext2fs_htree_has_idx(dp) && ext2fs_is_dot_entry(cnp)) {
+ if (!ext2fs_is_dot_entry(cnp) && ext2fs_htree_has_idx(dp)) {
numdirpasses = 1;
entryoffsetinblock = 0;
@@ -707,6 +707,37 @@
cache_enter(vdp, *vpp, cnp->cn_nameptr, cnp->cn_namelen, cnp->cn_flags);
return 0;
}
+static void
+ext2fs_accumulatespace (struct ext2fs_searchslot *ssp, struct ext2fs_direct *ep,
+ doff_t *offp)
+{
+ int size = ep->e2d_reclen;
+
+ if (ep->e2d_ino != 0)
+ size -= EXT2_DIR_REC_LEN(ep->e2d_namlen);
+
+ if (size <= 0)
+ return;
+
+ if (size >= ssp->slotneeded) {
+ ssp->slotstatus = FOUND;
+ ssp->slotoffset = *offp;
+ ssp->slotsize = ep->e2d_reclen;
+ return;
+ }
+
+ if (ssp->slotstatus != NONE)
+ return;
+
+ ssp->slotfreespace += size;
+ if (ssp->slotoffset == -1)
+ ssp->slotoffset = *offp;
+
+ if (ssp->slotfreespace >= ssp->slotneeded) {
+ ssp->slotstatus = COMPACT;
+ ssp->slotsize = *offp + ep->e2d_reclen - ssp->slotoffset;
+ }
+}
int
ext2fs_search_dirblock(struct inode *ip, void *data, int *foundp,
@@ -746,26 +777,8 @@
* in the current block so that we can determine if
* compaction is viable.
*/
- if (ssp->slotstatus != FOUND) {
- int size = ep->e2d_reclen;
-
- if (ep->e2d_ino != 0)
- size -= EXT2_DIR_REC_LEN(ep->e2d_namlen);
- if (size >= ssp->slotneeded) {
- ssp->slotstatus = FOUND;
- ssp->slotoffset = *offp;
- ssp->slotsize = ep->e2d_reclen;
- } else if (size > 0 && ssp->slotstatus == NONE) {
- ssp->slotfreespace += size;
- if (ssp->slotoffset == -1)
- ssp->slotoffset = *offp;
- if (ssp->slotfreespace >= ssp->slotneeded) {
- ssp->slotstatus = COMPACT;
- ssp->slotsize = *offp + ep->e2d_reclen -
- ssp->slotoffset;
- }
- }
- }
+ if (ssp->slotstatus != FOUND)
+ ext2fs_accumulatespace(ssp, ep, offp);
/*
* Check for a name match.
Home |
Main Index |
Thread Index |
Old Index