source: mainline/uspace/lib/ext4/libext4_directory.h@ 7bd2c19

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 7bd2c19 was 7bc4508, checked in by Frantisek Princ <frantisek.princ@…>, 14 years ago

First part of reading htree directory index - the most important functionality (computing hashes) still missing

  • Property mode set to 100644
File size: 5.1 KB
Line 
1/*
2 * Copyright (c) 2011 Frantisek Princ
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup libext4
30 * @{
31 */
32
33#ifndef LIBEXT4_LIBEXT4_DIRECTORY_H_
34#define LIBEXT4_LIBEXT4_DIRECTORY_H_
35
36#include "libext4_filesystem.h"
37#include "libext4_inode.h"
38
39#define EXT4_DIRECTORY_FILENAME_LEN 255
40
41/**
42 * Linked list directory entry structure
43 */
44typedef struct ext4_directory_entry_ll {
45 uint32_t inode; // Inode for the entry
46 uint16_t entry_length; // Distance to the next directory entry
47 uint8_t name_length; // Lower 8 bits of name length
48 union {
49 uint8_t name_length_high; // Higher 8 bits of name length
50 uint8_t inode_type; // Type of referenced inode (in rev >= 0.5)
51 } __attribute__ ((packed));
52 uint8_t name[EXT4_DIRECTORY_FILENAME_LEN]; // Entry name
53} __attribute__ ((packed)) ext4_directory_entry_ll_t;
54
55typedef struct ext4_directory_iterator {
56 ext4_filesystem_t *fs;
57 ext4_inode_ref_t *inode_ref;
58 block_t *current_block;
59 aoff64_t current_offset;
60 ext4_directory_entry_ll_t *current;
61} ext4_directory_iterator_t;
62
63
64/* Structures for indexed directory */
65
66typedef struct ext4_directory_dx_countlimit {
67 uint16_t limit;
68 uint16_t count;
69} ext4_directory_dx_countlimit_t;
70
71typedef struct ext4_directory_dx_dot_entry {
72 uint32_t inode;
73 uint16_t entry_length;
74 uint8_t name_length;
75 uint8_t inode_type;
76 uint8_t name[4];
77} ext4_directory_dx_dot_entry_t;
78
79typedef struct ext4_directory_dx_root_info {
80 uint32_t reserved_zero;
81 uint8_t hash_version;
82 uint8_t info_length;
83 uint8_t indirect_levels;
84 uint8_t unused_flags;
85} ext4_directory_dx_root_info_t;
86
87typedef struct ext4_directory_dx_entry {
88 uint32_t hash;
89 uint32_t block;
90} ext4_directory_dx_entry_t;
91
92typedef struct ext4_directory_dx_root {
93 ext4_directory_dx_dot_entry_t dots[2];
94 ext4_directory_dx_root_info_t info;
95 ext4_directory_dx_entry_t entries[0];
96} ext4_directory_dx_root_t;
97
98typedef struct ext4_directory_dx_hash_info {
99 uint32_t hash;
100 uint32_t minor_hash;
101 uint32_t hash_version;
102 uint32_t *seed;
103} ext4_directory_dx_hash_info_t;
104
105
106#define EXT4_ERR_BAD_DX_DIR (-75000)
107
108#define EXT4_DIRECTORY_DX_HASH_LEGACY 0
109#define EXT4_DIRECTORY_DX_HASH_HALF_MD4 1
110#define EXT4_DIRECTORY_DX_HASH_TEA 2
111#define EXT4_DIRECTORY_DX_HASH_LEGACY_UNSIGNED 3
112#define EXT4_DIRECTORY_DX_HASH_HALF_MD4_UNSIGNED 4
113#define EXT4_DIRECTORY_DX_HASH_TEA_UNSIGNED 5
114
115#define EXT4_DIRECTORY_HTREE_EOF 0x7fffffff
116
117
118extern uint32_t ext4_directory_entry_ll_get_inode(ext4_directory_entry_ll_t *);
119extern uint16_t ext4_directory_entry_ll_get_entry_length(
120 ext4_directory_entry_ll_t *);
121extern uint16_t ext4_directory_entry_ll_get_name_length(
122 ext4_superblock_t *, ext4_directory_entry_ll_t *);
123
124extern uint8_t ext4_directory_dx_root_info_get_hash_version(ext4_directory_dx_root_info_t *);
125extern uint8_t ext4_directory_dx_root_info_get_info_length(ext4_directory_dx_root_info_t *);
126extern uint8_t ext4_directory_dx_root_info_get_indirect_levels(ext4_directory_dx_root_info_t *);
127
128extern uint16_t ext4_directory_dx_countlimit_get_limit(ext4_directory_dx_countlimit_t *);
129extern uint16_t ext4_directory_dx_countlimit_get_count(ext4_directory_dx_countlimit_t *);
130
131extern uint32_t ext4_directory_dx_entry_get_hash(ext4_directory_dx_entry_t *);
132extern uint32_t ext4_directory_dx_entry_get_block(ext4_directory_dx_entry_t *);
133
134extern int ext4_directory_iterator_init(ext4_directory_iterator_t *,
135 ext4_filesystem_t *, ext4_inode_ref_t *, aoff64_t);
136extern int ext4_directory_iterator_next(ext4_directory_iterator_t *);
137extern int ext4_directory_iterator_seek(ext4_directory_iterator_t *, aoff64_t pos);
138extern int ext4_directory_iterator_fini(ext4_directory_iterator_t *);
139extern int ext4_directory_dx_find_entry(ext4_directory_iterator_t *,
140 ext4_filesystem_t *, ext4_inode_ref_t *, const char *);
141
142extern void ext4_directory_hash(ext4_directory_dx_hash_info_t *, const char* name);
143
144#endif
145
146/**
147 * @}
148 */
Note: See TracBrowser for help on using the repository browser.