shithub: lwext4

Download patch

ref: 400b183c480845e1cd2c2f49f74baade00d2653c
parent: 01c6151eb539b10954a8459193482524f4365242
author: root <[email protected]>
date: Sun Sep 20 12:31:38 EDT 2015

Hardlink suppert: ext4_flink interface proposed.

--- a/lwext4/ext4.c
+++ b/lwext4/ext4.c
@@ -881,6 +881,53 @@
 	return r;
 }
 
+int ext4_flink(const char *path, const char *hardlink_path)
+{
+	int r;
+	ext4_file f;
+	uint32_t name_off;
+	bool child_loaded = false;
+	uint32_t parent_inode, child_inode;
+	struct ext4_mountpoint *mp = ext4_get_mount(path);
+	struct ext4_mountpoint *target_mp = ext4_get_mount(hardlink_path);
+	struct ext4_inode_ref child_ref;
+
+	if (!mp)
+		return ENOENT;
+
+	/* Will that happen? Anyway return EINVAL for such case. */
+	if (mp != target_mp)
+		return EINVAL;
+
+	EXT4_MP_LOCK(mp);
+
+	r = ext4_generic_open2(&f, path, O_RDONLY,
+			       EXT4_DIRECTORY_FILETYPE_UNKNOWN,
+			       &parent_inode, &name_off);
+	if (r != EOK)
+		goto Finish;
+
+	child_inode = f.inode;
+	ext4_fclose(&f);
+
+	/*We have file to unlink. Load it.*/
+	r = ext4_fs_get_inode_ref(&mp->fs, child_inode, &child_ref);
+	if (r != EOK)
+		goto Finish;
+
+	child_loaded = true;
+
+	r = __ext4_create_hardlink(hardlink_path, &child_ref);
+
+Finish:
+	if (child_loaded)
+		ext4_fs_put_inode_ref(&child_ref);
+
+	EXT4_MP_UNLOCK(mp);
+	return r;
+
+}
+
 int ext4_frename(const char *path, const char *new_path)
 {
 	int r;
--- a/lwext4/ext4.h
+++ b/lwext4/ext4.h
@@ -258,6 +258,12 @@
  * @return  standard error code */
 int ext4_fremove(const char *path);
 
+/**@brief   create a hardlink for a file.
+ * @param   path path to file
+ * @param   hardlink_path path of hardlink
+ * @return  standard error code */
+int ext4_flink(const char *path, const char *hardlink_path);
+
 /**@brief Rename file
  * @param path source
  * @param new_path destination