diff options
author | Sascha Hauer <s.hauer@pengutronix.de> | 2018-03-29 13:47:12 +0200 |
---|---|---|
committer | Sascha Hauer <s.hauer@pengutronix.de> | 2018-07-11 09:58:38 +0200 |
commit | b3fbfad7aeaf8ee36216e1d14b5d7be27ba612de (patch) | |
tree | 61299cecd2c49902ff831813daa81926bacd69db /include/dirent.h | |
parent | 4c7b877a5c90bcf80d42086d246981f0686d1e27 (diff) | |
download | barebox-b3fbfad7aeaf8ee36216e1d14b5d7be27ba612de.tar.gz barebox-b3fbfad7aeaf8ee36216e1d14b5d7be27ba612de.tar.xz |
fs: dentry cache implementation
This adds the Linux dentry cache implementation to barebox.
Until now every filesystem driver resolves the full path to a file for
itself. This leads to code duplication and is error prone since
resolving paths is a complicated task. Also it can narrow down the
lookup performance since barebox only knows ASCII paths and has no way
of caching lookups.
With this patch we get the Linux dcache implementation. The path
resolving code from fs/namei.c is nearly taken as-is, minus the RCU
and locking code. Dcaching is made simple as of now: We simply cache
everything and never release any dentries. Although we do reference
counting for inodes and dentries it is effectively not used yet.
We never free anything until a fs is unmounted in which case we free
everything no matter if references are taken or not.
This patch also contains a wrapper in fs/legacy.c to support
filesystems with the old API.
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'include/dirent.h')
-rw-r--r-- | include/dirent.h | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/include/dirent.h b/include/dirent.h index 5ee4c2063e..1df5d90452 100644 --- a/include/dirent.h +++ b/include/dirent.h @@ -1,6 +1,8 @@ #ifndef __DIRENT_H #define __DIRENT_H +#include <linux/list.h> + struct dirent { char d_name[256]; }; @@ -11,6 +13,7 @@ typedef struct dir { struct node_d *node; struct dirent d; void *priv; /* private data for the fs driver */ + struct list_head entries; } DIR; DIR *opendir(const char *pathname); |