Tom Rini | 83d290c | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
Uma Shankar | a159643 | 2012-05-25 21:21:44 +0530 | [diff] [blame] | 2 | /* |
| 3 | * (C) Copyright 2011 - 2012 Samsung Electronics |
| 4 | * EXT4 filesystem implementation in Uboot by |
| 5 | * Uma Shankar <uma.shankar@samsung.com> |
| 6 | * Manjunatha C Achar <a.manjunatha@samsung.com> |
| 7 | * |
| 8 | * ext4ls and ext4load : based on ext2 ls load support in Uboot. |
| 9 | * |
| 10 | * (C) Copyright 2004 |
| 11 | * esd gmbh <www.esd-electronics.com> |
| 12 | * Reinhard Arlt <reinhard.arlt@esd-electronics.com> |
| 13 | * |
| 14 | * based on code from grub2 fs/ext2.c and fs/fshelp.c by |
| 15 | * GRUB -- GRand Unified Bootloader |
| 16 | * Copyright (C) 2003, 2004 Free Software Foundation, Inc. |
| 17 | * |
Uma Shankar | ed34f34 | 2012-05-25 21:22:49 +0530 | [diff] [blame] | 18 | * ext4write : Based on generic ext4 protocol. |
Uma Shankar | a159643 | 2012-05-25 21:21:44 +0530 | [diff] [blame] | 19 | */ |
| 20 | |
| 21 | #ifndef __EXT4_COMMON__ |
| 22 | #define __EXT4_COMMON__ |
| 23 | #include <ext_common.h> |
| 24 | #include <ext4fs.h> |
| 25 | #include <malloc.h> |
Simon Glass | 90526e9 | 2020-05-10 11:39:56 -0600 | [diff] [blame] | 26 | #include <asm/cache.h> |
Masahiro Yamada | 1221ce4 | 2016-09-21 11:28:55 +0900 | [diff] [blame] | 27 | #include <linux/errno.h> |
Stephen Warren | 03e2ecf | 2012-10-22 06:43:50 +0000 | [diff] [blame] | 28 | #if defined(CONFIG_EXT4_WRITE) |
Uma Shankar | ed34f34 | 2012-05-25 21:22:49 +0530 | [diff] [blame] | 29 | #include "ext4_journal.h" |
Pali Rohár | 4f0e77f | 2022-04-12 11:20:43 +0200 | [diff] [blame] | 30 | #include <linux/crc16.h> |
Uma Shankar | ed34f34 | 2012-05-25 21:22:49 +0530 | [diff] [blame] | 31 | #endif |
Uma Shankar | a159643 | 2012-05-25 21:21:44 +0530 | [diff] [blame] | 32 | |
| 33 | #define YES 1 |
| 34 | #define NO 0 |
Uma Shankar | a159643 | 2012-05-25 21:21:44 +0530 | [diff] [blame] | 35 | #define RECOVER 1 |
| 36 | #define SCAN 0 |
| 37 | |
| 38 | #define S_IFLNK 0120000 /* symbolic link */ |
| 39 | #define BLOCK_NO_ONE 1 |
Egbert Eich | 50ce4c0 | 2013-05-01 01:13:19 +0000 | [diff] [blame] | 40 | #define SUPERBLOCK_START (2 * 512) |
Uma Shankar | a159643 | 2012-05-25 21:21:44 +0530 | [diff] [blame] | 41 | #define SUPERBLOCK_SIZE 1024 |
| 42 | #define F_FILE 1 |
| 43 | |
Stephen Warren | 55b523b | 2012-09-18 08:05:28 +0000 | [diff] [blame] | 44 | static inline void *zalloc(size_t size) |
| 45 | { |
| 46 | void *p = memalign(ARCH_DMA_MINALIGN, size); |
| 47 | memset(p, 0, size); |
| 48 | return p; |
| 49 | } |
Uma Shankar | a159643 | 2012-05-25 21:21:44 +0530 | [diff] [blame] | 50 | |
Uma Shankar | a159643 | 2012-05-25 21:21:44 +0530 | [diff] [blame] | 51 | int ext4fs_read_inode(struct ext2_data *data, int ino, |
| 52 | struct ext2_inode *inode); |
Suriyan Ramasami | 9f12cd0 | 2014-11-17 14:39:36 -0800 | [diff] [blame] | 53 | int ext4fs_read_file(struct ext2fs_node *node, loff_t pos, loff_t len, |
| 54 | char *buf, loff_t *actread); |
Uma Shankar | a159643 | 2012-05-25 21:21:44 +0530 | [diff] [blame] | 55 | int ext4fs_find_file(const char *path, struct ext2fs_node *rootnode, |
| 56 | struct ext2fs_node **foundnode, int expecttype); |
| 57 | int ext4fs_iterate_dir(struct ext2fs_node *dir, char *name, |
| 58 | struct ext2fs_node **fnode, int *ftype); |
Uma Shankar | ed34f34 | 2012-05-25 21:22:49 +0530 | [diff] [blame] | 59 | |
Stephen Warren | 03e2ecf | 2012-10-22 06:43:50 +0000 | [diff] [blame] | 60 | #if defined(CONFIG_EXT4_WRITE) |
Uma Shankar | ed34f34 | 2012-05-25 21:22:49 +0530 | [diff] [blame] | 61 | uint32_t ext4fs_div_roundup(uint32_t size, uint32_t n); |
Michael Walle | 58a9ecb | 2016-09-01 11:21:40 +0200 | [diff] [blame] | 62 | uint16_t ext4fs_checksum_update(unsigned int i); |
Uma Shankar | ed34f34 | 2012-05-25 21:22:49 +0530 | [diff] [blame] | 63 | int ext4fs_get_parent_inode_num(const char *dirname, char *dname, int flags); |
Stefan Brüns | a0d767e | 2016-09-06 04:36:42 +0200 | [diff] [blame] | 64 | int ext4fs_update_parent_dentry(char *filename, int file_type); |
Michael Walle | 58a9ecb | 2016-09-01 11:21:40 +0200 | [diff] [blame] | 65 | uint32_t ext4fs_get_new_blk_no(void); |
Uma Shankar | ed34f34 | 2012-05-25 21:22:49 +0530 | [diff] [blame] | 66 | int ext4fs_get_new_inode_no(void); |
| 67 | void ext4fs_reset_block_bmap(long int blockno, unsigned char *buffer, |
| 68 | int index); |
| 69 | int ext4fs_set_block_bmap(long int blockno, unsigned char *buffer, int index); |
| 70 | int ext4fs_set_inode_bmap(int inode_no, unsigned char *buffer, int index); |
| 71 | void ext4fs_reset_inode_bmap(int inode_no, unsigned char *buffer, int index); |
| 72 | int ext4fs_iget(int inode_no, struct ext2_inode *inode); |
| 73 | void ext4fs_allocate_blocks(struct ext2_inode *file_inode, |
| 74 | unsigned int total_remaining_blocks, |
| 75 | unsigned int *total_no_of_block); |
Jean-Jacques Hiblot | b000180 | 2019-02-13 12:15:24 +0100 | [diff] [blame] | 76 | void put_ext4(uint64_t off, const void *buf, uint32_t size); |
Stefan Brüns | 9f5dd8b | 2016-09-20 01:12:42 +0200 | [diff] [blame] | 77 | struct ext2_block_group *ext4fs_get_group_descriptor |
| 78 | (const struct ext_filesystem *fs, uint32_t bg_idx); |
| 79 | uint64_t ext4fs_bg_get_block_id(const struct ext2_block_group *bg, |
| 80 | const struct ext_filesystem *fs); |
| 81 | uint64_t ext4fs_bg_get_inode_id(const struct ext2_block_group *bg, |
| 82 | const struct ext_filesystem *fs); |
| 83 | uint64_t ext4fs_bg_get_inode_table_id(const struct ext2_block_group *bg, |
| 84 | const struct ext_filesystem *fs); |
| 85 | uint64_t ext4fs_sb_get_free_blocks(const struct ext2_sblock *sb); |
| 86 | void ext4fs_sb_set_free_blocks(struct ext2_sblock *sb, uint64_t free_blocks); |
| 87 | uint32_t ext4fs_bg_get_free_blocks(const struct ext2_block_group *bg, |
| 88 | const struct ext_filesystem *fs); |
Uma Shankar | ed34f34 | 2012-05-25 21:22:49 +0530 | [diff] [blame] | 89 | #endif |
Uma Shankar | a159643 | 2012-05-25 21:21:44 +0530 | [diff] [blame] | 90 | #endif |