1 1.25 riastrad /* $NetBSD: ext2fs_bswap.c,v 1.25 2023/08/26 05:22:50 riastradh Exp $ */ 2 1.1 bouyer 3 1.1 bouyer /* 4 1.1 bouyer * Copyright (c) 1997 Manuel Bouyer. 5 1.1 bouyer * 6 1.1 bouyer * Redistribution and use in source and binary forms, with or without 7 1.1 bouyer * modification, are permitted provided that the following conditions 8 1.1 bouyer * are met: 9 1.1 bouyer * 1. Redistributions of source code must retain the above copyright 10 1.1 bouyer * notice, this list of conditions and the following disclaimer. 11 1.1 bouyer * 2. Redistributions in binary form must reproduce the above copyright 12 1.1 bouyer * notice, this list of conditions and the following disclaimer in the 13 1.1 bouyer * documentation and/or other materials provided with the distribution. 14 1.1 bouyer * 15 1.5 bouyer * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 16 1.5 bouyer * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 17 1.5 bouyer * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 18 1.5 bouyer * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 19 1.5 bouyer * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 20 1.5 bouyer * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 21 1.5 bouyer * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 22 1.5 bouyer * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 23 1.5 bouyer * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 24 1.5 bouyer * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 25 1.1 bouyer * 26 1.1 bouyer */ 27 1.7 lukem 28 1.7 lukem #include <sys/cdefs.h> 29 1.25 riastrad __KERNEL_RCSID(0, "$NetBSD: ext2fs_bswap.c,v 1.25 2023/08/26 05:22:50 riastradh Exp $"); 30 1.1 bouyer 31 1.1 bouyer #include <sys/types.h> 32 1.1 bouyer #include <ufs/ext2fs/ext2fs.h> 33 1.1 bouyer #include <ufs/ext2fs/ext2fs_dinode.h> 34 1.6 mycroft 35 1.10 simonb #if defined(_KERNEL) 36 1.10 simonb #include <sys/systm.h> 37 1.10 simonb #else 38 1.6 mycroft #include <string.h> 39 1.6 mycroft #endif 40 1.1 bouyer 41 1.17 jakllsch /* These functions are only needed if native byte order is not little endian */ 42 1.1 bouyer #if BYTE_ORDER == BIG_ENDIAN 43 1.1 bouyer void 44 1.9 xtraeme e2fs_sb_bswap(struct ext2fs *old, struct ext2fs *new) 45 1.1 bouyer { 46 1.13 tsutsui 47 1.1 bouyer /* preserve unused fields */ 48 1.1 bouyer memcpy(new, old, sizeof(struct ext2fs)); 49 1.3 bouyer new->e2fs_icount = bswap32(old->e2fs_icount); 50 1.3 bouyer new->e2fs_bcount = bswap32(old->e2fs_bcount); 51 1.3 bouyer new->e2fs_rbcount = bswap32(old->e2fs_rbcount); 52 1.3 bouyer new->e2fs_fbcount = bswap32(old->e2fs_fbcount); 53 1.3 bouyer new->e2fs_ficount = bswap32(old->e2fs_ficount); 54 1.3 bouyer new->e2fs_first_dblock = bswap32(old->e2fs_first_dblock); 55 1.3 bouyer new->e2fs_log_bsize = bswap32(old->e2fs_log_bsize); 56 1.3 bouyer new->e2fs_fsize = bswap32(old->e2fs_fsize); 57 1.3 bouyer new->e2fs_bpg = bswap32(old->e2fs_bpg); 58 1.3 bouyer new->e2fs_fpg = bswap32(old->e2fs_fpg); 59 1.3 bouyer new->e2fs_ipg = bswap32(old->e2fs_ipg); 60 1.3 bouyer new->e2fs_mtime = bswap32(old->e2fs_mtime); 61 1.3 bouyer new->e2fs_wtime = bswap32(old->e2fs_wtime); 62 1.3 bouyer new->e2fs_mnt_count = bswap16(old->e2fs_mnt_count); 63 1.3 bouyer new->e2fs_max_mnt_count = bswap16(old->e2fs_max_mnt_count); 64 1.3 bouyer new->e2fs_magic = bswap16(old->e2fs_magic); 65 1.3 bouyer new->e2fs_state = bswap16(old->e2fs_state); 66 1.3 bouyer new->e2fs_beh = bswap16(old->e2fs_beh); 67 1.3 bouyer new->e2fs_minrev = bswap16(old->e2fs_minrev); 68 1.3 bouyer new->e2fs_lastfsck = bswap32(old->e2fs_lastfsck); 69 1.3 bouyer new->e2fs_fsckintv = bswap32(old->e2fs_fsckintv); 70 1.3 bouyer new->e2fs_creator = bswap32(old->e2fs_creator); 71 1.3 bouyer new->e2fs_rev = bswap32(old->e2fs_rev); 72 1.3 bouyer new->e2fs_ruid = bswap16(old->e2fs_ruid); 73 1.3 bouyer new->e2fs_rgid = bswap16(old->e2fs_rgid); 74 1.3 bouyer new->e2fs_first_ino = bswap32(old->e2fs_first_ino); 75 1.3 bouyer new->e2fs_inode_size = bswap16(old->e2fs_inode_size); 76 1.3 bouyer new->e2fs_block_group_nr = bswap16(old->e2fs_block_group_nr); 77 1.3 bouyer new->e2fs_features_compat = bswap32(old->e2fs_features_compat); 78 1.3 bouyer new->e2fs_features_incompat = bswap32(old->e2fs_features_incompat); 79 1.3 bouyer new->e2fs_features_rocompat = bswap32(old->e2fs_features_rocompat); 80 1.3 bouyer new->e2fs_algo = bswap32(old->e2fs_algo); 81 1.12 tsutsui new->e2fs_reserved_ngdb = bswap16(old->e2fs_reserved_ngdb); 82 1.23 jdolecek new->e4fs_want_extra_isize = bswap16(old->e4fs_want_extra_isize); 83 1.1 bouyer } 84 1.1 bouyer 85 1.21 jdolecek void 86 1.21 jdolecek e2fs_i_bswap(struct ext2fs_dinode *old, struct ext2fs_dinode *new, size_t isize) 87 1.1 bouyer { 88 1.25 riastrad /* preserve non-swapped and unused fields */ 89 1.21 jdolecek memcpy(new, old, isize); 90 1.13 tsutsui 91 1.21 jdolecek /* swap what needs to be swapped */ 92 1.1 bouyer new->e2di_mode = bswap16(old->e2di_mode); 93 1.1 bouyer new->e2di_uid = bswap16(old->e2di_uid); 94 1.1 bouyer new->e2di_gid = bswap16(old->e2di_gid); 95 1.1 bouyer new->e2di_nlink = bswap16(old->e2di_nlink); 96 1.1 bouyer new->e2di_size = bswap32(old->e2di_size); 97 1.1 bouyer new->e2di_atime = bswap32(old->e2di_atime); 98 1.1 bouyer new->e2di_ctime = bswap32(old->e2di_ctime); 99 1.1 bouyer new->e2di_mtime = bswap32(old->e2di_mtime); 100 1.1 bouyer new->e2di_dtime = bswap32(old->e2di_dtime); 101 1.1 bouyer new->e2di_nblock = bswap32(old->e2di_nblock); 102 1.1 bouyer new->e2di_flags = bswap32(old->e2di_flags); 103 1.18 jakllsch new->e2di_version = bswap32(old->e2di_version); 104 1.1 bouyer new->e2di_gen = bswap32(old->e2di_gen); 105 1.1 bouyer new->e2di_facl = bswap32(old->e2di_facl); 106 1.22 jdolecek new->e2di_size_high = bswap32(old->e2di_size_high); 107 1.18 jakllsch new->e2di_nblock_high = bswap16(old->e2di_nblock_high); 108 1.18 jakllsch new->e2di_facl_high = bswap16(old->e2di_facl_high); 109 1.14 mrg new->e2di_uid_high = bswap16(old->e2di_uid_high); 110 1.14 mrg new->e2di_gid_high = bswap16(old->e2di_gid_high); 111 1.21 jdolecek new->e2di_checksum_low = bswap16(old->e2di_checksum_low); 112 1.21 jdolecek 113 1.21 jdolecek /* 114 1.21 jdolecek * Following fields are only supported for inode sizes bigger 115 1.21 jdolecek * than the old ext2 one 116 1.21 jdolecek */ 117 1.21 jdolecek if (isize == EXT2_REV0_DINODE_SIZE) 118 1.21 jdolecek return; 119 1.21 jdolecek 120 1.21 jdolecek new->e2di_extra_isize = bswap16(old->e2di_extra_isize); 121 1.21 jdolecek new->e2di_checksum_high = bswap16(old->e2di_checksum_high); 122 1.21 jdolecek 123 1.21 jdolecek /* Following fields are ext4, might not be actually present */ 124 1.21 jdolecek if (EXT2_DINODE_FITS(new, e2di_ctime_extra, isize)) 125 1.21 jdolecek new->e2di_ctime_extra = bswap32(old->e2di_ctime_extra); 126 1.21 jdolecek if (EXT2_DINODE_FITS(new, e2di_mtime_extra, isize)) 127 1.21 jdolecek new->e2di_mtime_extra = bswap32(old->e2di_mtime_extra); 128 1.21 jdolecek if (EXT2_DINODE_FITS(new, e2di_atime_extra, isize)) 129 1.21 jdolecek new->e2di_atime_extra = bswap32(old->e2di_atime_extra); 130 1.21 jdolecek if (EXT2_DINODE_FITS(new, e2di_crtime, isize)) 131 1.21 jdolecek new->e2di_crtime = bswap32(old->e2di_crtime); 132 1.21 jdolecek if (EXT2_DINODE_FITS(new, e2di_crtime_extra, isize)) 133 1.21 jdolecek new->e2di_crtime_extra = bswap32(old->e2di_crtime_extra); 134 1.21 jdolecek if (EXT2_DINODE_FITS(new, e2di_version_high, isize)) 135 1.21 jdolecek new->e2di_version_high = bswap32(old->e2di_version_high); 136 1.21 jdolecek if (EXT2_DINODE_FITS(new, e2di_projid, isize)) 137 1.21 jdolecek new->e2di_projid = bswap32(old->e2di_projid); 138 1.1 bouyer } 139 1.1 bouyer #endif 140