From d6d70a7315d5a39130928e031e3e72e7f790ac83 Mon Sep 17 00:00:00 2001 From: David Oberhollenzer Date: Tue, 17 Sep 2019 12:50:04 +0200 Subject: Add helper function to turn sqfs inode into struct stat Signed-off-by: David Oberhollenzer --- lib/sqfshelper/inode_stat.c | 78 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 lib/sqfshelper/inode_stat.c (limited to 'lib/sqfshelper/inode_stat.c') diff --git a/lib/sqfshelper/inode_stat.c b/lib/sqfshelper/inode_stat.c new file mode 100644 index 0000000..67ff764 --- /dev/null +++ b/lib/sqfshelper/inode_stat.c @@ -0,0 +1,78 @@ +/* SPDX-License-Identifier: GPL-3.0-or-later */ +/* + * inode_stat.c + * + * Copyright (C) 2019 David Oberhollenzer + */ +#include "config.h" + +#include "highlevel.h" + +#include +#include +#include + +int inode_stat(const sqfs_tree_node_t *node, struct stat *sb) +{ + memset(sb, 0, sizeof(*sb)); + + sb->st_mode = node->inode->base.mode; + sb->st_uid = node->uid; + sb->st_gid = node->gid; + sb->st_atime = node->inode->base.mod_time; + sb->st_mtime = node->inode->base.mod_time; + sb->st_ctime = node->inode->base.mod_time; + sb->st_ino = node->inode->base.inode_number; + sb->st_nlink = 1; + sb->st_blksize = 512; + + switch (node->inode->base.type) { + case SQFS_INODE_BDEV: + case SQFS_INODE_CDEV: + sb->st_rdev = node->inode->data.dev.devno; + sb->st_nlink = node->inode->data.dev.nlink; + break; + case SQFS_INODE_EXT_BDEV: + case SQFS_INODE_EXT_CDEV: + sb->st_rdev = node->inode->data.dev_ext.devno; + sb->st_nlink = node->inode->data.dev_ext.nlink; + break; + case SQFS_INODE_FIFO: + case SQFS_INODE_SOCKET: + sb->st_nlink = node->inode->data.ipc.nlink; + break; + case SQFS_INODE_EXT_FIFO: + case SQFS_INODE_EXT_SOCKET: + sb->st_nlink = node->inode->data.ipc_ext.nlink; + break; + case SQFS_INODE_SLINK: + sb->st_size = node->inode->data.slink.target_size; + sb->st_nlink = node->inode->data.slink.nlink; + break; + case SQFS_INODE_EXT_SLINK: + sb->st_size = node->inode->data.slink_ext.target_size; + sb->st_nlink = node->inode->data.slink_ext.nlink; + break; + case SQFS_INODE_FILE: + sb->st_size = node->inode->data.file.file_size; + break; + case SQFS_INODE_EXT_FILE: + sb->st_size = node->inode->data.file_ext.file_size; + sb->st_nlink = node->inode->data.file_ext.nlink; + break; + case SQFS_INODE_DIR: + sb->st_size = node->inode->data.dir.size; + sb->st_nlink = node->inode->data.dir.nlink; + break; + case SQFS_INODE_EXT_DIR: + sb->st_size = node->inode->data.dir_ext.size; + sb->st_nlink = node->inode->data.dir_ext.nlink; + break; + } + + sb->st_blocks = sb->st_size / sb->st_blksize; + if (sb->st_size % sb->st_blksize) + sb->st_blocks += 1; + + return 0; +} -- cgit v1.2.3