1da177e4c3
Initial git repository build. I'm not bothering with the full history, even though we have it. We can create a separate "historical" git archive of that later if we want to, and in the meantime it's about 3.2GB when imported into git - space that would just make the early git days unnecessarily complicated, when we don't have a lot of good infrastructure for it. Let it rip!
343 lines
9.1 KiB
Text
343 lines
9.1 KiB
Text
(Note: I consider version numbers as cheap. That means
|
|
that I do not like numbers like 0.1 and the like for
|
|
things that can be used since quite some time. But
|
|
then, 3.1 doesn't mean 'perfectly stable', too.)
|
|
|
|
Known bugs:
|
|
-----------
|
|
|
|
- Doesn't work on the alpha. The only 64/32-bit
|
|
problem that I'm aware of (pointer/int conversion
|
|
in readdir()) gives compiler warnings but is
|
|
apparently not causing the failure, as directory
|
|
reads basically work (but all files are of size 0).
|
|
Alas, I've got no alpha to debug. :-(
|
|
|
|
- The partition checker (drivers/block/genhd.c)
|
|
doesn't work with devices which have 256 byte
|
|
blocks (some very old SCSI drives).
|
|
|
|
- The feature to automatically make the fs clean
|
|
might leave a trashed file system with the
|
|
bitmap flag set valid.
|
|
|
|
- When a file is truncated to a size that is not
|
|
a multiple of the blocksize, the rest of the
|
|
last allocated block is not cleared. Well,
|
|
this fs never claimed to be Posix conformant.
|
|
|
|
Please direct bug reports to: zippel@linux-m68k.org
|
|
|
|
Version 3.20
|
|
------------
|
|
- kill kernel lock
|
|
- fix for a possible bitmap corruption
|
|
|
|
Version 3.19
|
|
------------
|
|
|
|
- sizeof changes from Kernel Janitor Project
|
|
- several bug fixes found with fsx
|
|
|
|
Version 3.18
|
|
------------
|
|
|
|
- change to global min macro + warning fixes
|
|
- add module tags
|
|
|
|
Version 3.17
|
|
------------
|
|
|
|
- locking fixes
|
|
- wrong sign in __affs_hash_dentry
|
|
- remove unnecessary check in affs_new_inode
|
|
- enable international mode for dircache fs
|
|
|
|
Version 3.16
|
|
------------
|
|
|
|
- use mark_buffer_dirty_inode instead of mark_buffer_dirty.
|
|
- introduce affs_lock_{link|dir|ext}.
|
|
|
|
Version 3.15
|
|
------------
|
|
|
|
- disable link to directories until we can properly support them.
|
|
- locking fixes for link creation/removal.
|
|
|
|
Version 3.14
|
|
------------
|
|
|
|
- correctly cut off long file names for compares
|
|
- correctly initialize s_last_bmap
|
|
|
|
Version 3.13
|
|
------------
|
|
|
|
Major cleanup for 2.4 [Roman Zippel]
|
|
- new extended block handling
|
|
- new bitmap allocation functions
|
|
- locking should be safe for the future
|
|
- cleanup of some interfaces
|
|
|
|
Version 3.12
|
|
------------
|
|
|
|
more 2.4 fixes: [Roman Zippel]
|
|
- s_lock changes
|
|
- increased getblock mess
|
|
- clear meta blocks
|
|
|
|
Version 3.11
|
|
------------
|
|
|
|
- Converted to use 2.3.x page cache [Dave Jones <dave@powertweak.com>]
|
|
- Corruption in truncate() bugfix [Ken Tyler <kent@werple.net.au>]
|
|
|
|
Version 3.10
|
|
------------
|
|
|
|
- Changed partition checker to allow devices
|
|
with physical blocks != 512 bytes.
|
|
|
|
- The partition checker now also ignores the
|
|
word at 0xd0 that Windows likes to write to.
|
|
|
|
Version 3.9
|
|
-----------
|
|
|
|
- Moved cleanup from release_file() to put_inode().
|
|
This makes the first one obsolete.
|
|
|
|
- truncate() zeroes the unused remainder of a
|
|
partially used last block when a file is truncated.
|
|
It also marks the inode dirty now (which is not
|
|
really necessary as notify_change() will do
|
|
it anyway).
|
|
|
|
- Added a few comments, fixed some typos (and
|
|
introduced some new ones), made the debug messages
|
|
more consistent. Changed a bad example in the
|
|
doc file (affs.txt).
|
|
|
|
- Sets the NOEXEC flag in read_super() for old file
|
|
systems, since you can't run programs on them.
|
|
|
|
Version 3.8
|
|
-----------
|
|
Bill Hawes kindly reviewed the affs and sent me the
|
|
patches he did. They're marked (BH). Thanks, Bill!
|
|
|
|
- Cleanup of error handling in read_super().
|
|
Didn't release all resources in case of an
|
|
error. (BH)
|
|
|
|
- put_inode() releases the ext cache only if it's
|
|
no longer needed. (BH)
|
|
|
|
- One set of dentry callbacks is enough. (BH)
|
|
|
|
- Cleanup of error handling in namei.c. (BH)
|
|
|
|
- Cleanup of error handling in file.c. (BH)
|
|
|
|
- The original blocksize of the device is
|
|
restored when the fs is unmounted. (BH)
|
|
|
|
- getblock() did not invalidate the key cache
|
|
when it allocated a new block.
|
|
|
|
- Removed some unnecessary locks as Bill
|
|
suggested.
|
|
|
|
- Simplified match_name(), changed all hashing
|
|
and case insensitive name comparisons to use
|
|
uppercase. This makes the tolower() routines
|
|
obsolete.
|
|
|
|
- Added mount option 'mufs' to force muFS
|
|
uid/gid interpretation.
|
|
|
|
- File mode changes were not updated on disk.
|
|
This was fixed before, but somehow got lost.
|
|
|
|
Version 3.7
|
|
-----------
|
|
|
|
- Added dentry callbacks to allow the dcache to
|
|
operate case insensitive and length ignorant
|
|
like the affs itself.
|
|
|
|
- getblock() didn't update the lastblock field in the
|
|
inode if the fs was not an OFS. This bug only shows
|
|
up if a file was enlarged via truncate() and there
|
|
was not enough space.
|
|
|
|
- Remove some more superfluous code left over from
|
|
the old link days ...
|
|
|
|
- Fixed some oversights which were in patch 2.1.78.
|
|
|
|
- Fixed a few typos.
|
|
|
|
Version 3.6
|
|
-----------
|
|
|
|
- dentry changes. (Thanks to Jes Sorensen for his help.)
|
|
|
|
- Fixed bug in balloc(): Superblock was not set dirty after
|
|
the bitmap was changed, so the bitmap wasn't sync'd.
|
|
|
|
- Fixed nasty bug in find_new_zone(): If the current
|
|
zone number was zero, the loop didn't terminate,
|
|
causing a solid lock-up.
|
|
|
|
- Removed support for old-style directory reads.
|
|
|
|
- Fixed bug in add_entry(): When doing a sorted insert,
|
|
the pointer to the next entry in the hash chain wasn't
|
|
correctly byte-swapped. Since most of the users of the
|
|
affs use it on a 68k, they didn't notice. But why did
|
|
I not find this during my tests?
|
|
|
|
- Fixed some oversights (version wasn't updated on some
|
|
directory changes).
|
|
|
|
- Handling of hard links rewritten. To the VFS
|
|
they appear now as normal Unix links. They are
|
|
now resolved only once in lookup(). The backside
|
|
is that unlink(), rename() and rmdir() have to
|
|
be smart about them, but the result is worth the
|
|
effort. This also led to some code cleanup.
|
|
|
|
- Changed name type to unsigned char; the test for
|
|
invalid filenames didn't work correctly.
|
|
(Thanks to Michael Krause for pointing at this.)
|
|
|
|
- Changed mapping of executable flag.
|
|
|
|
- Changed all network byte-order macros to the
|
|
recommended ones.
|
|
|
|
- Added a remount function, so attempts to remount
|
|
a dircache filesystem or one with errors read/write
|
|
can be trapped. Previously, ro remounts didn't
|
|
flush the super block, and rw remounts didn't
|
|
create allocation zones ...
|
|
|
|
- Call shrink_dcache_parent() in rmdir().
|
|
(Thanks to Bill Hawes.)
|
|
|
|
- Permission checks in unlink().
|
|
|
|
- Allow mounting of volumes with superfluous
|
|
bitmap pointers read only, also allows them
|
|
to be remounted read/write.
|
|
|
|
- Owner/Group defaults now to the fs user (i.e.
|
|
the one that mounted it) instead of root. This
|
|
obsoletes the mount options uid and gid.
|
|
|
|
- Argument to volume option could overflow the
|
|
name buffer. It is now silently truncated to
|
|
30 characters. (Damn it! This kind of bug
|
|
is too embarrassing.)
|
|
|
|
- Split inode.c into 2 files, the superblock
|
|
routines desperately wanted their own file.
|
|
|
|
- truncate() didn't allocate an extension block
|
|
cache. If a file was extended by means of
|
|
truncate(), this led to an Oops.
|
|
|
|
- fsuser is now checked last.
|
|
|
|
- rename() will not ignore changes in filename
|
|
casing any more (though mv(1) still won't allow
|
|
you to do "mv oldname OldName").
|
|
|
|
Version 3.5
|
|
-----------
|
|
|
|
- Extension block caches are now allocated on
|
|
demand instead of when a file is opened, as
|
|
files can be read and written without opening
|
|
them (e. g. the loopback device does this).
|
|
|
|
- Removed an unused function.
|
|
|
|
Version 3.4
|
|
-----------
|
|
|
|
- Hash chains are now sorted by block numbers.
|
|
(Thanks to Kars de Jong for finding this.)
|
|
- Removed all unnecessary external symbols.
|
|
|
|
Version 3.3
|
|
-----------
|
|
|
|
- Tried to make all types 'correct' and consistent.
|
|
- Errors and warnings are now reported via a
|
|
function. They are all prefixed by a severity
|
|
and have the same appearance:
|
|
"AFFS: <function>: <error message>"
|
|
(There's one exception to this, as in that function
|
|
is no pointer to the super block available.)
|
|
- The filesystem is remounted read-only after an
|
|
error.
|
|
- The names of newly created filesystem objects are
|
|
now checked for validity.
|
|
- Minor cleanups in comments.
|
|
- Added this Changes file. At last!
|
|
|
|
Version 3.2
|
|
-----------
|
|
|
|
- Extension block cache: Reading/writing of huge files
|
|
(several MB) is much faster (of course the added
|
|
overhead slows down opening, but this is hardly
|
|
noticeable).
|
|
- The same get_block()-routine can now be used for
|
|
both OFS and FFS.
|
|
- The super block is now searched in the block that
|
|
was calculated and in the one following. This
|
|
should remedy the round-off error introduced by
|
|
the 1-k blocks that Linux uses.
|
|
- Minor changes to adhere to the new VFS interface.
|
|
- The number of used blocks is now also calculated
|
|
if the filesystem is mounted read-only.
|
|
- Prefixed some constants with AFFS_ to avoid name
|
|
clashes.
|
|
- Removed 'EXPERIMENTAL' status.
|
|
|
|
Version 3.1
|
|
-----------
|
|
|
|
- Fixed a nasty bug which didn't allow read-only
|
|
mounts.
|
|
- Allow dir-cache filesystems to be mounted
|
|
read only.
|
|
- OFS support.
|
|
- Several other changes I just cannot remember
|
|
any more.
|
|
|
|
Version 3.0
|
|
-----------
|
|
|
|
- Almost complete rewrite for the new VFS
|
|
interface in Linux 1.3.
|
|
- Write support.
|
|
- Support for hard and symbolic links.
|
|
- Lots of things I remember even less ...
|
|
|
|
Version 2.0
|
|
-----------
|
|
|
|
- Fixed a few things to get it compiled.
|
|
- Automatic root block calculation.
|
|
- Partition checker for genhd.c
|
|
|
|
========================================
|
|
|
|
Let's just call Ray Burr's original affs
|
|
'Version 1.0'.
|