diff options
author | Justin Lecher <jlec@gentoo.org> | 2010-11-19 18:49:02 +0000 |
---|---|---|
committer | Justin Lecher <jlec@gentoo.org> | 2010-11-19 18:49:02 +0000 |
commit | 5ef9821a2f201fa17856e6b4d29cc32b593b61e7 (patch) | |
tree | 875dc7b0788dba19219d671022005ec8e183d1bc /sys-fs/e2fsprogs/files | |
parent | bump a new snapshot (diff) | |
download | gentoo-2-5ef9821a2f201fa17856e6b4d29cc32b593b61e7.tar.gz gentoo-2-5ef9821a2f201fa17856e6b4d29cc32b593b61e7.tar.bz2 gentoo-2-5ef9821a2f201fa17856e6b4d29cc32b593b61e7.zip |
Import Prefix Changes
(Portage version: 2.2.0_alpha4/cvs/Linux x86_64)
Diffstat (limited to 'sys-fs/e2fsprogs/files')
5 files changed, 2150 insertions, 0 deletions
diff --git a/sys-fs/e2fsprogs/files/e2fsprogs-1.41-mint.patch b/sys-fs/e2fsprogs/files/e2fsprogs-1.41-mint.patch new file mode 100644 index 000000000000..43ed92d959c8 --- /dev/null +++ b/sys-fs/e2fsprogs/files/e2fsprogs-1.41-mint.patch @@ -0,0 +1,1947 @@ +http://bugs.gentoo.org/show_bug.cgi?id=256234 +http://sourceforge.net/tracker/?func=detail&aid=2550325&group_id=2406&atid=302406 + +diff -ur --new-file e2fsprogs-1.41.3/lib/ext2fs/Makefile.in e2fsprogs-1.41.3-mint/lib/ext2fs/Makefile.in +--- e2fsprogs-1.41.3/lib/ext2fs/Makefile.in 2008-10-07 14:22:39.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/lib/ext2fs/Makefile.in 2009-01-23 10:48:50.000000000 +0000 +@@ -74,7 +74,9 @@ + unix_io.o \ + unlink.o \ + valid_blk.o \ +- version.o ++ version.o \ ++ mint_io.o \ ++ xhdi.o + + SRCS= ext2_err.c \ + $(srcdir)/alloc.c \ +@@ -146,6 +148,8 @@ + $(srcdir)/unlink.c \ + $(srcdir)/valid_blk.c \ + $(srcdir)/version.c \ ++ $(srcdir)/mint_io.c \ ++ $(srcdir)/xhdi.c \ + $(srcdir)/write_bb_file.c + + HFILES= bitops.h ext2fs.h ext2_io.h ext2_fs.h ext2_ext_attr.h ext3_extents.h \ +diff -ur --new-file e2fsprogs-1.41.3/lib/ext2fs/bitops.h e2fsprogs-1.41.3-mint/lib/ext2fs/bitops.h +--- e2fsprogs-1.41.3/lib/ext2fs/bitops.h 2008-10-07 14:22:39.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/lib/ext2fs/bitops.h 2009-01-23 10:47:35.000000000 +0000 +@@ -125,7 +125,7 @@ + */ + #ifdef NO_INLINE_FUNCS + #if (defined(__GNUC__) && (defined(__i386__) || defined(__i486__) || \ +- defined(__i586__) || defined(__mc68000__))) ++ defined(__i586__) || defined(__mc68020__))) + /* This prevents bitops.c from trying to include the C */ + /* function version of these functions */ + #define _EXT2_HAVE_ASM_BITOPS_ +@@ -246,7 +246,7 @@ + #endif /* i386 */ + + #if ((defined __GNUC__) && !defined(_EXT2_USE_C_VERSIONS_) && \ +- (defined(__mc68000__))) ++ (defined(__mc68020__))) + + #define _EXT2_HAVE_ASM_BITOPS_ + +@@ -280,6 +280,50 @@ + return retval; + } + ++#elif defined(__mc68000__) ++ ++#define _EXT2_HAVE_ASM_BITOPS_ ++ ++_INLINE_ int ++ext2fs_set_bit (unsigned int nr, void *addr) ++{ ++ int mask, retval; ++ unsigned char *ADDR = (unsigned char *) addr; ++ ++ ADDR += nr >> 3; ++ mask = 1UL << (nr & 0x07); ++ retval = (mask & *ADDR) != 0; ++ *ADDR |= mask; ++ ++ return retval; ++} ++ ++_INLINE_ int ++ext2fs_clear_bit (unsigned int nr, void *addr) ++{ ++ int mask, retval; ++ unsigned char *ADDR = (unsigned char *) addr; ++ ++ ADDR += nr >> 3; ++ mask = 1UL << (nr & 0x07); ++ retval = (mask & *ADDR) != 0; ++ *ADDR &= ~mask; ++ ++ return retval; ++} ++ ++_INLINE_ int ++ext2fs_test_bit (unsigned int nr, const void *addr) ++{ ++ int mask; ++ const unsigned char *ADDR = (const unsigned char *) addr; ++ ++ ADDR += nr >> 3; ++ mask = 1UL << (nr & 0x07); ++ ++ return ((mask & *ADDR) != 0); ++} ++ + #endif /* __mc68000__ */ + + +diff -ur --new-file e2fsprogs-1.41.3/lib/ext2fs/ext2_fs.h e2fsprogs-1.41.3-mint/lib/ext2fs/ext2_fs.h +--- e2fsprogs-1.41.3/lib/ext2fs/ext2_fs.h 2009-01-23 10:01:34.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/lib/ext2fs/ext2_fs.h 2009-01-23 10:49:44.000000000 +0000 +@@ -307,6 +307,7 @@ + #define _IOT_ext2_new_group_input _IOT (_IOTS(__u32), 5, _IOTS(__u16), 2, 0, 0) + #endif + ++#ifndef __MINT__ + #define EXT2_IOC_GETFLAGS _IOR('f', 1, long) + #define EXT2_IOC_SETFLAGS _IOW('f', 2, long) + #define EXT2_IOC_GETVERSION _IOR('v', 1, long) +@@ -316,6 +317,9 @@ + #define EXT2_IOC_GROUP_EXTEND _IOW('f', 7, unsigned long) + #define EXT2_IOC_GROUP_ADD _IOW('f', 8,struct ext2_new_group_input) + #define EXT4_IOC_GROUP_ADD _IOW('f', 8,struct ext4_new_group_input) ++#else ++#include <mint/dcntl.h> ++#endif + + /* + * Structure of an inode on the disk +diff -ur --new-file e2fsprogs-1.41.3/lib/ext2fs/getsize.c e2fsprogs-1.41.3-mint/lib/ext2fs/getsize.c +--- e2fsprogs-1.41.3/lib/ext2fs/getsize.c 2008-10-07 14:22:39.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/lib/ext2fs/getsize.c 2009-01-23 10:47:35.000000000 +0000 +@@ -58,6 +58,11 @@ + #define BLKGETSIZE DKIOCGETBLOCKCOUNT32 + #endif /* APPLE_DARWIN */ + ++#ifdef __MINT__ ++#include <sys/ioctl.h> ++#include "mint_io.h" ++#endif ++ + #include "ext2_fs.h" + #include "ext2fs.h" + +diff -ur --new-file e2fsprogs-1.41.3/lib/ext2fs/llseek.c e2fsprogs-1.41.3-mint/lib/ext2fs/llseek.c +--- e2fsprogs-1.41.3/lib/ext2fs/llseek.c 2008-10-07 14:22:39.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/lib/ext2fs/llseek.c 2009-01-23 10:47:35.000000000 +0000 +@@ -115,6 +115,8 @@ + + #else /* !linux */ + ++#ifndef __MINT__ ++ + #ifndef EINVAL + #define EINVAL EXT2_ET_INVALID_ARGUMENT + #endif +@@ -133,6 +135,8 @@ + #endif + } + ++#endif /* __MINT__ */ ++ + #endif /* linux */ + + +diff -ur --new-file e2fsprogs-1.41.3/lib/ext2fs/mint_io.c e2fsprogs-1.41.3-mint/lib/ext2fs/mint_io.c +--- e2fsprogs-1.41.3/lib/ext2fs/mint_io.c 1970-01-01 00:00:00.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/lib/ext2fs/mint_io.c 2009-01-23 10:49:51.000000000 +0000 +@@ -0,0 +1,858 @@ ++/* ++ * $Id: e2fsprogs-1.41-mint.patch,v 1.1 2010/11/19 18:49:02 jlec Exp $ ++ * ++ * This file belongs to FreeMiNT. It's not in the original MiNT 1.12 ++ * distribution. See the file CHANGES for a detailed log of changes. ++ * ++ * ++ * Copyright 2000 Frank Naumann <fnaumann@freemint.de> ++ * All rights reserved. ++ * ++ * This program is free software; you can redistribute it and/or modify ++ * it under the terms of the GNU General Public License as published by ++ * the Free Software Foundation; either version 2, or (at your option) ++ * any later version. ++ * ++ * This file is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ * ++ * Author: Frank Naumann <fnaumann@freemint.de> ++ * Started: 200-06-14 ++ * ++ * Please send suggestions, patches or bug reports to me or ++ * the MiNT mailing list. ++ * ++ */ ++ ++# ifdef __MINT__ ++ ++# include <assert.h> ++# include <ctype.h> ++# include <errno.h> ++# include <fcntl.h> ++# include <limits.h> ++# include <stdarg.h> ++# include <stdlib.h> ++# include <stdio.h> ++# include <string.h> ++# include <time.h> ++# include <unistd.h> ++ ++# include "et/com_err.h" ++# include "ext2fs/ext2_io.h" ++# include <sys/ioctl.h> ++# include <sys/stat.h> ++# define loff_t ext2_loff_t ++# define llseek ext2fs_llseek ++ ++# include <mintbind.h> ++# include "mint_io.h" ++# include "xhdi.h" ++ ++ ++# if 0 ++# define DEBUG(x) printf x ++# else ++# define DEBUG(x) ++# endif ++ ++ ++/* prototypes */ ++ ++int __open_v(const char *_filename, int iomode, va_list argp); ++ ++int open(__const char *__file, int __oflag, ...) __THROW; ++int __open(__const char *__file, int __oflag, ...) __THROW; ++ ++int ioctl(int fd, int cmd, void *arg); ++int __ioctl(int fd, int cmd, void *arg); ++ ++int fsync(int __fd) __THROW; ++int __fsync(int __fd) __THROW; ++ ++__off_t lseek(int __fd, __off_t __offset, int __whence) __THROW; ++__off_t __lseek(int __fd, __off_t __offset, int __whence) __THROW; ++ ++int close(int __fd) __THROW; ++int __close(int __fd) __THROW; ++ ++ssize_t read(int __fd, void *__buf, size_t __nbytes) __THROW; ++ssize_t __read(int __fd, void *__buf, size_t __nbytes) __THROW; ++ ++ssize_t write(int __fd, __const void *__buf, size_t __n) __THROW; ++ssize_t __write(int __fd, __const void *__buf, size_t __n) __THROW; ++ ++int fstat(int __fd, struct stat *__buf) __THROW; ++int __fstat(int __fd, struct stat *__buf) __THROW; ++ ++int stat(const char *filename, struct stat *st) __THROW; ++ ++ ++struct device ++{ ++ int used; ++ ++ int drv; ++ int open_flags; ++ ++ ushort xhdi_maj; ++ ushort xhdi_min; ++ ulong xhdi_start; ++ ulong xhdi_blocks; ++ ulong xhdi_blocksize; ++ char xhdi_id[4]; ++ ++ loff_t pos; ++}; ++ ++# define DEVS 16 ++static struct device devs[DEVS]; ++ ++static void ++init_device(struct device *dev) ++{ ++ dev->used = 0; ++ ++ dev->drv = -1; ++ dev->open_flags = 0; ++ dev->xhdi_maj = 0; ++ dev->xhdi_min = 0; ++ dev->xhdi_start = 0; ++ dev->xhdi_blocks = 0; ++ dev->xhdi_blocksize = 0; ++ ++ dev->pos = 0; ++} ++ ++static inline void ++init(void) ++{ ++ static int done = 0; ++ int i; ++ ++ if (done) ++ return; ++ ++ assert(sizeof(loff_t) == sizeof(long long)); ++ ++ for (i = 0; i < DEVS; i++) ++ init_device (&devs[i]); ++ ++ init_XHDI(); ++ ++ /* we are now initialized */ ++ done = 1; ++} ++ ++static struct device * ++get_device(int fd) ++{ ++ struct device *dev; ++ ++ if ((fd < 1024) || (fd >= (1024 + DEVS))) ++ return NULL; ++ ++ fd -= 1024; ++ dev = &devs[fd]; ++ ++ assert(dev->used); ++ ++ return dev; ++} ++ ++static int ++alloc_device(void) ++{ ++ int i; ++ ++ for (i = 0; i < DEVS; i++) ++ { ++ struct device *dev = &devs[i]; ++ ++ if (!dev->used) ++ { ++ dev->used = 1; ++ return (i + 1024); ++ } ++ } ++ ++ __set_errno(ENOMEM); ++ return -1; ++} ++ ++static void ++free_device(struct device *dev) ++{ ++ assert(dev->used); ++ ++ init_device (dev); ++} ++ ++ ++int ++open(const char *filename, int iomode, ...) ++{ ++ const char *f = filename; ++ struct device *mydev = NULL; ++ int dev = -1; ++ long ret; ++ ++ init(); ++ ++ if (!filename) ++ { ++ __set_errno(EINVAL); ++ return -1; ++ } ++ ++ if ((f[1] == ':') && (f[2] == '\0')) ++ { ++ int c = tolower(f[0]); ++ ++ if (c >= 'a' && c <= 'z') ++ c = c - 'a'; ++ else if (c >= '1' && c <= '6') ++ c = 26 + (c - '1'); ++ ++ if ((c >= 0) && (c < 32)) ++ { ++ dev = alloc_device(); ++ if (dev != -1) ++ { ++ mydev = get_device(dev); ++ assert(mydev); ++ ++ mydev->drv = c; ++ mydev->open_flags = iomode; ++ } ++ } ++ } ++ ++ if (dev == -1) ++ { ++ /* fall through */ ++ ++ va_list args; ++ int retval; ++ ++ va_start(args, iomode); ++ retval = __open_v(filename, iomode, args); ++ va_end(args); ++ ++ return retval; ++ } ++ ++ if (mydev->open_flags == O_RDONLY) ++ { ++ DEBUG(("readonly mode!\n")); ++ sync(); ++ } ++ else if (Dlock(1, mydev->drv)) ++ { ++ printf("Can't lock partition %c:!\n", mydev->drv+'A'); ++ ++ if (mydev) ++ free_device(mydev); ++ ++ __set_errno(EACCES); ++ return -1; ++ } ++ ++ __set_errno(EERROR); ++ ++ ret = XHGetVersion (); ++ DEBUG(("XHDI version: %lx\n", ret)); ++ ++ ret = XHInqDev2(mydev->drv, ++ &mydev->xhdi_maj, &mydev->xhdi_min, ++ &mydev->xhdi_start, NULL, ++ &mydev->xhdi_blocks, mydev->xhdi_id); ++ if (ret) ++ { ++ printf("XHInqDev2 [%c] fail (ret = %li, errno = %i)\n", ++ mydev->drv+'A', ret, errno); ++ ret = -1; ++ } ++ else ++ { ++ ret = XHInqTarget(mydev->xhdi_maj, mydev->xhdi_min, ++ &mydev->xhdi_blocksize, NULL, NULL); ++ if (ret) ++ { ++ printf("XHInqTarget [%i:%i] fail (ret = %li, errno = %i)\n", ++ mydev->xhdi_maj, mydev->xhdi_min, ret, errno); ++ ret = -1; ++ } ++ else ++ { ++ char *xhdi_id = mydev->xhdi_id; ++ ++ if ( 0 ++ || ((xhdi_id[0] == 'G') && (xhdi_id[1] == 'E') && (xhdi_id[2] == 'M')) /* GEM */ ++ || ((xhdi_id[0] == 'B') && (xhdi_id[1] == 'G') && (xhdi_id[2] == 'M')) /* BGM */ ++ || ((xhdi_id[0] == 'F') && (xhdi_id[1] == '3') && (xhdi_id[2] == '2')) /* F32 */ ++ || ((xhdi_id[0] == 'M') && (xhdi_id[1] == 'I') && (xhdi_id[2] == 'X')) /* MIX */ ++ || ((xhdi_id[0] == 'R') && (xhdi_id[1] == 'A') && (xhdi_id[2] == 'W')) /* RAW */ ++ || ((xhdi_id[0] == 'L') && (xhdi_id[1] == 'N') && (xhdi_id[2] == 'X')) /* LNX */ ++ || ((xhdi_id[0] == '\0') && (xhdi_id[1] == 'D'))) /* any DOS */ ++ { ++ DEBUG(("Partition ok and accepted!\n")); ++ DEBUG(("start = %lu, blocks = %lu, blocksize = %lu\n", ++ mydev->xhdi_start, mydev->xhdi_blocks, ++ mydev->xhdi_blocksize)); ++ } ++ else ++ { ++ xhdi_id [3] = '\0'; ++ printf("Wrong partition ID [%s]!\n", xhdi_id); ++ printf("Only 'RAW', 'LNX' and DOS partitions are supported.\n"); ++ ++ __set_errno(EPERM); ++ ret = -1; ++ } ++ } ++ } ++ ++ if (ret) ++ { ++ if (mydev) ++ free_device(mydev); ++ ++ dev = -1; ++ } ++ ++ return dev; ++} ++ ++int ++close(int fd) ++{ ++ struct device *mydev = get_device(fd); ++ int ret = 0; ++ ++ if (!mydev) ++ /* fall through */ ++ return __close(fd); ++ ++ if (mydev->open_flags == O_RDONLY) ++ { ++ ; ++ } ++ else if (Dlock(0, mydev->drv)) ++ { ++ printf("Can't unlock partition %c:!\n", 'A'+mydev->drv); ++ ++ __set_errno(EACCES); ++ ret = -1; ++ } ++ ++ free_device(mydev); ++ return ret; ++} ++ ++/* simple buffer */ ++static char buffer[1024L * 128]; ++static ulong buf_recno = 0; ++static long buf_n = 0; ++ ++static long ++rwabs_xhdi(struct device *mydev, ushort rw, void *buf, ulong size, ulong recno) ++{ ++ ulong n = size / mydev->xhdi_blocksize; ++ long r; ++ ++ assert((size % mydev->xhdi_blocksize) == 0); ++ ++ if (!n || (recno + n) > mydev->xhdi_blocks) ++ { ++ printf("rwabs_xhdi: access outside partition (drv = %c:)\n", 'A'+mydev->drv); ++ exit(2); ++ } ++ ++ if (n > 65535UL) ++ { ++ printf("rwabs_xhdi: n to large (drv = %c)\n", 'A'+mydev->drv); ++ exit(2); ++ } ++ ++ if (!rw && (buf_recno == recno) && (buf_n == n)) ++ { ++ bcopy(buffer, buf, buf_n * mydev->xhdi_blocksize); ++ return 0; ++ } ++ ++ r = XHReadWrite (mydev->xhdi_maj, mydev->xhdi_min, rw, mydev->xhdi_start + recno, n, buf); ++ ++ if (!r && (n * mydev->xhdi_blocksize) <= sizeof(buffer)) ++ { ++ bcopy(buf, buffer, n * mydev->xhdi_blocksize); ++ ++ buf_recno = recno; ++ buf_n = n; ++ } ++ else ++ buf_n = 0; ++ ++ return r; ++} ++ ++# define max(a,b) (a > b ? a : b) ++# define min(a,b) (a > b ? b : a) ++ ++int ++read(int fd, void *_buf, size_t size) ++{ ++ struct device *mydev = get_device(fd); ++ ++ if (!mydev) ++ /* fall through */ ++ return __read(fd, _buf, size); ++ ++{ ++ char *buf = _buf; ++ long todo; /* characters remaining */ ++ long done; /* characters processed */ ++ ++ todo = size; ++ done = 0; ++ ++ if (todo == 0) ++ return 0; ++ ++ /* partial block copy ++ */ ++ if (mydev->pos % mydev->xhdi_blocksize) ++ { ++ char tmp[mydev->xhdi_blocksize]; ++ ++ ulong recno = mydev->pos / mydev->xhdi_blocksize; ++ ulong offset = mydev->pos % mydev->xhdi_blocksize; ++ ulong data; ++ long ret; ++ ++ ret = rwabs_xhdi(mydev, 0, tmp, mydev->xhdi_blocksize, recno); ++ if (ret) ++ { ++ DEBUG(("read: partial part: read failure (r = %li, errno = %i)\n", ret, errno)); ++ goto out; ++ } ++ ++ data = mydev->xhdi_blocksize - offset; ++ data = min (todo, data); ++ ++ memcpy(buf, tmp + offset, data); ++ ++ buf += data; ++ todo -= data; ++ done += data; ++ mydev->pos += data; ++ } ++ ++ if (todo) ++ { ++ assert((todo > 0)); ++ assert((mydev->pos % mydev->xhdi_blocksize) == 0); ++ } ++ ++ ++ /* full blocks ++ */ ++ if (todo / mydev->xhdi_blocksize) ++ { ++ ulong recno = mydev->pos / mydev->xhdi_blocksize; ++ ulong data = (todo / mydev->xhdi_blocksize) * mydev->xhdi_blocksize; ++ long ret; ++ ++ ret = rwabs_xhdi (mydev, 0, buf, data, recno); ++ if (ret) ++ { ++ DEBUG(("read: full blocks: read failure (r = %li, errno = %i)\n", ret, errno)); ++ goto out; ++ } ++ ++ buf += data; ++ todo -= data; ++ done += data; ++ mydev->pos += data; ++ } ++ ++ if (todo) ++ { ++ assert((todo > 0) && (todo < mydev->xhdi_blocksize)); ++ assert((mydev->pos % mydev->xhdi_blocksize) == 0); ++ } ++ ++ /* anything left? ++ */ ++ if (todo) ++ { ++ char tmp[mydev->xhdi_blocksize]; ++ ++ ulong recno = mydev->pos / mydev->xhdi_blocksize; ++ long ret; ++ ++ ret = rwabs_xhdi (mydev, 0, tmp, mydev->xhdi_blocksize, recno); ++ if (ret) ++ { ++ DEBUG(("read: left part: read failure (r = %li, errno = %i)]\n", ret, errno)); ++ goto out; ++ } ++ ++ memcpy(buf, tmp, todo); ++ ++ done += todo; ++ mydev->pos += todo; ++ } ++ ++ assert(done == size); ++ ++out: ++ return done; ++} ++} ++ ++int ++write(int fd, const void *_buf, size_t size) ++{ ++ struct device *mydev = get_device(fd); ++ ++ if (!mydev) ++ /* fall through */ ++ return __write(fd, _buf, size); ++ ++ if (mydev->open_flags == O_RDONLY) ++ { ++ __set_errno(EPERM); ++ return -1; ++ } ++{ ++ const char *buf = _buf; ++ long todo; /* characters remaining */ ++ long done; /* characters processed */ ++ ++ todo = size; ++ done = 0; ++ ++ if (todo == 0) ++ return 0; ++ ++ /* partial block copy ++ */ ++ if (mydev->pos % mydev->xhdi_blocksize) ++ { ++ char tmp[mydev->xhdi_blocksize]; ++ ++ ulong recno = mydev->pos / mydev->xhdi_blocksize; ++ ulong offset = mydev->pos % mydev->xhdi_blocksize; ++ ulong data; ++ long ret; ++ ++ ret = rwabs_xhdi(mydev, 0, tmp, mydev->xhdi_blocksize, recno); ++ if (ret) ++ { ++ DEBUG(("write: partial part: read failure (r = %li, errno = %i)\n", ret, errno)); ++ goto out; ++ } ++ ++ data = mydev->xhdi_blocksize - offset; ++ data = min (todo, data); ++ ++ memcpy(tmp + offset, buf, data); ++ ++ ret = rwabs_xhdi(mydev, 1, tmp, mydev->xhdi_blocksize, recno); ++ if (ret) ++ { ++ DEBUG(("write: partial part: write failure (r = %li, errno = %i)\n", ret, errno)); ++ goto out; ++ } ++ ++ buf += data; ++ todo -= data; ++ done += data; ++ mydev->pos += data; ++ } ++ ++ if (todo) ++ { ++ assert((todo > 0)); ++ assert((mydev->pos % mydev->xhdi_blocksize) == 0); ++ } ++ ++ /* full blocks ++ */ ++ if (todo / mydev->xhdi_blocksize) ++ { ++ ulong recno = mydev->pos / mydev->xhdi_blocksize; ++ ulong data = (todo / mydev->xhdi_blocksize) * mydev->xhdi_blocksize; ++ long ret; ++ ++ ret = rwabs_xhdi(mydev, 1, (void *)buf, data, recno); ++ if (ret) ++ { ++ DEBUG(("write: full blocks: write failure (r = %li, errno = %i)\n", ret, errno)); ++ goto out; ++ } ++ ++ buf += data; ++ todo -= data; ++ done += data; ++ mydev->pos += data; ++ } ++ ++ if (todo) ++ { ++ assert((todo > 0) && (todo < mydev->xhdi_blocksize)); ++ assert((mydev->pos % mydev->xhdi_blocksize) == 0); ++ } ++ ++ /* anything left? ++ */ ++ if (todo) ++ { ++ char tmp[mydev->xhdi_blocksize]; ++ ++ ulong recno = mydev->pos / mydev->xhdi_blocksize; ++ long ret; ++ ++ ret = rwabs_xhdi(mydev, 0, tmp, mydev->xhdi_blocksize, recno); ++ if (ret) ++ { ++ DEBUG(("write: left part: read failure (r = %li, errno = %i)]\n", ret, errno)); ++ goto out; ++ } ++ ++ memcpy(tmp, buf, todo); ++ ++ ret = rwabs_xhdi(mydev, 1, tmp, mydev->xhdi_blocksize, recno); ++ if (ret) ++ { ++ DEBUG(("write: partial part: write failure (r = %li, errno = %i)\n", ret, errno)); ++ goto out; ++ } ++ ++ done += todo; ++ mydev->pos += todo; ++ } ++ ++ assert(done == size); ++ ++out: ++ return done; ++} ++} ++ ++int ++ioctl(int fd, int cmd, void *arg) ++{ ++ struct device *mydev = get_device(fd); ++ ++ if (!mydev) ++ /* fall through */ ++ return __ioctl(fd, cmd, arg); ++ ++ DEBUG(("ioctl: cmd = %i\n", cmd)); ++ ++ switch (cmd) ++ { ++ case BLKGETSIZE: ++ { ++ ulong *size = arg; ++ *size = mydev->xhdi_blocks * (mydev->xhdi_blocksize / 512); ++ break; ++ } ++ case BLOCKSIZE: ++ { ++ ulong *block_size = arg; ++ *block_size = mydev->xhdi_blocksize; ++ break; ++ } ++ default: ++ __set_errno(EINVAL); ++ return -1; ++ } ++ ++ return 0; ++} ++ ++int ++fstat(int fd, struct stat *st) ++{ ++ struct device *mydev = get_device(fd); ++ ++ if (!mydev) ++ /* fall through */ ++ return __fstat(fd, st); ++ ++ bzero(st, sizeof(*st)); ++ ++ st->st_dev = mydev->xhdi_maj; ++ st->st_ino = mydev->drv; ++ st->st_mode = S_IFBLK | S_IRUSR | S_IWUSR; ++ st->st_nlink = 1; ++ st->st_uid = 0; ++ st->st_gid = 0; ++ st->st_rdev = mydev->xhdi_min; ++ st->st_atime = time (NULL); ++ st->st_mtime = time (NULL); ++ st->st_ctime = time (NULL); ++ st->st_size = (int64_t) mydev->xhdi_blocks * mydev->xhdi_blocksize; ++ st->st_blocks = (int64_t) mydev->xhdi_blocks * mydev->xhdi_blocksize / 512; ++ st->st_blksize = mydev->xhdi_blocksize; ++ st->st_flags = 0; ++ st->st_gen = 0; ++ ++ return 0; ++} ++ ++int ++stat(const char *filename, struct stat *st) ++{ ++ struct device *mydev; ++ int fd, res; ++ ++ fd = open(filename, O_RDONLY); ++ if (fd == -1) ++ return -1; ++ ++ mydev = get_device(fd); ++ if (!mydev) ++ { ++ close(fd); ++ ++ /* fall through */ ++ return __stat(filename, st); ++ } ++ ++ res = fstat(fd, st); ++ close(fd); ++ ++ return res; ++} ++ ++int ++fsync(int fd) ++{ ++ struct device *mydev = get_device(fd); ++ ++ if (!mydev) ++ /* fall through */ ++ return __fsync(fd); ++ ++ /* nothing todo */ ++ return 0; ++} ++ ++loff_t llseek(int fd, loff_t offset, int origin); ++ ++loff_t ++llseek(int fd, loff_t offset, int origin) ++{ ++ struct device *mydev = get_device(fd); ++ ++ if (!mydev) ++ /* fall through */ ++ return __lseek(fd, (off_t) offset, origin); ++ ++ ++ switch (origin) ++ { ++ case SEEK_SET: ++ break; ++ case SEEK_CUR: ++ offset += mydev->pos; ++ break; ++ case SEEK_END: ++ offset += (int64_t) mydev->xhdi_blocks * mydev->xhdi_blocksize; ++ break; ++ default: ++ return -1; ++ } ++ ++ if (offset > (loff_t) mydev->xhdi_blocks * mydev->xhdi_blocksize) ++ { ++ __set_errno(EINVAL); ++ return -1; ++ } ++ ++ mydev->pos = offset; ++ return mydev->pos; ++} ++ ++loff_t lseek64(int fd, loff_t offset, int origin); ++ ++loff_t ++lseek64(int fd, loff_t offset, int origin) ++{ ++ return llseek(fd, offset, origin); ++} ++ ++__off_t ++lseek(int fd, __off_t offset, int mode) ++{ ++ struct device *mydev = get_device(fd); ++ ++ if (!mydev) ++ /* fall through */ ++ return __lseek(fd, offset, mode); ++ ++{ ++ loff_t _offset = offset; ++ ++ switch (mode) ++ { ++ case SEEK_SET: ++ break; ++ case SEEK_CUR: ++ _offset += mydev->pos; ++ break; ++ case SEEK_END: ++ _offset += (loff_t) mydev->xhdi_blocks * mydev->xhdi_blocksize; ++ break; ++ default: ++ return -1; ++ } ++ ++ if (_offset > LONG_MAX) ++ { ++ __set_errno(EINVAL); ++ return -1; ++ } ++ ++ if (_offset > (loff_t) mydev->xhdi_blocks * mydev->xhdi_blocksize) ++ { ++ __set_errno(EINVAL); ++ return -1; ++ } ++ ++ mydev->pos = _offset; ++ return (off_t) mydev->pos; ++} ++} ++ ++int gettype(int fd); ++ ++int ++gettype(int fd) ++{ ++ struct device *mydev = get_device(fd); ++ char *xhdi_id; ++ ++ if (!mydev) ++ return -1; ++ ++ /* Get filesystem type by XHDI ID */ ++ xhdi_id = mydev->xhdi_id; ++ if ((xhdi_id[0] == '\0') && (xhdi_id[1] == 'D')) ++ return 0; /* DOS (\0D*) */ ++ else ++ return 1; /* Atari (GEM/GBM) */ ++} ++ ++# endif /* __MINT__ */ +diff -ur --new-file e2fsprogs-1.41.3/lib/ext2fs/mint_io.h e2fsprogs-1.41.3-mint/lib/ext2fs/mint_io.h +--- e2fsprogs-1.41.3/lib/ext2fs/mint_io.h 1970-01-01 00:00:00.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/lib/ext2fs/mint_io.h 2009-01-23 10:49:53.000000000 +0000 +@@ -0,0 +1,22 @@ ++/* ++ * mint_io.h ++ * ++ * Copyright (C) 2000 Frank Naumann <fnaumann@freemint.de>. ++ * ++ * %Begin-Header% ++ * This file may be redistributed under the terms of the GNU Public ++ * License. ++ * %End-Header% ++ */ ++ ++# ifdef __MINT__ ++ ++# ifndef _mint_io_h ++# define _mint_io_h ++ ++# define BLKGETSIZE (('b'<< 8) | 1) ++# define BLOCKSIZE (('b'<< 8) | 2) ++ ++# endif /* _mint_io_h */ ++ ++# endif /* __MINT__ */ +diff -ur --new-file e2fsprogs-1.41.3/lib/ext2fs/unix_io.c e2fsprogs-1.41.3-mint/lib/ext2fs/unix_io.c +--- e2fsprogs-1.41.3/lib/ext2fs/unix_io.c 2008-10-13 03:12:22.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/lib/ext2fs/unix_io.c 2009-01-23 10:47:35.000000000 +0000 +@@ -51,9 +51,15 @@ + #define BLKROGET _IO(0x12, 94) /* Get read-only status (0 = read_write). */ + #endif + ++#ifdef __MINT__ ++#include <sys/ioctl.h> ++#include "mint_io.h" ++#endif ++ + #include "ext2_fs.h" + #include "ext2fs.h" + ++ + /* + * For checking structure magic numbers... + */ +@@ -512,6 +518,16 @@ + } + } + #endif ++ ++#ifdef __MINT__ ++ { ++ unsigned long block_size; ++ retval = ioctl(data->dev, BLOCKSIZE, &block_size); ++ if (retval == 0) ++ io->block_size = block_size; ++ } ++#endif ++ + *channel = io; + return 0; + +diff -ur --new-file e2fsprogs-1.41.3/lib/ext2fs/xhdi.c e2fsprogs-1.41.3-mint/lib/ext2fs/xhdi.c +--- e2fsprogs-1.41.3/lib/ext2fs/xhdi.c 1970-01-01 00:00:00.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/lib/ext2fs/xhdi.c 2009-01-23 10:49:55.000000000 +0000 +@@ -0,0 +1,577 @@ ++/* ++ * Copyright 2000 Frank Naumann <fnaumann@freemint.de> ++ * All rights reserved. ++ * ++ * This program is free software; you can redistribute it and/or modify ++ * it under the terms of the GNU General Public License as published by ++ * the Free Software Foundation; either version 2, or (at your option) ++ * any later version. ++ * ++ * This file is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ * ++ * Started: 2000-05-02 ++ * ++ * Changes: ++ * ++ * 0.1: ++ * ++ * fix: Cookie handling stuff; use Getcookie from MiNT-Lib now ++ * requires an actual MiNT-Lib (>= PL49) ++ * ++ * 0.0: ++ * ++ * - inital version ++ * ++ */ ++ ++# include "xhdi.h" ++ ++# include <stdio.h> ++# include <stdlib.h> ++# include <errno.h> ++# include <mintbind.h> ++# include <mint/cookie.h> ++ ++ ++/* ++ * internal usage ++ */ ++ ++/* dummy routine */ ++static long ++XHDIfail (void) ++{ ++ return -ENOSYS; ++} ++ ++/* XHDI handler function */ ++static long (*XHDI)() = XHDIfail; ++ ++ushort XHDI_installed = 0; ++ ++ ++# define C_XHDI 0x58484449L ++# define XHDIMAGIC 0x27011992L ++ ++/* initalize flag */ ++static ushort init = 1; ++ ++long ++init_XHDI (void) ++{ ++ long *val; ++ long r; ++ ++ init = 0; ++ ++ r = Getcookie (C_XHDI, (long *) &val); ++ if (r == C_FOUND) ++ { ++ long *magic_test = val; ++ ++ /* check magic */ ++ if (magic_test) ++ { ++ magic_test--; ++ if (*magic_test == XHDIMAGIC) ++ { ++ XHDI = val; ++ } ++ } ++ } ++ ++ r = XHGetVersion (); ++ if (r < 0) ++ { ++ perror ("XHGetVersion"); ++ ++ XHDI = XHDIfail; ++ return r; ++ } ++ ++ /* we need at least XHDI 1.10 */ ++ if (r >= 0x110) ++ { ++ XHDI_installed = r; ++ return 0; ++ } ++ ++ XHDI = XHDIfail; ++ return -1; ++} ++ ++ ++/* ++ * XHDI wrapper routines ++ */ ++ ++# define CALL \ ++ long oldstack = 0; \ ++ long r; \ ++ \ ++ if (init) init_XHDI (); \ ++ \ ++ if (!Super (1L)) \ ++ oldstack = Super (0L); \ ++ \ ++ r = XHDI (args); \ ++ if (r < 0) \ ++ { \ ++ __set_errno (-r); \ ++ r = -1; \ ++ } \ ++ \ ++ if (oldstack) \ ++ Super (oldstack); \ ++ \ ++ return r ++ ++long ++XHGetVersion (void) ++{ ++ struct args_XHGetVersion ++ { ++ ushort opcode; ++ } ++ args = ++ { ++ 0 ++ }; ++ ++ CALL; ++} ++ ++long ++XHInqTarget (ushort major, ushort minor, ulong *block_size, ulong *device_flags, char *product_name) ++{ ++ struct args_XHInqTarget ++ { ++ ushort opcode; ++ ushort major; ++ ushort minor; ++ ulong *block_size; ++ ulong *device_flags; ++ char *product_name; ++ } ++ args = ++ { ++ 1, ++ major, ++ minor, ++ block_size, ++ device_flags, ++ product_name ++ }; ++ ++ CALL; ++} ++ ++long ++XHReserve (ushort major, ushort minor, ushort do_reserve, ushort key) ++{ ++ struct args_XHReserve ++ { ++ ushort opcode; ++ ushort major; ++ ushort minor; ++ ushort do_reserve; ++ ushort key; ++ } ++ args = ++ { ++ 2, ++ major, ++ minor, ++ do_reserve, ++ key ++ }; ++ ++ CALL; ++} ++ ++long ++XHLock (ushort major, ushort minor, ushort do_lock, ushort key) ++{ ++ struct args_XHLock ++ { ++ ushort opcode; ++ ushort major; ++ ushort minor; ++ ushort do_lock; ++ ushort key; ++ } ++ args = ++ { ++ 3, ++ major, ++ minor, ++ do_lock, ++ key ++ }; ++ ++ CALL; ++} ++ ++long ++XHStop (ushort major, ushort minor, ushort do_stop, ushort key) ++{ ++ struct args_XHStop ++ { ++ ushort opcode; ++ ushort major; ++ ushort minor; ++ ushort do_stop; ++ ushort key; ++ } ++ args = ++ { ++ 4, ++ major, ++ minor, ++ do_stop, ++ key ++ }; ++ ++ CALL; ++} ++ ++long ++XHEject (ushort major, ushort minor, ushort do_eject, ushort key) ++{ ++ struct args_XHEject ++ { ++ ushort opcode; ++ ushort major; ++ ushort minor; ++ ushort do_eject; ++ ushort key; ++ } ++ args = ++ { ++ 5, ++ major, ++ minor, ++ do_eject, ++ key ++ }; ++ ++ CALL; ++} ++ ++long ++XHDrvMap (void) ++{ ++ struct args_XHDrvMap ++ { ++ ushort opcode; ++ } ++ args = ++ { ++ 6 ++ }; ++ ++ CALL; ++} ++ ++long ++XHInqDev (ushort bios, ushort *major, ushort *minor, ulong *start, __BPB *bpb) ++{ ++ struct args_XHInqDev ++ { ++ ushort opcode; ++ ushort bios; ++ ushort *major; ++ ushort *minor; ++ ulong *start; ++ __BPB *bpb; ++ } ++ args = ++ { ++ 7, ++ bios, ++ major, ++ minor, ++ start, ++ bpb ++ }; ++ ++ CALL; ++} ++ ++long ++XHInqDriver (ushort bios, char *name, char *version, char *company, ushort *ahdi_version, ushort *maxIPL) ++{ ++ struct args_XHInqDriver ++ { ++ ushort opcode; ++ ushort bios; ++ char *name; ++ char *version; ++ char *company; ++ ushort *ahdi_version; ++ ushort *maxIPL; ++ } ++ args = ++ { ++ 8, ++ bios, ++ name, ++ version, ++ company, ++ ahdi_version, ++ maxIPL ++ }; ++ ++ CALL; ++} ++ ++long ++XHNewCookie (void *newcookie) ++{ ++ struct args_XHNewCookie ++ { ++ ushort opcode; ++ void *newcookie; ++ } ++ args = ++ { ++ 9, ++ newcookie ++ }; ++ ++ CALL; ++} ++ ++long ++XHReadWrite (ushort major, ushort minor, ushort rwflag, ulong recno, ushort count, void *buf) ++{ ++ struct args_XHReadWrite ++ { ++ ushort opcode; ++ ushort major; ++ ushort minor; ++ ushort rwflag; ++ ulong recno; ++ ushort count; ++ void *buf; ++ } ++ args = ++ { ++ 10, ++ major, ++ minor, ++ rwflag, ++ recno, ++ count, ++ buf ++ }; ++ ++ CALL; ++} ++ ++long ++XHInqTarget2 (ushort major, ushort minor, ulong *block_size, ulong *device_flags, char *product_name, ushort stringlen) ++{ ++ struct args_XHInqTarget2 ++ { ++ ushort opcode; ++ ushort major; ++ ushort minor; ++ ulong *block_size; ++ ulong *device_flags; ++ char *product_name; ++ ushort stringlen; ++ } ++ args = ++ { ++ 11, ++ major, ++ minor, ++ block_size, ++ device_flags, ++ product_name, ++ stringlen ++ }; ++ ++ CALL; ++} ++ ++long ++XHInqDev2 (ushort bios, ushort *major, ushort *minor, ulong *start, __BPB *bpb, ulong *blocks, char *partid) ++{ ++ struct args_XHInqDev2 ++ { ++ ushort opcode; ++ ushort bios; ++ ushort *major; ++ ushort *minor; ++ ulong *start; ++ __BPB *bpb; ++ ulong *blocks; ++ char *partid; ++ } ++ args = ++ { ++ 12, ++ bios, ++ major, ++ minor, ++ start, ++ bpb, ++ blocks, ++ partid ++ }; ++ ++ CALL; ++} ++ ++long ++XHDriverSpecial (ulong key1, ulong key2, ushort subopcode, void *data) ++{ ++ struct args_XHDriverSpecial ++ { ++ ushort opcode; ++ ulong key1; ++ ulong key2; ++ ushort subopcode; ++ void *data; ++ } ++ args = ++ { ++ 13, ++ key1, ++ key2, ++ subopcode, ++ data ++ }; ++ ++ CALL; ++} ++ ++long ++XHGetCapacity (ushort major, ushort minor, ulong *blocks, ulong *bs) ++{ ++ struct args_XHGetCapacity ++ { ++ ushort opcode; ++ ushort major; ++ ushort minor; ++ ulong *blocks; ++ ulong *bs; ++ } ++ args = ++ { ++ 14, ++ major, ++ minor, ++ blocks, ++ bs ++ }; ++ ++ CALL; ++} ++ ++long ++XHMediumChanged (ushort major, ushort minor) ++{ ++ struct args_XHMediumChanged ++ { ++ ushort opcode; ++ ushort major; ++ ushort minor; ++ } ++ args = ++ { ++ 15, ++ major, ++ minor ++ }; ++ ++ CALL; ++} ++ ++long ++XHMiNTInfo (ushort op, void *data) ++{ ++ struct args_XHMiNTInfo ++ { ++ ushort opcode; ++ ushort op; ++ void *data; ++ } ++ args = ++ { ++ 16, ++ op, ++ data ++ }; ++ ++ CALL; ++} ++ ++long ++XHDOSLimits (ushort which, ulong limit) ++{ ++ struct args_XHDOSLimits ++ { ++ ushort opcode; ++ ushort which; ++ ulong limit; ++ } ++ args = ++ { ++ 17, ++ which, ++ limit ++ }; ++ ++ CALL; ++} ++ ++long ++XHLastAccess (ushort major, ushort minor, ulong *ms) ++{ ++ struct args_XHLastAccess ++ { ++ ushort opcode; ++ ushort major; ++ ushort minor; ++ ulong *ms; ++ } ++ args = ++ { ++ 18, ++ major, ++ minor, ++ ms ++ }; ++ ++ CALL; ++} ++ ++long ++XHReaccess (ushort major, ushort minor) ++{ ++ struct args_XHReaccess ++ { ++ ushort opcode; ++ ushort major; ++ ushort minor; ++ } ++ args = ++ { ++ 19, ++ major, ++ minor ++ }; ++ ++ CALL; ++} +diff -ur --new-file e2fsprogs-1.41.3/lib/ext2fs/xhdi.h e2fsprogs-1.41.3-mint/lib/ext2fs/xhdi.h +--- e2fsprogs-1.41.3/lib/ext2fs/xhdi.h 1970-01-01 00:00:00.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/lib/ext2fs/xhdi.h 2009-01-23 10:49:56.000000000 +0000 +@@ -0,0 +1,144 @@ ++/* ++ * Copyright 2000 Frank Naumann <fnaumann@freemint.de> ++ * All rights reserved. ++ * ++ * This program is free software; you can redistribute it and/or modify ++ * it under the terms of the GNU General Public License as published by ++ * the Free Software Foundation; either version 2, or (at your option) ++ * any later version. ++ * ++ * This file is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ * ++ */ ++ ++# ifndef _xhdi_h ++# define _xhdi_h ++ ++# include <sys/types.h> ++ ++typedef unsigned char uchar; ++ ++ ++/* ++ * BIOS parameter block (osbind.h is buggy) ++ */ ++ ++typedef struct ++{ ++ ushort recsiz; /* bytes per sector */ ++ short clsiz; /* sectors per cluster */ ++ ushort clsizb; /* bytes per cluster */ ++ short rdlen; /* root directory size */ ++ short fsiz; /* size of FAT */ ++ short fatrec; /* startsector of second FAT */ ++ short datrec; /* first data sector */ ++ ushort numcl; /* total number of clusters */ ++ short bflags; /* some flags */ ++ ++} __BPB; ++ ++ ++/* ++ * Extended BIOS Parameter Block (XHDI) ++ */ ++ ++typedef struct ++{ ++ ushort recsiz; /* bytes per sector */ ++ short clsiz; /* sectors per cluster */ ++ ushort clsizb; /* bytes per cluster */ ++ short rdlen; /* root directory size or 0 if FAT32 */ ++ short fsiz; /* size of FAT or 0 if FAT32 */ ++ short fatrec; /* startsector of second FAT or 0 if FAT32 */ ++ short datrec; /* first data sector or 0 if FAT32 */ ++ ushort numcl; /* total number of clusters or 0 if FAT32 */ ++ short bflags; /* bit 0: 0 = FAT12, 1 = FAT16 ++ * bit 1: 0 = 2 FATs, 1 = 1 FAT ++ * bit 2: 0 = BPB, 1 = EXTENDED_BPB ++ */ ++ ++ /* Ab hier undokumentiert, nur A: und B:! */ ++ short ntracks; /* Anzahl Spuren */ ++ short nsides; /* Anzahl Seiten */ ++ short spc; /* Sektoren pro Zylinder */ ++ short spt; /* Sektoren pro Spur */ ++ ushort nhid; /* Anzahl versteckte Sektoren */ ++ uchar ser[3]; /* Seriennummer */ ++ uchar serms[4]; /* ab TOS 2.06: MS-DOS-4.0-Seriennummer */ ++ char unused; ++ ++ /* if bit 2 of bflags are set */ ++ long l_recsiz; /* bytes per sector */ ++ long l_clsiz; /* sectors per cluster */ ++ long l_clsizb; /* bytes per cluster */ ++ long l_rdlen; /* root directory size */ ++ long l_fsiz; /* size of FAT */ ++ long l_fatrec; /* startsector of second FAT */ ++ long l_datrec; /* first data sector */ ++ long l_numcl; /* total number of clusters */ ++ long l_rdstcl; /* if FAT32: startcluster of root directory ++ * otherwise 0 ++ */ ++} __xhdi_BPB; ++ ++ ++# define XH_TARGET_STOPPABLE 0x00000001L ++# define XH_TARGET_REMOVABLE 0x00000002L ++# define XH_TARGET_LOCKABLE 0x00000004L ++# define XH_TARGET_EJECTABLE 0x00000008L ++# define XH_TARGET_LOCKED 0x20000000L ++# define XH_TARGET_STOPPED 0x40000000L ++# define XH_TARGET_RESERVED 0x80000000L ++ ++# define XH_MI_SETKERINFO 0 ++# define XH_MI_GETKERINFO 1 ++ ++# define XH_DL_SECSIZ 0 ++# define XH_DL_MINFAT 1 ++# define XH_DL_MAXFAT 2 ++# define XH_DL_MINSPC 3 ++# define XH_DL_MAXSPC 4 ++# define XH_DL_CLUSTS 5 ++# define XH_DL_MAXSEC 6 ++# define XH_DL_DRIVES 7 ++# define XH_DL_CLSIZB 8 ++# define XH_DL_RDLEN 9 ++# define XH_DL_CLUSTS12 12 ++# define XH_DL_CLUSTS32 13 ++# define XH_DL_BFLAGS 14 ++ ++ ++extern ushort XHDI_installed; ++ ++long init_XHDI (void); ++ ++long XHGetVersion (void); ++long XHInqTarget (ushort major, ushort minor, ulong *block_size, ulong *device_flags, char *product_name); ++long XHReserve (ushort major, ushort minor, ushort do_reserve, ushort key); ++long XHLock (ushort major, ushort minor, ushort do_lock, ushort key); ++long XHStop (ushort major, ushort minor, ushort do_stop, ushort key); ++long XHEject (ushort major, ushort minor, ushort do_eject, ushort key); ++long XHDrvMap (void); ++long XHInqDev (ushort bios, ushort *major, ushort *minor, ulong *start, __BPB *bpb); ++long XHInqDriver (ushort bios, char *name, char *version, char *company, ushort *ahdi_version, ushort *maxIPL); ++long XHNewCookie (void *newcookie); ++long XHReadWrite (ushort major, ushort minor, ushort rwflag, ulong recno, ushort count, void *buf); ++long XHInqTarget2 (ushort major, ushort minor, ulong *block_size, ulong *device_flags, char *product_name, ushort stringlen); ++long XHInqDev2 (ushort bios, ushort *major, ushort *minor, ulong *start, __BPB *bpb, ulong *blocks, char *partid); ++long XHDriverSpecial (ulong key1, ulong key2, ushort subopcode, void *data); ++long XHGetCapacity (ushort major, ushort minor, ulong *blocks, ulong *bs); ++long XHMediumChanged (ushort major, ushort minor); ++long XHMiNTInfo (ushort op, void *data); ++long XHDOSLimits (ushort which, ulong limit); ++long XHLastAccess (ushort major, ushort minor, ulong *ms); ++long XHReaccess (ushort major, ushort minor); ++ ++ ++# endif /* _xhdi_h */ +diff -ur --new-file e2fsprogs-1.41.3/misc/e2undo.c e2fsprogs-1.41.3-mint/misc/e2undo.c +--- e2fsprogs-1.41.3/misc/e2undo.c 2009-01-23 12:59:44.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/misc/e2undo.c 2009-01-23 12:56:40.000000000 +0000 +@@ -19,6 +19,7 @@ + #if HAVE_ERRNO_H + #include <errno.h> + #endif ++#include <sys/types.h> + #include "ext2fs/tdb.h" + #include "ext2fs/ext2fs.h" + #include "nls-enable.h" +diff -ur --new-file e2fsprogs-1.41.3/misc/e2initrd_helper.c e2fsprogs-1.41.3-mint/misc/e2initrd_helper.c +--- e2fsprogs-1.41.3/misc/e2initrd_helper.c 2009-01-23 12:58:29.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/misc/e2initrd_helper.c 2009-01-23 12:59:11.000000000 +0000 +@@ -50,7 +50,7 @@ + int ptr; + }; + +-struct fs_info { ++struct _fs_info { + char *device; + char *mountpt; + char *type; +@@ -58,7 +58,7 @@ + int freq; + int passno; + int flags; +- struct fs_info *next; ++ struct _fs_info *next; + }; + + static void usage(void) +@@ -230,7 +230,7 @@ + *q = 0; + } + +-static int parse_fstab_line(char *line, struct fs_info *fs) ++static int parse_fstab_line(char *line, struct _fs_info *fs) + { + char *dev, *device, *mntpnt, *type, *opts, *freq, *passno, *cp; + +@@ -280,7 +280,7 @@ + return 0; + } + +-static void free_fstab_line(struct fs_info *fs) ++static void free_fstab_line(struct _fs_info *fs) + { + if (fs->device) + fs->device = 0; +@@ -290,7 +290,7 @@ + fs->type = 0; + if (fs->opts) + fs->opts = 0; +- memset(fs, 0, sizeof(struct fs_info)); ++ memset(fs, 0, sizeof(struct _fs_info)); + } + + +@@ -334,7 +334,7 @@ + errcode_t retval; + struct mem_file file; + char *buf; +- struct fs_info fs_info; ++ struct _fs_info _fs_info; + int ret; + + retval = get_file(fs, "/etc/fstab", &file); +@@ -344,14 +344,14 @@ + if (!buf) + continue; + +- ret = parse_fstab_line(buf, &fs_info); ++ ret = parse_fstab_line(buf, &_fs_info); + if (ret < 0) + goto next_line; + +- if (!strcmp(fs_info.mountpt, "/")) +- printf("%s\n", fs_info.type); ++ if (!strcmp(_fs_info.mountpt, "/")) ++ printf("%s\n", _fs_info.type); + +- free_fstab_line(&fs_info); ++ free_fstab_line(&_fs_info); + + next_line: + free(buf); +diff -ur --new-file e2fsprogs-1.41.3/misc/mke2fs.c e2fsprogs-1.41.3-mint/misc/mke2fs.c +--- e2fsprogs-1.41.3/misc/mke2fs.c 2008-10-07 14:22:39.000000000 +0000 ++++ e2fsprogs-1.41.3-mint/misc/mke2fs.c 2009-01-23 10:47:35.000000000 +0000 +@@ -1819,6 +1819,36 @@ + return retval; + } + ++#ifdef __MINT__ ++void ++warn (const char *drv) ++{ ++ char c; ++ int check; ++ ++ check = open (drv, O_RDONLY); ++ if (check == -1) ++ return; ++ ++ close (check); ++ ++ if (check < 1024) ++ return; ++ ++ fprintf (stderr, "\n"); ++ fprintf (stderr, "WARNING: THIS WILL TOTALLY DESTROY ANY DATA ON %s:\n", drv); ++ fprintf (stderr, "Are you ABSOLUTELY SURE you want to do this? (y/n) "); ++ scanf ("%c", &c); ++ fprintf (stderr, "\n"); ++ ++ if (c == 'y' || c == 'Y') ++ return; ++ ++ fprintf (stderr, "Aborted\n"); ++ exit (1); ++} ++#endif ++ + int main (int argc, char *argv[]) + { + errcode_t retval = 0; +@@ -1839,6 +1869,11 @@ + #endif + PRS(argc, argv); + ++#ifdef __MINT__ ++ if (!quiet) ++ warn (device_name); ++#endif ++ + #ifdef CONFIG_TESTIO_DEBUG + if (getenv("TEST_IO_FLAGS") || getenv("TEST_IO_BLOCK")) { + io_ptr = test_io_manager; diff --git a/sys-fs/e2fsprogs/files/e2fsprogs-1.41.12-darwin-makefile.patch b/sys-fs/e2fsprogs/files/e2fsprogs-1.41.12-darwin-makefile.patch new file mode 100644 index 000000000000..9fbbfcb041bf --- /dev/null +++ b/sys-fs/e2fsprogs/files/e2fsprogs-1.41.12-darwin-makefile.patch @@ -0,0 +1,101 @@ +diff --git a/lib/Makefile.darwin-lib b/lib/Makefile.darwin-lib +index c94a5e7..6a11a66 100644 +--- a/lib/Makefile.darwin-lib ++++ b/lib/Makefile.darwin-lib +@@ -1,14 +1,15 @@ + # +-# This is a Makefile stub which handles the creation of Darwin BSD shared +-# libraries. ++# This is a Makefile stub which handles the creation of Darwin shared ++# libraries based on the ELF scheme. + # + # In order to use this stub, the following makefile variables must be defined. +-# +-# BSDLIB_VERSION = 1.0 +-# BSDLIB_IMAGE = libce +-# BSDLIB_MYDIR = et +-# BSDLIB_INSTALL_DIR = $(SHLIBDIR) +-# ++# ++# ELF_VERSION = 1.0 ++# ELF_SO_VERSION = 1 ++# ELF_IMAGE = libce ++# ELF_MYDIR = et ++# ELF_INSTALL_DIR = $(SHLIBDIR) ++# ELF_OTHER_LIBS = -lc + + all:: image + +@@ -16,36 +17,53 @@ real-subdirs:: Makefile + $(E) " MKDIR pic" + $(Q) mkdir -p pic + +-BSD_LIB = $(BSDLIB_IMAGE).$(BSDLIB_VERSION).dylib +-BSDLIB_PIC_FLAG = -fPIC ++ELF_LIB = $(ELF_IMAGE).$(ELF_VERSION).dylib ++ELF_SONAME = $(ELF_IMAGE).$(ELF_SO_VERSION).dylib + +-image: $(BSD_LIB) ++image: $(ELF_LIB) + + $(BSD_LIB): $(OBJS) +- $(E) " GEN_BSD_SOLIB $(BSD_LIB)" +- $(Q) (cd pic; $(CC) -dynamiclib -compatibility_version 1.0 -current_version $(BSDLIB_VERSION) \ +- -flat_namespace -undefined warning -o $(BSD_LIB) $(OBJS)) +- $(Q) $(MV) pic/$(BSD_LIB) . +- $(Q) $(RM) -f ../$(BSD_LIB) ++ $(E) " GEN_ELF_SOLIB $(ELF_LIB)" ++ $(Q) (cd pic; $(CC) -dynamiclib -o $(ELF_LIB) $(LDFLAGS) \ ++ -Wl,-install_name,$(libdir)/$(ELF_SONAME) $(OBJS) $(ELF_OTHER_LIBS)) ++ $(Q) $(MV) pic/$(ELF_LIB) . ++ $(Q) $(RM) -f ../$(ELF_LIB) ../$(ELF_IMAGE).dylib ../$(ELF_SONAME) + $(Q) (cd ..; $(LN) $(LINK_BUILD_FLAGS) \ +- `echo $(my_dir) | sed -e 's;lib/;;'`/$(BSD_LIB) $(BSD_LIB)) +- $(Q) (cd ..; $(LN) $(LINK_BUILD_FLAGS) $(BSD_LIB) $(BSDLIB_IMAGE).dylib) ++ `echo $(my_dir) | sed -e 's;lib/;;'`/$(ELF_LIB) $(ELF_LIB)) ++ $(Q) (cd ..; $(LN) $(LINK_BUILD_FLAGS) ../$(ELF_SONAME)) ++ ++installdirs-elf-lib:: ++ $(E) " MKINSTALLDIRS $(ELF_INSTALL_DIR) $(libdir)" ++ $(Q) $(MKINSTALLDIRS) $(DESTDIR)$(ELF_INSTALL_DIR) \ ++ $(DESTDIR)$(libdir) ++ ++installdirs:: installdirs-elf-lib + +-install-shlibs install:: $(BSD_LIB) +- $(E) " INSTALL_PROGRAM $(BSDLIB_INSTALL_DIR)/$(BSD_LIB)" +- $(Q) $(INSTALL_PROGRAM) $(BSD_LIB) \ +- $(DESTDIR)$(BSDLIB_INSTALL_DIR)/$(BSD_LIB) +- -$(Q) $(LDCONFIG) ++install-shlibs install:: $(ELF_LIB) installdirs-elf-lib ++ $(E) " INSTALL-ELF-LIB $(ELF_INSTALL_DIR)/$(ELF_LIB)" ++ $(Q) $(INSTALL_PROGRAM) $(ELF_LIB) $(DESTDIR)$(ELF_INSTALL_DIR)/$(ELF_LIB) ++ $(E) " SYMLINK $(ELF_INSTALL_DIR)/$(ELF_SONAME)" ++ $(Q) $(LN_S) -f $(ELF_LIB) $(DESTDIR)$(ELF_INSTALL_DIR)/$(ELF_SONAME) ++ $(E) " SYMLINK $(libdir)/$(ELF_IMAGE).dylib" ++ $(Q) $(LN_S) -f $(ELF_SONAME) \ ++ $(DESTDIR)$(libdir)/$(ELF_IMAGE).dylib + + install-strip: install ++ $(E) " STRIP-LIB $(ELF_INSTALL_DIR)/$(ELF_LIB)" ++ $(Q) $(STRIP) --strip-unneeded --remove-section=.comment \ ++ --remove-section=.note $(DESTDIR)$(ELF_INSTALL_DIR)/$(ELF_LIB) + + install-shlibs-strip: install-shlibs ++ $(E) " STRIP-LIB $(ELF_INSTALL_DIR)/$(ELF_LIB)" ++ @$(STRIP) --strip-unneeded --remove-section=.comment \ ++ --remove-section=.note $(DESTDIR)$(ELF_INSTALL_DIR)/$(ELF_LIB) + + uninstall-shlibs uninstall:: +- $(RM) -f $(DESTDIR)$(BSDLIB_INSTALL_DIR)/$(BSD_LIB) ++ $(RM) -f $(DESTDIR)$(ELF_INSTALL_DIR)/$(ELF_LIB) \ ++ $(DESTDIR)$(ELF_INSTALL_DIR)/$(ELF_SONAME) \ ++ $(DESTDIR)$(libdir)/$(ELF_IMAGE).dylib + + clean:: + $(RM) -rf pic +- $(RM) -f $(BSD_LIB) +- $(RM) -f ../$(BSD_LIB) +- $(RM) -f ../$(BSDLIB_IMAGE).dylib ++ $(RM) -f $(ELF_LIB) ++ $(RM) -f ../$(ELF_LIB) ../$(ELF_IMAGE).dylib ../$(ELF_SONAME) diff --git a/sys-fs/e2fsprogs/files/e2fsprogs-1.41.12-darwin-no-mntent.patch b/sys-fs/e2fsprogs/files/e2fsprogs-1.41.12-darwin-no-mntent.patch new file mode 100644 index 000000000000..ceb565d8fcd3 --- /dev/null +++ b/sys-fs/e2fsprogs/files/e2fsprogs-1.41.12-darwin-no-mntent.patch @@ -0,0 +1,27 @@ +diff --git a/misc/ismounted.c b/misc/ismounted.c +index 50b4140..84579a4 100644 +--- a/misc/ismounted.c ++++ b/misc/ismounted.c +@@ -86,8 +86,10 @@ static errcode_t check_mntent_file(const char *mtab_file, const char *file, + char buf[1024], *device = 0, *mnt_dir = 0, *cp; + + *mount_flags = 0; ++ #ifndef __APPLE__ + if ((f = setmntent (mtab_file, "r")) == NULL) + return errno; ++ #endif + if (stat(file, &st_buf) == 0) { + if (S_ISBLK(st_buf.st_mode)) { + #ifndef __GNU__ /* The GNU hurd is broken with respect to stat devices */ +@@ -175,7 +177,11 @@ static errcode_t check_mntent_file(const char *mtab_file, const char *file, + + retval = 0; + errout: ++ #ifdef __APPLE__ ++ fclose (f); ++ #else + endmntent (f); ++ #endif + return retval; + #else /* !HAVE_MNTENT_H */ + return 0; diff --git a/sys-fs/e2fsprogs/files/e2fsprogs-1.41.4-darwin-no-mntent.patch b/sys-fs/e2fsprogs/files/e2fsprogs-1.41.4-darwin-no-mntent.patch new file mode 100644 index 000000000000..e48d0c208934 --- /dev/null +++ b/sys-fs/e2fsprogs/files/e2fsprogs-1.41.4-darwin-no-mntent.patch @@ -0,0 +1,32 @@ +Dirk Tilger <dirk@miriup.de>: + For the mntent.patch: e2fsprogs is using a GNU libc specific + operation: setmntent and endmntent. Both operate on /etc/mtab, which + doesn't exist on MacOSX, thus they are simply not called on Darwin. + +http://bugs.gentoo.org/show_bug.cgi?id=263841 + +--- misc/ismounted.c 2008-05-05 21:00:01 +0400 ++++ misc/ismounted.c 2008-05-05 21:00:16 +0400 +@@ -86,8 +86,10 @@ + if ((f = fopen(mtab_file, "r")) == NULL) + return errno; + ++ #ifndef __APPLE__ + if ((f = setmntent (mtab_file, "r")) == NULL) + return errno; ++ #endif + if (stat(file, &st_buf) == 0) { + if (S_ISBLK(st_buf.st_mode)) { + #ifndef __GNU__ /* The GNU hurd is broken with respect to stat devices */ +@@ -177,7 +173,11 @@ + + retval = 0; + errout: ++ #ifdef __APPLE__ ++ fclose (f); ++ #else + endmntent (f); ++ #endif + return retval; + } + diff --git a/sys-fs/e2fsprogs/files/e2fsprogs-1.41.7-mint-blkid.patch b/sys-fs/e2fsprogs/files/e2fsprogs-1.41.7-mint-blkid.patch new file mode 100644 index 000000000000..2464ba0ee577 --- /dev/null +++ b/sys-fs/e2fsprogs/files/e2fsprogs-1.41.7-mint-blkid.patch @@ -0,0 +1,43 @@ +http://bugs.gentoo.org/276055 + +<alanh@fairlite.co.uk>: +The configure test program links against libblkid to test. This works +fine on shared library systems as libblkid automatically depends on +libuuid. But on static systems it needs explicit linking. + + +--- configure.in ++++ configure.in +@@ -398,8 +398,8 @@ + fi + + AC_CHECK_LIB(blkid, blkid_get_cache, +- [LIBBLKID=`$PKG_CONFIG --libs blkid`; +- STATIC_LIBBLKID=`$PKG_CONFIG --static --libs blkid`], ++ [LIBBLKID=`$PKG_CONFIG --libs blkid --libs uuid`; ++ STATIC_LIBBLKID=`$PKG_CONFIG --static --libs blkid --libs uuid`], + [AC_MSG_ERROR([external blkid library not found])], + [$LIBBLKID]) + BLKID_CMT=# +--- configure ++++ configure +@@ -4565,7 +4565,7 @@ + $as_echo_n "(cached) " >&6 + else + ac_check_lib_save_LIBS=$LIBS +-LIBS="-lblkid $LIBBLKID $LIBS" ++LIBS="-lblkid -luuid $LIBBLKID $LIBS" + cat >conftest.$ac_ext <<_ACEOF + /* confdefs.h. */ + _ACEOF +@@ -4625,8 +4625,8 @@ + { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_blkid_blkid_get_cache" >&5 + $as_echo "$ac_cv_lib_blkid_blkid_get_cache" >&6; } + if test "x$ac_cv_lib_blkid_blkid_get_cache" = x""yes; then +- LIBBLKID=`$PKG_CONFIG --libs blkid`; +- STATIC_LIBBLKID=`$PKG_CONFIG --static --libs blkid` ++ LIBBLKID=`$PKG_CONFIG --libs blkid --libs uuid`; ++ STATIC_LIBBLKID=`$PKG_CONFIG --static --libs blkid --libs uuid` + else + { { $as_echo "$as_me:$LINENO: error: external blkid library not found" >&5 + $as_echo "$as_me: error: external blkid library not found" >&2;} |