ChangeLog
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:81k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. 2000-01-02  a sun  <asun@asun.cobalt.com>
  2. * file.c (hfs_get_block): added hfs_get_block for regular files. 
  3. 1999-04-12  a sun  <asun@hecate.darksunrising.blah>
  4. * file_hdr.c (hdr_read): added rootinfo behaviour for DID header.
  5. 1999-04-11  a sun  <asun@hecate.darksunrising.blah>
  6. * super.c (parse_options): added s_version so that we can select
  7. between different versions of the same layout.
  8. 1999-04-05  a sun  <asun@hecate.darksunrising.blah>
  9. * linux/hfs_fs.h: unified netatalk and appledouble header format. 
  10. added in all of the AFP attribute bits.
  11. * file_hdr.c: added netatalk appledouble v2 compatible headers. 
  12. 1999-01-30  a sun  <asun@hecate.darksunrising.blah>
  13. * catalog.c (hfs_cat_move): fixed corruption problem with
  14. renames.
  15. 1999-01-27  a sun  <asun@hecate.darksunrising.blah>
  16. * file_hdr.c (get/set_dates): got rid of broken afpd times. NOTE:
  17. you must use netatalk-1.4b2+asun2.1.2 or newer for this.
  18. 1998-12-20  a sun  <asun@hecate.darksunrising.blah>
  19. * bdelete.c (del_root): assign bthLNode and bthFNode only if the
  20. root node becomes a leaf node. Disk First Aid no longer
  21. complains. Norton Utilities, of course, has decided that it
  22. doesn't like the root node number. bleah. i think that it might be
  23. due to Norton Utilities not expecting the root node to have moved.
  24. 1998-12-16  a sun  <asun@hecate.darksunrising.blah>
  25. * sysdep.c (hfs_revalidate_dentry): fix inode dates when there's a
  26. timezone change.
  27. 1998-12-15  root  <root@hecate.darksunrising.blah>
  28. * extent.c (new_extent): expand block size variables to handle
  29. u32. 
  30. * mdb.c (hfs_mdb_get): AlBlkSiz shouldn't be capped at 65535. we
  31. should be able to handle much larger volumes now.
  32. 1998-11-21  a sun  <asun@hecate.darksunrising.blah>
  33. * hfs_sysdep.h, hfs_fs.h: added hfs_from_utc/to_utc to deal with
  34. date differences on hfs formatted media. 
  35. NOTE: hfs extended keeps everything in utc, so we'll need to deal
  36. with that when appropriate.
  37. 1998-11-12  a sun  <asun@hecate.darksunrising.blah>
  38. * extent.c (shrink_fork): added some lock_bitmap/unlock_bitmap's
  39. to protect hfs_clear_vbm_bits. we should no longer have problems
  40. with free_ablocks wrapping around.
  41. 1998-11-02  a sun  <asun@hecate.darksunrising.blah>
  42. * mdb.c (hfs_mdb_get): plugged up an mdb failed initialization
  43. leak.
  44. 1998-10-31  a sun  <asun@hecate.darksunrising.blah>
  45. * version.c (hfs_version): bumped to version 0.96.
  46. * mdb.c (hfs_mdb_commit): you only write out the alternate MDB
  47. when the catalog or extents overflow files grow. that just leaves
  48. the btree corruption problems. bleah (whilst deleting a bunch of
  49. files, more of the btree can get pruned away than desired).
  50. 1998-10-30  a sun  <asun@hecate.darksunrising.blah>
  51. * dir.c: fixed a bunch of silliness with deletions. make sure to
  52. zero out stuff and set mark_inode_dirty().
  53. 1998-10-29  a sun  <asun@hecate.darksunrising.blah>
  54. * string.c (hfs_strcmp, hfs_streq, hfs_strhash): converted them to
  55. take name/len arguments instead of hfs_name to reduce copying.
  56. * dir.c, dir_nat.c, dir_cap.c, dir_dbl.c, sysdep.c: modified
  57. relevant areas to reflect string.c changes.
  58. 1998-10-28  a sun  <asun@hecate.darksunrising.blah>
  59. * hfs.h (hfs_lookup_dentry): oh my. more silliness. make sure to
  60. have the d_lookup use the same hash value as the one generated by
  61. hfs_hash_dentry. i also changed the argument order.
  62. (hfs_drop_special): change the argument order to be more in line
  63. with what the dcache stuff looks like.
  64. * sysdep.c (hfs_compare_dentry): the compare was returning the
  65. wrong value for correct matches and causing all sorts of
  66. mischief. this fixes both directory counts and mounting on top of
  67. hfs volumes.
  68. * file.c, file_cap.c, file_hdr.c: added mark_inode_dirty()'s in
  69. the relevant places.
  70. 1998-10-11  root  <asun@hecate.darksunrising.blah>
  71. * mdb.c (hfs_mdb_get): moved initialization of mdb->entry_dirty
  72. list to here to deal with trying to read a bad hfs volume.
  73. 1998-10-10  a sun  <asun@zoology.washington.edu>
  74. * inode.c, catalog.c, dir_*.c, sysdep.c: parts of the dcache
  75. conversion didn't get done properly. specifically, i forgot to
  76. move the hfs_cat_puts into the right place. that's fixed now.
  77. 1998-09-11  a sun  <asun@purgatorius.zoology.washington.edu>
  78. * mdb.c: altered mdb struct to reflect hfs plus usage.
  79. 1998-08-27  a sun  <asun@purgatorius.zoology.washington.edu>
  80. * file.c, file_hdr.c, file_cap.c: dealt with the remaining
  81. copy_to/from_user() error cases.
  82. 1998-08-26  a sun  <asun@purgatorius.zoology.washington.edu>
  83. * super.c (hfs_read_super): fixed to deal with cdroms. why doesn't
  84. the cdrom layer call the partition table code?
  85. Wed Jan 21 14:04:26 1998  a sun  <asun@zoology.washington.edu>
  86. * inode.c, sysdep.c
  87. use d_iput to uncache dentry from catalog entry instead of relying
  88. on put_inode. no more NULL pointer dereferences!
  89. * catalog.c
  90. cleaned up hfs_cat_put a little.
  91. ISSUES (non-fatal): mv dir dir2 while creating files in dir screws
  92.                     up directory counts.
  93.     deletion using netatalk screws up directory
  94.       counts.
  95. Thu Jan 15 19:14:28 1998  a sun  <asun@zoology.washington.edu>
  96. * catalog.c
  97. make deletion happen when requested instead of waiting until
  98. an hfs_cat_put as the dcache can hold onto entries for quite
  99. some time.
  100. Wed Jan 14 14:43:16 1998  a sun  <asun@zoology.washington.edu>
  101. * catalog.c
  102. the current catalog allocation scheme allocates
  103. PAGE_SIZE/sizeof(struct hfs_cat_entry) entries at a time and keeps
  104. a pool of free entries up to this allocation unit * 8.
  105. * inode.c
  106. make sure to always hfs_cat_put if hfs_iget is going to return
  107. NULL.
  108. * string.c, catalog.c
  109. use linux' hashing method to generate hashes. the old hashing was
  110.   getting collisions. catalog.c also has a larger hash table to
  111.   prevent collisions.
  112. Tue Jan 13 13:06:01 1998  a sun  <asun@zoology.washington.edu>
  113. * version.c
  114. bumped to 0.95+asun3
  115. * catalog.c
  116. re-wrote to dynamically allocate/delete catalog entries. on a 486,
  117. entries fit into the size-256 slab.
  118. Wed Jan  7 19:33:33 1998  a sun  <asun@zoology.washington.edu>
  119. * inode.c 
  120. don't hfs_cat_put gratuitously in hfs_iget. that's a bad
  121.   idea and results in screwed up entry counts.
  122. Tue Jan  6 14:38:24 1998  a sun  <asun@zoology.washington.edu>
  123. * version.c
  124. changed it to 0.95+asun2
  125. * sysdep.c
  126. altered catalog entry pruning to make sure that an iput
  127. gets done. for some reason, shrink_dcache_parent wasn't
  128. doing it.
  129. * catalog.c
  130. added a global dirty list to check for pruning.
  131. Tue Jan  6 12:29:52 1998  a sun  <asun@zoology.washington.edu>
  132. * catalog.c
  133. re-wrote it to be similar to 2.1.x inode.c. this should
  134.   at least make catalog.c SMP safe. 
  135. * hfs.h, linux/hfs_fs.h
  136. moved dentry operations into hfs.h. these probably should
  137. be moved somewhere else.
  138. * super.c, dir_cap.c, dir_nat.c, dir_dbl.c, sysdep.c
  139. added dentry ops to hash everything to lowercase.
  140. Sun Dec 28 22:48:53 1997  a sun  <asun@zoology.washington.edu>
  141. * sysdep.c, catalog.c, hfs.h
  142. as a temporary workaround until catalog.c gets re-written, 
  143. i flush the dcache if we need more entries. 
  144. Fri Dec 19 15:11:21 1997  a sun  <asun@zoology.washington.edu>
  145. * dir_dbl.c
  146. statically allocate tmp_name instead of doing it dynamically.
  147. NOTE: well, those pesky hfs_cat_put messages still aren't gone. in
  148. addition, catalog.c needs to be modified to free up some entries
  149. when the cache gets filled up. 
  150. Sun Dec 14 11:51:11 1997  a sun  <asun@zoology.washington.edu>
  151. * linux/hfs_fs.h
  152. moved the dentry stuff into within the #ifdef __KERNEL__ 
  153. part of hfs_fs.h and cleaned up a little.
  154. Sun Dec 14 11:24:54 1997  a sun  <asun@zoology.washington.edu>
  155. * dir.c
  156. changed hfs_rename to delete all old dentries. hfs_cat_put
  157. messages on umount should be a thing of the past now.
  158. Sun Dec 14 01:12:58 1997  a sun  <asun@zoology.washington.edu>
  159. * dir.c
  160. changed mark_inodes_deleted to dget/d_delete/dput the dentry
  161. instead of just dropping it. the bytes available should now
  162. be updated properly upon deletion.
  163. Wed Dec 10 00:01:25 1997  a sun  <asun@zoology.washington.edu>
  164. * dir.c
  165. changed mark_inodes_deleted to drop the dentry instead of 
  166. just deleting it. 
  167. TODO: bytes available aren't being properly updated when a
  168. resource fork gets deleted.
  169. Mon Dec  8 23:22:40 1997  a sun  <asun@zoology.washington.edu>
  170. * dir_cap.c, dir_nat.c, dir_dbl.c, dir.c
  171. * hfs.h, linux/hfs_sysdep.h, linux/hfs_fs_i.h
  172. Added code to drop ({dbl,cap,nat}_drop_dentry) invalid
  173. dentries when creating or moving a file.
  174. * inode.c
  175. Added code to delete cached dentries when a file gets deleted.
  176. * current yuckiness: there's an extra hfs_cat_put somewhere. it's
  177. harmless but bothersome.
  178. Thu Dec  4 00:14:03 1997  a sun  <asun@zoology.washington.edu>
  179. * dir.c, dir_cap.c, dir_nat.c, file.c, file_hdr.c, inode.c,
  180. * linux/{hfs_sysdep.h, hfs_fs.h}, version.c:
  181. Completed first code dentrification sweep. It mounts! It copies!
  182. It dcaches! 
  183. Mon Apr 28 06:58:44 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  184. * version.c, INSTALL.sgml, HFS.sgml:
  185. Bump version to 0.95 (Woohoo! We're beta!)
  186. * linux/hfs_fs.h:
  187. Modify HFS_SB() and HFS_I() when compiled into the kernel.
  188. * FAQ.sgml:
  189. Add a new question (and its answer):
  190. Why does my Macintosh show generic application and document icons?
  191. * HFS.sgml:
  192. Add some URLs and remove the (now empty) FAQ section.
  193. Sun Apr 27 22:17:01 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  194. * HFS.sgml:
  195. Don't call the version 1 headers "slightly modified".
  196. * file_hdr.c, dir_nat.c:
  197. Comment some AFPD compatibility stuff.
  198. * FAQ.sgml:
  199. Update for version 0.95.
  200. * BUG_INFO:
  201. Remove the BIG_INFO script since we no longer mention it.
  202. * README.sgml, INSTALL.sgml, HFS.sgml, Makefile:
  203. Split README.sgml into HFS.sgml and INSTALL.sgml.
  204. Stop including the document sources in snapshots.
  205. * file_hdr.c:
  206. Fix hdr_truncate() not to truncate the data fork.
  207. Wed Apr 16 23:56:25 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  208. * FAQ.sgml:
  209. Bump version to 0.8.4 and add two answers:
  210. How to fsck an HFS filesystem.
  211. How to generate linux/version.h.
  212. * version.c, README.sgml:
  213. Bump version to 0.8.4.
  214. * README.sgml, FAQ.sgml, Makefile:
  215. Separate the FAQ from the README.
  216. * linux/hfs_fs.h:
  217. Add (struct hfs_fork) to the forward declarations.
  218. Thu Apr 10 05:47:16 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  219. * linux/hfs_sysdep.h:
  220. Work around the non-const declaration of test_bit()'s second argument.
  221. * Makefile:
  222. Use .config from the kernel source to check for MODVERSIONS.
  223. Wed Apr  9 07:57:17 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  224. * bnode.c:
  225. Check the record table in each bnode as we read it from disk.
  226. * super.c, mdb.c, hfs.h:
  227. Deal with the ATTRIB_CLEAN bit of the MDB properly (in mdb.c).
  228. * super.c, hfs.h, mdb.c:
  229. Search for the alt-MDB rather than using the device size to find it.
  230. Wed Apr  9 03:39:05 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  231. * version.c, README.sgml:
  232. Bump version to 0.8.3.
  233. Mon Apr  7 20:09:56 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  234. * part_tbl.c:
  235. Fix to allow bootable CDROMs (which have blocksize != 512) to mount.
  236. * super.c:
  237. Check that blk_size[MAJOR(dev)] is non-NULL before dereferencing.
  238. Sat Apr  5 10:44:42 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  239. * hfs_btree.h, binsert.c, brec.c, bfind.c, bins_del.c, bdelete.c:
  240. Make btree operations less likely to do
  241. nasty things if the tree is corrupted.
  242. * part_tbl.c, README.sgml:
  243. Count partitions from 0 rather than from 1.
  244. Wed Apr  2 23:26:51 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  245. * bdelete.c:
  246. Don't bother checking for oversized keys in hfs_bdelete().
  247. * bdelete.c, bfind.c, binsert.c:
  248. Verify key lengths against the maximum given for the tree.
  249. * Makefile:
  250. Check that /usr/include/linux/modversions.h exists before including it.
  251. This allows compilation without CONFIG_MODVERSIONS enabled.
  252. Sat Mar 29 13:17:53 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  253. * linux/hfs_fs.h, super.c, file_hdr.c, hfs.h, extent.c, file_cap.c,
  254.   dir_dbl.c, dir_nat.c, dir.c, dir_cap.c, binsert.c, catalog.c,
  255.   bfind.c:
  256. Make (struct hfs_bkey) and (struct hfs_brec) more "abstract".
  257. * binsert.c:
  258. Remove redundant test in hfs_binsert().
  259. Sat Mar 29 05:24:23 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  260. * version.c, README.sgml:
  261. Fix formatting problems in README.sgml and bump version to 0.8.2.
  262. * extent.c:
  263. Fix bug that caused serious headaches with fragmented files.
  264. Fri Mar 28 00:23:18 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  265. * version.c, README.sgml:
  266. Bump version to 0.8.1.
  267. * btree.c, balloc.c:
  268. Commit map nodes to buffers when new map nodes are added.
  269. Thu Mar 27 22:41:07 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  270. * Makefile:
  271. Include linux/modversions.h from the gcc command line.
  272. * mdb.c:
  273. Was updating modified date twice in hfs_mdb_commit().
  274. * linux/hfs_sysdep.h, linux/hfs_fs.h, linux/hfs_fs_i.h,
  275.   linux/hfs_fs_sb.h, sysdep.c, trans.c, super.c, hfs_sysdep.h, inode.c,
  276.   hfs_fs_i.h, hfs_fs_sb.h, hfs_fs.h, hfs.h, file_cap.c, file_hdr.c,
  277.   file.c, dir_nat.c, dir_cap.c, dir_dbl.c, Makefile, dir.c:
  278. Rearrange headers in preparation for inclusion in the kernel.
  279. * hfs_fs_sb.h, hfs_fs.h:
  280. Add forward declarations so other code can include these headers.
  281. * hfs_sysdep.h:
  282. Include __constant_hton[ls]() for little-endian machines.
  283. * hfs_fs.h, hfs_sysdep.h, hfs.h:
  284. Move typedefs of hfs_{byte,word,lword}_t from hfs.h to hfs_sysdep.h.
  285. Include hfs_sysdep.h from hfs_fs.h.
  286. * trans.c, super.c, part_tbl.c, string.c, inode.c, mdb.c, hfs_fs_sb.h,
  287.   hfs_sysdep.h, hfs_fs.h, hfs.h, hfs_btree.h, file_cap.c, file_hdr.c,
  288.   file.c, dir_nat.c, extent.c, dir_dbl.c, dir.c, dir_cap.c, catalog.c,
  289.   btree.c, bnode.c, brec.c, bitmap.c, bitops.c, bins_del.c, binsert.c,
  290.   bdelete.c, bfind.c, balloc.c:
  291. Big type system changes in preparation for kernel inclusion:
  292. '[US](8|16|32)' -> 'hfs_[us](8|16|32)' (avoids name space pollution)
  293. 'hfs_name_t' -> 'struct hfs_name' (allows forward declaration)
  294. * super.c, hfs_fs.h:
  295. Add init_hfs_fs() to super.c for non-module compilation.
  296. Wed Mar 26 07:53:59 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  297. * version.c, README.sgml:
  298. Bump version to 0.8.
  299. * README.sgml:
  300. Special compilation note for DEC Alpha.
  301. * README.sgml:
  302. Note status on non-Intel processors.
  303. * hfs_fs.h:
  304. Use long's for read() and write() on the Alpha.
  305. * README.sgml:
  306. Document the afpd mount option.
  307. * inode.c:
  308. Make files always writable for owner in afpd mode.
  309. Tue Mar 25 23:21:39 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  310. * part_tbl.c:
  311. Clean up the error checking code a bit.
  312. Sat Mar 22 19:43:40 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  313. * part_tbl.c:
  314. Fixed uninitialized variable in old-style partition code.
  315. * bins_del.c, bdelete.c:
  316. Fix extraneous "bad argument to shift_{left,right}" messages.
  317. * bitops.c:
  318. Note that these routines are now tested on Intel, PPC and Alpha.
  319. * Makefile:
  320. Add -fno-builtin to the CFLAGS.
  321. Fri Feb 14 10:50:14 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  322. * hfs_sysdep.h:
  323. Don't include <asm/*.h> until after <linux/types.h>.
  324. * catalog.c:
  325. Use volume create date in hashfn() rather than casting pointer to int.
  326. * hfs.h, mdb.c:
  327. Maintaing volume create, modify and backup dates in struct hfs_mdb.
  328. * hfs_fs.h:
  329. Include the header for put_user BEFORE using it!
  330. * string.c, hfs.h:
  331. Make hfs_strhash() return an unsigned int.
  332. * trans.c, version.c, super.c, mdb.c, part_tbl.c, string.c, inode.c,
  333.   hfs_sysdep.h, hfs_fs.h, hfs_fs_sb.h, hfs_btree.h, hfs.h, file_cap.c,
  334.   file_hdr.c, extent.c, dir_dbl.c, dir_nat.c, dir_cap.c, dir.c,
  335.   catalog.c, btree.c, bnode.c, brec.c, bitmap.c, binsert.c,
  336.   bins_del.c, bdelete.c, balloc.c, README.sgml, Makefile:
  337. Updated copyright notices.
  338. * trans.c, part_tbl.c, string.c, super.c, inode.c, mdb.c, hfs_fs.h,
  339.   hfs_fs_sb.h, hfs_sysdep.h, hfs_btree.h, hfs.h, file_cap.c,
  340.   file_hdr.c, dir_nat.c, extent.c, dir_cap.c, dir_dbl.c, catalog.c,
  341.   dir.c, brec.c, btree.c, bitmap.c, bnode.c, bdelete.c, bins_del.c,
  342.   binsert.c, Makefile, TODO, balloc.c:
  343. First shot at portability to the DEC Alpha and non-gcc compilers.
  344. This involved a significant overhaul of the type system.
  345. Tue Feb  4 04:26:54 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  346. * version.c, README.sgml:
  347. Bump version to "pre-0.8-4".
  348. * dir_nat.c:
  349. Allow creat() in Netatalk .AppleDouble directories.
  350. * dir_dbl.c:
  351. Make local functions static.
  352. * dir_dbl.c:
  353. Removed unnecessary 'extern' qualifiers from forward declarations.
  354. * file_hdr.c, TODO:
  355. Fixed the 30-year time warp with afpd.
  356. * TODO, trans.c:
  357. Don't mangle the name .AppleDesktop under fork=netatalk.
  358. Mon Feb  3 23:18:45 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  359. * inode.c:
  360. Make header files always writable when the afpd mount option is given.
  361. Otherwise it is impossible to unlock a locked file.
  362. * TODO, inode.c:
  363. Let afpd think chmod() always succeeds, so "New Folder" works right.
  364. * super.c:
  365. The 'afpd' mount option now makes 'fork=n,names=n' the default.
  366. * TODO:
  367. List the current known afpd-compatibility problems as bugs.
  368. * file_hdr.c:
  369. Make certain date changes through header files get written to disk.
  370. Sat Feb  1 02:24:12 1997  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  371. * mdb.c:
  372. Work around for Linux rounding device sizes to 1k increments.
  373. * README.sgml:
  374. Fixed a typo: "the a".
  375. Sat Dec 28 20:41:01 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  376. * TODO:
  377. Add ioctl() interface as a "missing feature."
  378. * dir_nat.c:
  379. Finish implementing the afpd-compatibility
  380. mode using the new 'afpd' mount option.
  381. * hfs_fs_sb.h, super.c:
  382. Add new 'afpd' mount option.
  383. * file_cap.c:
  384. Spelling fix.
  385. Wed Dec 11 23:16:08 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  386. * TODO, README.sgml:
  387. Optimistically document the hybrid CD problem as fixed.
  388. * part_tbl.c:
  389. Fix the partition code so at least some of the hybrid
  390. CDROMs that were previously rejected are now accepted.
  391. * hfs.h:
  392. Make fs_start a 32-bit integer rather than 16-bits.
  393. The 16-bit value would overflow if a partition started
  394. beyond the 32M mark (e.g. the Executor 2 Beta 1 CDROM).
  395. * extent.c:
  396. Fixed a typo in an error message.
  397. Tue Dec 10 14:43:46 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  398. * dir_nat.c:
  399. Merge in the (still dormant) afpd-compatibility changes.
  400. * inode.c:
  401. Make the .AppleDouble directory writable (again).
  402. * version.c, README.sgml:
  403. Bump version up to "pre-0.8-3".
  404. * hfs_fs.h, file_cap.c, file_hdr.c:
  405. Move AFP constants to hfs_fs.h and prefix them with "HFS_".
  406. * dir_nat.c, inode.c:
  407. Back-out changes that allowed writing to the .AppleDouble directory.
  408. * Makefile:
  409. Update rules for linuxdoc-sgml v1.5.
  410. * extent.c:
  411. Fixed serious bug in decode_extent() with handling of empty extents.
  412. * file.c:
  413. Rewrote hfs_getblk().
  414. It will no longer hang if hfs_extent_map() is buggy.
  415. Also halves the worst-case number of calls to hfs_extent_map().
  416. * extent.c:
  417. Fixed serious bug in decode_extent() with handling of empty extents.
  418. * hfs_fs.h:
  419. Small change so the PPC (and maybe other architectures?)
  420. pick up the prototypes for the user-space access functions.
  421. * super.c, file_cap.c, file_hdr.c, hfs_fs.h, file.c:
  422. Updated for new user-space memory interface.
  423. Sun Dec  8 11:49:36 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  424. * dir_nat.c:
  425. Add special code for unlink(), and rename() in the .AppleDouble
  426. directory and rmdir() of the .AppleDouble directory.
  427. * inode.c:
  428. Make the .AppleDouble directory writable.
  429. * file_hdr.c:
  430. Use AFP flags in version 1 headers (for Netatalk compatibility).
  431. * trans.c:
  432. Fixed bug with long names causing kernel Oops.
  433. Mon Oct  7 06:05:01 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  434. * hfs_fs.h, file_cap.c, file_hdr.c, hfs.h, extent.c, file.c, dir.c:
  435. Fix types for various read/write/truncate computations.
  436. Also allows compilation with 2.1.x kernels.
  437. Thu Sep 19 10:28:43 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  438. * README.sgml, version.c:
  439. Bump version up to "pre-0.8-2".
  440. * TODO:
  441. Reformat the To Do list introducing prioritized categories.
  442. * file_hdr.c, file.c:
  443. Move comments about mmap() for headers from file.c to file_hdr.c.
  444. Also revise the reasoning for not yet having it implemented.
  445. * dir_nat.c, dir_cap.c, dir_dbl.c:
  446. Remove 'hfs_' prefix from names of some purely local functions.
  447. * dir_dbl.c, TODO:
  448. Under AppleDouble make create(), mkdir(), mknod(), unlink(), rename()
  449. and rename() check against header files when arguments start with '%'.
  450. * super.c, hfs_fs_sb.h, hfs_fs.h, dir_dbl.c, dir_nat.c, dir_cap.c,
  451.   dir.c, README.sgml:
  452. Fix problem that prevented creating %RootInfo or .rootinfo in all
  453. directories in addition to preventing deletion from the root directory.
  454. * TODO:
  455. Remove writable header files from the To Do list.
  456. * README.sgml:
  457. Add extensive discussion of writing to HFS filesystems and
  458. the format of the special files.
  459. * file_hdr.c:
  460. Generate the 'homefs' field for version 1 header files.
  461. Wed Sep 18 23:07:45 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  462. * hfs_fs.h, file_cap.c:
  463. Comment the definition of (struct hfs_cap_info).
  464. * version.c, README.sgml:
  465. Bump version up to "pre-0.8-1" and update the "How can I write?" FAQ.
  466. * file_hdr.c:
  467. Implement hdr_write() and hdr_truncate()!!
  468. * hfs_fs_i.h, inode.c:
  469. Make hdr_layout per-inode (not per-file) so hdr_truncate() will work.
  470. * file.c, hfs.h, catalog.c, extent.c, balloc.c:
  471. hfs_extent_adj() now uses fork->lsize to determine the target file size.
  472. Sun Sep 15 07:55:24 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  473. * README.sgml, trans.c:
  474. Prevent creation of files & directories with '' or ':' in their names.
  475. * string.c, hfs_fs.h, hfs.h, dir_dbl.c, dir_nat.c, dir_cap.c:
  476. With case=lower could have run off end of string.
  477. Tue Sep 10 12:05:47 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  478. * inode.c:
  479. Small clean up of HFS_FIL_LOCK handling.
  480. * inode.c:
  481. Fix notify_change() not to accidentally make metadata executable.
  482. * hfs_fs.h:
  483. AppleSingle files should have HFS_ITYPE_NORM.
  484. * inode.c:
  485. Return to old behavior where MdDat = i_mtime.
  486. * dir_dbl.c:
  487. Fix serious bug in hfs_dbl_readdir() that would lock-up access to a
  488. directory if one tried to write to a directory they had previously read.
  489. * file.c:
  490. Fix hfs_do_write() to adjust the fork's 'lsize' if it changed.
  491. * inode.c, file_cap.c:
  492. Allow truncate() to be called even on metadata.
  493. Any size changes will last only until the next iput() of the inode.
  494. Truncating a header file doesn't yet truncate the resource fork.
  495. * inode.c:
  496. Allow chmod() on a directory if it doesn't actually change i_mode.
  497. * hfs_fs.h, trans.c, super.c:
  498. Rename hfs_cap2mac() to hfs_colon2mac().
  499. Rename hfs_apl2mac() to hfs_prcnt2mac().
  500. * file_hdr.c:
  501. Move header construction out of hdr_read() to create hdr_build_meta().
  502. * hfs.h:
  503. Add byte-order independent conversions: U32->U16, U32->U8 and U16->U8.
  504. * file.c, file_cap.c, hfs_fs.h:
  505. Rename fix_perms() to hfs_file_fix_mode() and
  506. move it from file_cap.c to file.c.
  507. * README.sgml, super.c:
  508. Make the default for the names mount option vary with the fork option.
  509. * file_cap.c:
  510. The umask was applied incorrectly in fix_perms().
  511. Mon Sep  9 13:11:28 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  512. * README.sgml:
  513. Note that it compiles on m68k machines, but needs more testing.
  514. * hfs_sysdep.h, Makefile:
  515. Changes to compile unmodified on m68k (and possibly other machines).
  516. * dir_cap.c:
  517. hfs_cap_readdir() was mistakenly producing .rootinfo entries for
  518. the .finderinfo and .resource subdirectories of the root directory.
  519. * inode.c:
  520. A directory's i_size was too small by 1 under CAP, so hfs_cap_readdir()
  521. would omit the last directory entry.  i_nlink was also too large by 1.
  522. Sun Sep  8 12:56:06 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  523. * file_hdr.c:
  524. Rewrite hdr_read() to be more efficient and to deal correctly with
  525. descriptors having lengths that differ from the actual size of the data.
  526. * file_cap.c:
  527. Add write support for CAP finderinfo files!!
  528. * super.c, inode.c, hfs_fs.h, hfs_fs_i.h, hfs_fs_sb.h, file_dbl.c,
  529.   file_nat.c, file_hdr.c, file.c, file_cap.c, Makefile, dir.c:
  530. Generate metadata (header files and CAP finderinfo files) on-the-fly.
  531. The files file_{dbl,nat}.c are merged into file_hdr.c as a result.
  532. Sat Sep  7 08:09:24 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  533. * README.sgml:
  534. Fix silly grammatical error.
  535. Fri Sep  6 09:17:12 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  536. * hfs_fs_sb.h, super.c:
  537. No need to cast type of s_reserved.
  538. * file_dbl.c, file_nat.c, dir_dbl.c, dir_nat.c, file_cap.c, dir_cap.c:
  539. Add the missing NULL readpage and writepage entries to the inode_ops.
  540. * file_dbl.c, file_nat.c, file.c, file_cap.c:
  541. Cleanup error checking for read() and write().
  542. Thu Sep  5 05:29:53 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  543. * version.c, README.sgml:
  544. Bump version up to "0.7.2".
  545. User-visible changes from 0.7.0:
  546. + Corrected CAP finderinfo file format.
  547. + Support for more features of CAP finderinfo files.
  548. + No longer requires gcc 2.7.0 or newer.
  549. + Now implements mknod() system call.
  550. * hfs_fs.h, dir_nat.c, file_cap.c, file_nat.c, README.sgml, dir_cap.c:
  551. Include the CAP and Netatalk copyright notices.
  552. * hfs_fs.h, file_cap.c:
  553. Repair and improve CAP support.
  554. * catalog.c:
  555. Oops! The BkDat for new files and directories was in 1972 when
  556. it should have been in 1904 (not that it matters that much).
  557. * inode.c:
  558. The HFS MdDat should be the larger of the i_mtime and i_ctime.
  559. * README.sgml:
  560. Change 'm_time' to 'i_mtime'.
  561. Wed Sep  4 13:27:35 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  562. * version.c, README.sgml:
  563. Bump version up to "0.7.1".
  564. User-visible changes from 0.7.0:
  565. + Minor bug in CAP finderinfo file format fixed.
  566. + No longer requires gcc 2.7.0 or newer.
  567. + Now implements mknod() system call.
  568. * README.sgml:
  569. Removed note about needing gcc 2.7.0 or newer.
  570. * file.c:
  571. Optimize hfs_do_read() based on the fact that HFS has no holes in files.
  572. Minor code formatting changes.
  573. * hfs.h, hfs_sysdep.h, mdb.c, extent.c, file.c, btree.c, catalog.c,
  574.   balloc.c, bnode.c:
  575. Reorganize memory management routines.
  576. hfs_malloc() and hfs_free() are the main routines.
  577. The macros FREE() and MALLOC() are gone.
  578. HFS_NEW() and HFS_DELETE() are new 'shorthand' macros.
  579. * btree.c:
  580. Fix broken debugging code.
  581. * super.c, hfs.h, mdb.c, part_tbl.c, Makefile:
  582. Separate partition table handling into its own file.
  583. * dir.c:
  584. Spelling fixes.
  585. * sysdep.c:
  586. Oops!  Error check got sense reversed while editing.
  587. * mdb.c, sysdep.c, hfs.h, hfs_btree.h, hfs_sysdep.h, btree.c, extent.c,
  588.   bfind.c, bnode.c, balloc.c:
  589. Make hfs_buffer a pointer to a buffer_head, rather than a buffer_head.
  590. * hfs_fs.h, dir_cap.c, dir_dbl.c, dir_nat.c, dir.c:
  591. Add a mknod() entry to the inode_operations for normal directories.
  592. All it is good for is letting root create regular files.
  593. * file_dbl.c, file_nat.c, file.c, file_cap.c, dir_cap.c, dir_dbl.c,
  594.   dir_nat.c:
  595. Add the missing NULL entries to the end of the file_operations.
  596. * super.c, hfs_btree.h, hfs_fs.h, mdb.c, extent.c, hfs.h, catalog.c:
  597. Make the remainder of the (untested) changes
  598. to allow compilation with gcc 2.6.3.
  599. * hfs_fs.h:
  600. Fix hfs_fs.h to work with gcc 2.6.3.
  601. * hfs_fs.h:
  602. (struct hfs_cap_info) should never have been 'packed'.
  603. * BUG_INFO:
  604. Use -V for getting version of module utilities.
  605. * super.c, sysdep.c, trans.c, hfs_fs_sb.h, inode.c, hfs_fs.h,
  606.   hfs_fs_i.h, file_cap.c, file_dbl.c, file_nat.c, dir_dbl.c,
  607.   dir_nat.c, file.c, dir.c, dir_cap.c:
  608. Fix up hfs_fs{,_i,_sb}.h in preparation for inclusion in kernel.
  609. Tue Sep  3 23:58:03 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  610. * hfs.h:
  611. Change eventual destination to linux/fs/hfs rather than include/linux.
  612. * super.c, inode.c, mdb.c, hfs_btree.h, hfs_fs.h, hfs_sysdep.h,
  613.   file_dbl.c, file_nat.c, hfs.h, dir_nat.c, extent.c, dir_dbl.c,
  614.   catalog.c, dir_cap.c, brec.c, btree.c, binsert.c, bnode.c, bdelete.c,
  615.   bfind.c, bins_del.c, balloc.c:
  616. Replace all the swap{16,32}() stuff w/ ntohl() and friends.
  617. Fri Aug 30 09:51:23 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  618. * version.c, README.sgml:
  619. Rewrite installation instructions and bump version up to "0.7.0".
  620. * Makefile:
  621. Remove the INCDIR variable; we now rely on the
  622. user to have the correct links in /usr/include.
  623. Mon Aug 26 12:25:41 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  624. * version.c, README.sgml:
  625. Reformat the documentation and bump version up to "pre-0.7-9".
  626. Hopefully this will become version 0.7 in a few days.
  627. Thu Aug 22 08:00:44 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  628. * README.sgml, version.c:
  629. Bump version up to "pre-0.7-8".
  630. * file_nat.c, file_dbl.c:
  631. AppleDouble headers had resource fork size in wrong byte order.
  632. Wed Aug 21 05:22:28 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  633. * version.c, README.sgml:
  634. Bump version up to "pre-0.7-7".
  635. * bnode.c:
  636. Fixed a long-standing bug in hfs_bnode_lock().
  637. This bug occasionally caused lock-up under heavy load.
  638. Tue Aug 20 09:15:10 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  639. * README.sgml, version.c:
  640. Bump version up to "pre-0.7-6".
  641. * catalog.c:
  642. Fix a deadlock problem in catalog readers/writers locking.
  643. * bins_del.c:
  644. hfs_bnode_update_key() was still corrupting the header node sometimes.
  645. * catalog.c, dir.c:
  646. Fix problem with extending the catalog B-tree hanging hfs_cat_commit().
  647. Fix a race that could delete a non-empty directory.
  648. Sun Aug 18 23:16:43 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  649. * version.c, README.sgml:
  650. Bump version to "pre-0.7-5" for test release.
  651. * dir_cap.c, README.sgml:
  652. Change ".:rootinfo:" to ".rootinfo".
  653. * hfs_fs.h, dir_cap.c, dir_dbl.c, dir_nat.c:
  654. Mangle the names as first step in hfs_{cap,dbl,nat}_lookup().
  655. Use the new hfs_streq() to catch mixed case matches to the special
  656. files and directories in hfs_{cap,dbl,nat}_lookup().
  657. Store reserved names only once.
  658. * dir.c, hfs.h, string.c:
  659. Implement hfs_streq() which tests for string equality more
  660. rapidly than hfs_strcmp() by checking for equal length first,
  661. and use it when checking for reserved names.
  662. * inode.c, TODO, dir_cap.c, dir_dbl.c, README.sgml:
  663. Provide the metadata for the root directory for the CAP and AppleDouble
  664. schemes in the files ".:rootinfo:" and "%RootInfo", respectively.
  665. * TODO, super.c:
  666. Add (untested) support for the old Mac Plus style of partition map.
  667. * bdelete.c, TODO:
  668. Note the possibility of bdelete() to hanging on a corrupted B-tree.
  669. * TODO:
  670. Add items corresponding to some of the 'XXX' comments in the sources.
  671. * dir_dbl.c, dir_cap.c:
  672. Update comments, removing ref. to a comment that once existed in inode.c
  673. * catalog.c:
  674. Remove some redundant locking and error checks
  675. that had been previously marked as questionable.
  676. Sat Aug 17 08:06:56 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  677. * binsert.c, bfind.c, bins_del.c, balloc.c, bdelete.c:
  678. Edited some comments for correctness.
  679. * README.sgml, version.c:
  680. Bump version up to "pre-0.7-4" in preparation for snapshot release.
  681. * Makefile:
  682. Have 'make dep' delete the *.o and *.s files.
  683. * catalog.c, hfs.h, TODO, bfind.c:
  684. Move looping from hfs_cat_next() into hfs_bsucc(),
  685. where it can be done an entire node at a time.
  686. Fri Aug 16 05:02:59 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  687. * TODO:
  688. Add AppleShare support to the list of goals.
  689. * trans.c, super.c, hfs_fs.h, README.sgml:
  690. Add a "names=netatalk" mount option, since
  691. Netatalk quotes initial periods and CAP doesn't.
  692. * Makefile:
  693. Oops! Had removed the 'include .depend' from Makefile.
  694. * inode.c, hfs_fs.h, file_nat.c, file_dbl.c, file.c, dir_nat.c,
  695.   dir_dbl.c, dir_cap.c, dir.c, README.sgml:
  696. Update for 2.0.1 and newer kernels.
  697. * Makefile:
  698. Get rid of ifeq stuff and use a .tmpdepend file to make sure
  699. a failed 'make depend' doesn't allow a 'make hfs.o'.
  700. Wed Aug 14 01:03:01 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  701. * version.c, README.sgml:
  702. Bump version up to "pre-0.7-3" in preparation for snapshot release.
  703. * btree.c, extent.c, bnode.c:
  704. Fix up some debugging code.
  705. Tue Aug 13 12:42:12 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  706. * version.c, README.sgml:
  707. Bump revision to "pre-0.7-2".
  708. * super.c, sysdep.c, mdb.c, file_nat.c, inode.c, file_cap.c,
  709.   file_dbl.c, file.c, extent.c, dir.c, catalog.c, btree.c, bnode.c,
  710.   balloc.c:
  711. Added the remaining missing function comments.
  712. * Makefile, README.sgml:
  713. Simplify the default make rule to build the dependency file AND hfs.o.
  714. Change the installation instructions to reflect the change.
  715. * hfs.h:
  716. Added missing structure comments.
  717. * bdelete.c:
  718. Merge bdelete_brec() back into hfs_bdelete().
  719. Add missing function comments.
  720. * extent.c:
  721. Insignificant code change removing an unneeded indirection.
  722. * btree.c, hfs_btree.h, balloc.c, bnode.c:
  723. Add a 'sys_mdb' field to (struct hfs_btree).
  724. * extent.c, hfs_sysdep.h, sysdep.c, bnode.c, balloc.c, bfind.c,
  725.   Makefile:
  726. Move hfs_buffer_read() from hfs_sysdep.h to sysdep.c so it can use
  727. the symbol HFS_SECTOR_SIZE rather than the manifest constant 512.
  728. Have hfs_buffer_read() print an error message,
  729. and remove redundant errors from the callers.
  730. * hfs_sysdep.h, mdb.c, super.c, file.c, hfs.h, hfs_btree.h, catalog.c,
  731.   extent.c, btree.c, balloc.c, bfind.c, bnode.c:
  732. Get rid of the type hfs_device and the fields of that type,
  733. using the type hfs_sysmdb and the 'sys_mdb' field in its place.
  734. * Makefile:
  735. Fix definition of HDRS variable.
  736. * README.sgml, version.c:
  737. Bump version up to "pre-0.7-1".
  738. * Makefile:
  739. Separate sources and headers into three groups:
  740. B-tree code, HFS code and Linux code.
  741. * bitmap.c, bitops.c, hfs.h, hfs_sysdep.h, balloc.c:
  742. Implemented portable set of bit operations in hfs_sysdep.h
  743. * mdb.c, hfs_sysdep.h, hfs_btree.h, extent.c, btree.c, bitmap.c,
  744.   bnode.c, balloc.c:
  745. Implement a portable set of buffer operations in hfs_sysdep.h
  746. * TODO:
  747. Remove note about separating header files into two parts.
  748. * catalog.c:
  749. Remove call to hfs_mdb_dirty(), since the hfs_brec_relse() does it.
  750. * hfs.h, extent.c, file.c:
  751. Move hfs_getblk() from extent.c to file.c, since that is now the
  752. only file that actually uses it.
  753. * balloc.c:
  754. Replace use of hfs_getblk() in balloc.c with a local function
  755. (get_new_node()) that doesn't retry, since B-trees can't shrink.
  756. * hfs.h, hfs_btree.h, hfs_sysdep.h, mdb.c, extent.c:
  757. Make hfs_buffer a typedef.
  758. * inode.c, hfs.h, hfs_sysdep.h, dir.c:
  759. Change hfs_sysentry to a typedef.
  760. Rename 'sysentry' field of (struct hfs_cat_entry) to 'sys_entry'.
  761. * super.c, mdb.c, catalog.c:
  762. Rename hfs_cat_sync() to hfs_cat_commit() and call it
  763. from hfs_mdb_commit() rather than from hfs_write_super().
  764. * catalog.c, file.c:
  765. Minimize the calls to hfs_mdb_dirty().   Now called when:
  766. 1) A buffer holding a volume bitmap block is dirtied.
  767. 2) A dirty B-tree node is written back to the buffers.
  768. 3) A dirty catalog entry is written back to the buffers.
  769. * hfs_sysdep.h, hfs.h:
  770. Make hfs_sysmdb a typedef.
  771. Sun Aug 11 08:46:10 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  772. * hfs_sysdep.h, extent.c, hfs.h:
  773. Replace hfs_mdb_{lock,unlock} with more portable
  774. scheme using a wait queue in the MDB.
  775. * hfs.h, hfs_btree.h, hfs_sysdep.h, bnode.c, catalog.c, binsert.c:
  776. Make hfs_wait_queue a typedef'd pointer to a (struct wait_queue).
  777. Rename hfs_wait_on() to hfs_sleep_on().
  778. * catalog.c, hfs_sysdep.h, super.c, bfind.c, bnode.c, balloc.c:
  779. Implemented hfs_dev_name() in hfs_sysdep.h
  780. as a portable call to produce a device name.
  781. * super.c, hfs.h, mdb.c:
  782. Rename hfs_mdb_read() to hfs_mdb_get(), and don't take a
  783. 'sys_mdb' argument.  That's the callers responsibility.
  784. * sysdep.c, Makefile:
  785. Remove the pointless file sysdep.c
  786. * README.sgml:
  787. Clean up the "System Requirements" section.
  788. Sat Aug 10 22:41:24 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  789. * sysdep.h, sysdep.c, super.c, hfs_sysdep.h, mdb.c, string.c,
  790.   hfs_fs.h, hfs_fs_i.h, hfs_fs_sb.h, hfs_btree_private.h, hfs_btree.h,
  791.   file_cap.c, file_dbl.c, file_nat.c, hfs.h, file.c, dir_nat.c,
  792.   extent.c, dir.c, dir_cap.c, dir_dbl.c, catalog.c, bnode.c, brec.c,
  793.   btree.c, binsert.c, bitmap.c, bitops.c, bfind.c, bins_del.c,
  794.   Makefile, balloc.c, bdelete.c:
  795. Includes the hfs.h that was missing from the previous check in.
  796. MAJOR include-file cleanup:
  797. hfs_btree.h merged into hfs.h
  798. hfs_btree_private.h renamed hfs_btree.h
  799. sysdep.h renamed hfs_sysdep.h
  800. Fixed some minor portability fixes shown up by the header split.
  801. * README.sgml:
  802. Add instructions for a dealing with a missing linux/version.h
  803. * hfs_fs.h, mdb.c, string.c, catalog.c, extent.c, btree.c, bitmap.c,
  804.   bitops.c, bnode.c, brec.c, bins_del.c, binsert.c, bdelete.c, bfind.c,
  805.   balloc.c:
  806. Major split of hfs_fs.h into Linux-specific
  807. part (hfs_fs.h) and HFS-specific part (hfs.h).
  808. * file.c, extent.c:
  809. Move hfs_getblk() from file.c to extent.c
  810. * sysdep.h, super.c, mdb.c, hfs_fs_sb.h, hfs_fs.h, file.c, extent.c,
  811.   catalog.c, bnode.c, bitmap.c:
  812. Make the field 's_mdb' in (struct hfs_sb_info) a pointer to
  813. the MDB, rather than the actual MDB.  This allowed the definition
  814. of (struct hfs_mdb) to be moved from hfs_fs_sb.h to hfs_fs.h.
  815. * ccache.c, hfs_fs.h, Makefile, catalog.c:
  816. Merged ccache.c and catalog.c into the latter.
  817. Moved definition of (struct hfs_cat_rec) into catalog.c
  818. * extent.c:
  819. Oops!  Last set of changes didn't compile but they're OK now.
  820. * hfs_btree.h, hfs_fs.h, mdb.c, ccache.c, extent.c, btree.c:
  821. Move the definition of (struct hfs_raw_extent) inside
  822. extent.c and treat it as simple array of U16's elsewhere.
  823. * hfs_fs.h, dir_dbl.c, dir_nat.c, ccache.c, catalog.c, dir_cap.c:
  824. Make hfs_cat_next() return the CNID and cdrType of the entry.
  825. Now catalog.c and ccache.c are the only files which
  826. depend on the structure of a catalog record on disk.
  827. * dir.c, hfs_fs.h, catalog.c:
  828. Replace hfs_cat_new_{file,dir}() with hfs_cat_{create,mkdir}()
  829. which are wrappers for what used to be hfs_cat_create().
  830. * hfs_fs.h, mdb.c, super.c, Makefile:
  831. Split super.c into super.c (Linux stuff) and mdb.c (MDB stuff).
  832. * super.c, hfs_fs_sb.h:
  833. Add the MDB field 'drAtrb' to (struct hfs_mdb) as the field 'attrib'.
  834. * hfs_fs_sb.h, super.c:
  835. Split hfs_read_super() into hfs_read_super() and hfs_mdb_read().
  836. * super.c, hfs_fs_sb.h:
  837. Remove the unneeded 'hs' field from (struct hfs_mdb).
  838. * TODO:
  839. Remove item about hfs_notify_change() needing to update metadata.
  840. * inode.c, hfs_fs.h, hfs_fs_sb.h, file_cap.c, file_dbl.c, file_nat.c,
  841.   file.c, dir.c:
  842. Add a flags argument to hfs_{cap,dbl,nat}_buildmeta() so that
  843. it only builds the parts that are currently out-of-date.
  844. Call hfs_{cap,dbl,nat}_buildmeta() through hfs_update_meta()
  845. in hfs_notify_change() and hfs_rename() to update the metadata.
  846. * dir.c:
  847. Make test for normal dir in update_dirs_{plus,minus}() more explicit.
  848. * inode.c, file_cap.c, file_dbl.c, file_nat.c, dir_dbl.c, dir_nat.c,
  849.   file.c, README.sgml, dir_cap.c:
  850. Resolve the "meta-data" vs. "metadata" rivalry in favor of the latter.
  851. * btree.c:
  852. Simplify some debugging code.
  853. * hfs_btree_private.h, bnode.c, btree.c, balloc.c:
  854. Put the in-core copy of the header node IN the
  855. B-tree structure rather than just a pointer to it.
  856. * hfs_btree_private.h, btree.c, bnode.c:
  857. Have hfs_btree_commit() call hfs_bnode_commit()
  858. to commit the header and root nodes.
  859. * hfs_fs.h, super.c, hfs_btree_private.h, btree.c, hfs_btree.h,
  860.   balloc.c:
  861. Change hfs_commit_mdb() to hfs_mdb_commit().
  862. Make hfs_mdb_commit() call hfs_btree_commit().
  863. Move code to update B-tree size and extent
  864. from hfs_btree_extend() to hfs_btree_commit().
  865. Make hfs_btree_extend() call hfs_mdb_commit().
  866. * super.c:
  867. Change hfs_commit_super() to hfs_commit_mdb().
  868. * btree.c, bnode.c, bfind.c:
  869. Fixed up broken debugging code and error messages.
  870. * super.c, hfs_btree_private.h, btree.c, hfs_btree.h, bdelete.c,
  871.   binsert.c, balloc.c:
  872. Now use write-back caching of B-tree header fields.
  873. * hfs_fs.h:
  874. Get rid of the add{16,32}() inlines as they are no longer used.
  875. * hfs_btree_private.h, binsert.c, btree.c, bdelete.c, bfind.c, balloc.c:
  876. All the needed fields of the B-tree header are
  877. now cached for reading, but not yet writing.
  878. * TODO:
  879. Remove "Implement write count" from TODO list.
  880. * file.c, super.c, bnode.c:
  881. Implement write count.
  882. * catalog.c:
  883. Fix directory entry counting in hfs_cat_move().
  884. * balloc.c:
  885. Simplify hfs_btree_extend(), since the allocation
  886. request will get rounded up to the clumpsize.
  887. * extent.c:
  888. Honor clumpsize when allocating blocks to files.
  889. * file_cap.c, file_dbl.c, file_nat.c, super.c, dir.c, file.c,
  890.   ccache.c, catalog.c, balloc.c:
  891. Mark 44 functions in need of commenting.
  892. * hfs_fs_sb.h, super.c, extent.c, hfs_fs.h, ccache.c, btree.c, balloc.c:
  893. Record clumpsize in allocation blocks rather than 512-byte blocks.
  894. * sysdep.h, super.c, TODO, balloc.c, hfs_fs_sb.h:
  895. Now updates the backup MDB when a B-tree grows.
  896. * extent.c:
  897. hfs_extent_free() had test against NULL backward.
  898. The result is that access to a file with extents in the extents
  899. B-tree would result in an infinite loop in hfs_cat_put().
  900. * hfs_fs_sb.h, super.c, hfs_fs.h:
  901. Reorganize partition map code to get size of partition
  902. in preparation for dealing with the alternate MDB.
  903. Fri Aug  9 03:25:13 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  904. * Makefile:
  905. Add make rules for README.{ps,info}
  906. * README, README.sgml, DOC, FAQ, Makefile, .cvsignore, 
  907. Merge CHANGES into ChangeLog.
  908. Merge DOC, FAQ and README into README.sgml.
  909. Add make rules for building README.{txt,dvi}
  910. * BUG_INFO, Makefile:
  911. Added a BUG_INFO script which attempts to collect some useful
  912. information which I'd like to see in every bug report I receive.
  913. * Makefile, version.c:
  914. Added version.c which contains a version string.
  915. Thu Aug  8 21:48:24 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  916. * trans.c:
  917. Fix Latin-1 -> Macintosh filename mapping to change colons to pipes.
  918. * trans.c:
  919. Fixed Mac->Latin-1 translation to behave as documented for the
  920. extended 8-bit characters without corresponding Latin-1 characters.
  921. * inode.c, super.c, file.c, hfs_fs_i.h, hfs_fs_sb.h, DOC:
  922. Added a conv={binary,text,auto} mount option similar to that of the
  923. msdos, hpfs and iso9660 filesystems, but applying only to data forks.
  924. As compared to those filesystems, HFS has the advantage that only a
  925. single CR need be converted to a NL, rather than a CR/NL sequence, so
  926. it is quite safe to seek in the file.
  927. Additionally the 'Type' field is far more reliable indicator of text
  928. files than a file extension.
  929. * super.c:
  930. Simplified parsing of mount options.
  931. * super.c:
  932. Oops!  The part=<n> mount option was being parsed in octal!
  933. * TODO:
  934. Remove "case=lower" from the list of goals.
  935. * super.c, hfs_fs.h, hfs_fs_sb.h, string.c, dir_dbl.c, dir_nat.c,
  936.   dir_cap.c, DOC:
  937. Resurrect the case={asis,lower} mount option.
  938. * dir.c:
  939. Simpler test for "normal" directory in update_dirs_{plus,minus}().
  940. * hfs_fs_sb.h, super.c, dir.c, hfs_fs.h, catalog.c, DOC:
  941. Add mount options to specify what Type and Creator will be used for
  942. new files and change the default from NULLs to "????".
  943. Wed Aug  7 11:32:22 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  944. * catalog.c:
  945. In hfs_cat_next() use entry->cnid rather than the key of the initial
  946. brec to identify the end of the directory.
  947. * README:
  948. Update for pre-0.7 version.
  949. * hfs_fs.h:
  950. Create versioned module if CONFIG_MODVERSIONS is set in linux/config.h
  951. * TODO:
  952. Note need for special steps for unaligned accesses on some machines.
  953. * FAQ:
  954. Added Q0: What is HFS?
  955. Added Q7: Does hfs_fs work w/ 400k and 800k diskettes?
  956. Brought Q6 (about writability) up to date.
  957. Made a few other answers more verbose.
  958. Tue Aug  6 00:58:46 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  959. * Makefile:
  960. Changed 'snapshot' rule to include cvs tag command.
  961. * hfs_fs.h, dir_cap.c, dir_dbl.c, dir_nat.c, catalog.c, ccache.c:
  962. Implemented readers half of dir locking scheme so readdir() should
  963. produce consistent results and count_dir_entries() is not race prone.
  964. * catalog.c:
  965. hfs_cat_move() was calling hfs_cat_decache() after changing
  966. the key rather than before, corrupting the hash lists.
  967. Mon Aug  5 14:03:46 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  968. * hfs_fs.h, catalog.c:
  969. Implemented the writers half of a locking scheme for directories.
  970. * inode.c:
  971. Fixed a serious bug in hfs_notify_change() that would allow a chmod()
  972. on directory meta-data and would cause the directory inode (if it was
  973. in memory at the time) to change into a file inode.
  974. * inode.c:
  975. Fixed a problem with write permissions on directory meta-data.
  976. * dir_dbl.c, dir_nat.c, dir_cap.c:
  977. hfs_{cap,dbl,nat}_readdir() now return the correct value in the 'd_ino'
  978. field of the dirent for all cases, something I think has always been
  979. done incorrectly until now.
  980. * dir_nat.c, inode.c, dir_cap.c:
  981. In hfs_{cap,nat}_lookup() take advantage of the
  982. 'file_type' field of (struct hfs_inode_info).
  983. * TODO:
  984. Removed two accomplished goals (rename() and improved readdir()).
  985. * inode.c, dir_dbl.c, dir_nat.c, hfs_fs_i.h, dir.c, dir_cap.c:
  986. Rewrite hfs_{cap,dbl,nat}_readdir() to take advantage of hfs_cat_next().
  987. They now use a uniform 'i_size' for all inodes for a given directory.
  988. This simplifies update_dirs_{plus,minus}() and eliminates the need for
  989. the 'file_size' and 'dir_link' fields of (struct hfs_inode_info).
  990. For the CAP and Netatalk schemes the meta-data directories are now the
  991. last entries rather than coming just after '.' and '..'.  This is in
  992. preparation for the day when we can write to the files in those
  993. directories, and ensures that when using 'tar' to copy HFS filesystems
  994. the file or directory will be created before the meta-data is written.
  995. Otherwise we could be stuck writing meta-data and not knowing if it is
  996. for a file or a directory!
  997. * ccache.c:
  998. Updated count_dir_entries() for new hfs_cat_next().
  999. * hfs_fs.h, catalog.c:
  1000. hfs_cat{nth,next}() no longer take a 'types' argument,
  1001. so they now return all entries.
  1002. hfs_cat_next() now uses the ParID of the key to detect
  1003. the end of the directory.
  1004. hfs_cat_nth() now accepts n=0 as a valid input, requesting the thread.
  1005. * trans.c, string.c, super.c, dir_nat.c, hfs_fs.h, dir.c, dir_cap.c,
  1006.   dir_dbl.c, catalog.c:
  1007. Rename (struct hfs_cname) to the more appropriate (struct hfs_pstr).
  1008. * hfs_fs.h, hfs_btree.h:
  1009. Move some constants from hfs_fs.h to hfs_btree.h
  1010. * bdelete.c, hfs_btree.h:
  1011. Remove hfs_bdelete_brec() from public B-tree interface.
  1012. * hfs_btree_private.h, hfs_fs.h, btree.c, hfs_btree.h, bnode.c, brec.c,
  1013.   bfind.c, bins_del.c, binsert.c, balloc.c, bdelete.c, Makefile:
  1014. Split B-tree stuff into public and private parts:
  1015. brec.c split into bfind.c and brec.c
  1016. hfs_btree.h split into hfs_btree.h and hfs_btree_private.c
  1017. * inode.c:
  1018. The tests and sets of the HFS_FIL_LOCK bit where all reversed!
  1019. * hfs_fs.h, ccache.c:
  1020. Redo some ccache stuff, removing the 'error' field from
  1021. (struct hfs_cat_entry) and ensuring that hfs_cat_put()
  1022. will not sleep on an uninitialized entry.
  1023. Sun Aug  4 23:43:28 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1024. * sysdep.h:
  1025. Change swap{16,32}() back to macros since hton[ls]() are functions.
  1026. * hfs_fs.h, ccache.c:
  1027. Use only lowest order byte of parent CNID in hashing a catalog key.
  1028. * bdelete.c:
  1029. The "improved" bdelete() was TOO paranoid looking for missing parents.
  1030. * ccache.c:
  1031. Get rid of pointless swap16const(0).
  1032. * hfs_fs.h, inode.c, extent.c, ccache.c, dir_cap.c, dir_nat.c,
  1033.   binsert.c, catalog.c:
  1034. Store cnid and associated constants in big-endian byte order.
  1035. This reduces the number of byte-order swaps required.
  1036. * sysdep.h:
  1037. Make swap32() and swap16() inline functions.
  1038. * dir_nat.c, dir_cap.c, dir_dbl.c:
  1039. Added hfs_rename() to the inode_operations for normal directories.
  1040. * dir.c, hfs_fs.h:
  1041. Added hfs_rename() and cleaned up hfs_{create,mkdir,unlink,rmdir}().
  1042. * catalog.c:
  1043. Added the missing check for moving a directory into itself.
  1044. * catalog.c, ccache.c, hfs_fs.h:
  1045. Implement a nearly ideal hfs_cat_move().
  1046. It still needs to prevent moving a directory into itself.
  1047. The functions hfs_cat_{create,delete,move}() still need work with
  1048. respect to their atomicity (especially vs. readdir).
  1049. * bdelete.c:
  1050. Fixed a serious bug in hfs_bdelete_brec() that would yield a corrupted
  1051. b-tree when the first record in a bnode was deleted.
  1052. Made bdelete() more aggressive when checking for missing parents.
  1053. Sat Aug  3 06:11:50 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1054. * btree.c, super.c:
  1055. Fixed a problem that caused a kernel oops when no HFS filesystem
  1056. is found.
  1057. Wed Jul 24 13:06:12 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1058. * catalog.c:
  1059. Remove race in hfs_cat_create() that could overflow directory valence.
  1060. * catalog.c:
  1061. Fix hfs_cat_create() so the parent directory doesn't get deleted
  1062. out from under it.  Otherwise we could have created files and
  1063. directories in deleted directories.
  1064. * hfs_fs.h, dir_cap.c, dir_dbl.c, dir_nat.c, catalog.c, ccache.c:
  1065. Redo hfs_cat_{next,nth}() in terms of which entry types to
  1066. allow, rather than which to skip.
  1067. * catalog.c:
  1068. The function hfs_cat_create() would fail to hfs_cat_put(entry) if
  1069. the 'record' argument was invalid or if the 'result' argument was NULL.
  1070. * dir.c:
  1071. The functions hfs_{create,mkdir,unlink,rmdir} all failed to
  1072. call iput() when their arguments conflicted with a reserved name.
  1073. * catalog.c, hfs_fs_sb.h:
  1074. Start over on rename().  Still unfinished.
  1075. Fix silly bug in hfs_cat_create() that made it always fail.
  1076. * ccache.c:
  1077. Fix byte-order bug in write_entry().
  1078. Tue Jul 23 12:12:58 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1079. * dir_dbl.c, dir_nat.c, hfs_fs.h, dir.c, dir_cap.c:
  1080. Remove the macros KEY() and PARENT() since the key is now easy
  1081. to access through the catalog entry.
  1082. Replace the macros NAME{IN,OUT}() with inline functions
  1083. hfs_name{in,out}() to gain type checking of arguments.
  1084. * catalog.c:
  1085. Remove the macro TYPE().
  1086. * inode.c, file_dbl.c, file_nat.c, file.c, file_cap.c:
  1087. Remove the #define's of the unused macro KEY().
  1088. * hfs_fs.h, dir_cap.c, dir_dbl.c, dir_nat.c, catalog.c, dir.c:
  1089. Replace hfs_lookup_parent() in dir.c with hfs_cat_parent() in catalog.c.
  1090. This new function performs locking to protect against rename() changing
  1091. the parent during I/O.
  1092. It is also intended for use with files as well as directories.
  1093. Change hfs_{cap,dbl,nat}_lookup() to use the new function.
  1094. * dir.c, hfs_fs.h, catalog.c:
  1095. Remerge hfs_cat_{create,mkdir}() into hfs_cat_create() and resurrect
  1096. hfs_cat_new_{file,dir}().
  1097. Fix hfs_cat_{create,delete} to use the improved catalog cache for
  1098. locking in place of directory-level create/delete locks.
  1099. Fix hfs_{create,mkdir}() to use the new hfs_cat_create().
  1100. * hfs_fs.h, ccache.c:
  1101. Rewrite parts to remove need for specialized create/delete locking.
  1102. Use new case-independent hash function.
  1103. Fix bug in hfs_cat_get() that would read an entry w/o locking it.
  1104. Call hfs_relinquish() before retrying a deleted entry in hfs_cat_get.
  1105. If there is a read error, then don't retry in hfs_cat_get().
  1106. Remove unused 'version' field from (struct hfs_cat_entry).
  1107. * sysdep.h:
  1108. Add hfs_relinquish(), a system-independent alias for schedule().
  1109. * hfs_fs.h, string.c:
  1110. Add hfs_strhash(), a simplistic case-independent hash function.
  1111. * hfs_fs.h, inode.c:
  1112. Make hfs_iget() an inline function.
  1113. * TODO:
  1114. Add a few goals and removed those that have been achieved.
  1115. * Makefile:
  1116. Add ccache.c to list of source files.
  1117. Add rule for *.s files and include them in the 'clean' rule.
  1118. Wed Jul 17 17:22:45 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1119. * sysdep.h, trans.c, string.c, super.c, hfs_fs_i.h, hfs_fs_sb.h,
  1120.   inode.c, hfs_btree.h, hfs_fs.h, file_dbl.c, file_nat.c, extent.c,
  1121.   file.c, file_cap.c, dir_dbl.c, dir_nat.c, ccache.c, dir.c,
  1122.   dir_cap.c, btree.c, catalog.c, bnode.c, brec.c, balloc.c:
  1123. Total rewrite of the inode-handling stuff to be centered around
  1124. a catalog entry cache (ccache.c).  This results not only in a far
  1125. more sensible way of doing things, but also removed many race
  1126. conditions. (The source and object code both got smaller too!)
  1127. Many small "undocumented features" were also fixed.
  1128. Replace HFS_CNAME with (struct hfs_cname).
  1129. rename() has been temporarily abandoned.
  1130. Thu Jul 11 01:14:38 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1131. * dir.c:
  1132. As written hfs_lookup_parent() had two overlapping read requests
  1133. in the catalog tree.  This could have led to deadlock.
  1134. Wed Jul 10 09:27:00 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1135. * catalog.c, hfs_fs.h, bdelete.c:
  1136. More work on getting rename() fleshed out.  Still not done.
  1137. Before I can finish it looks like I'll need to build a
  1138. mechanism for exclusive access to the catalog tree.  There
  1139. just doesn't seem to be any other way to get proper POSIX
  1140. semantics without a bunch of race conditions elsewhere.
  1141. * hfs_fs.h, inode.c, dir_cap.c, dir_dbl.c, dir_nat.c, catalog.c:
  1142. More work on the still incomplete rename() code.
  1143. Merge hfs_cat_add_{dir,file}() into hfs_cat_create().
  1144. Add file-thread support to hfs_cat_{create,delete,rename}.
  1145. Tue Jul  9 09:43:15 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1146. * inode.c, dir_dbl.c, dir_nat.c, extent.c, dir_cap.c:
  1147. The indirect (struct hfs_file) was causing blocks not to be freed
  1148. when files where deleted, and an omission in hfs_put_inode() was
  1149. preventing the inode from getting freed.  Both are now fixed.
  1150. * hfs_fs.h, dir_dbl.c, dir_nat.c, hfs_btree.h, catalog.c, dir_cap.c,
  1151.   bdelete.c:
  1152. Made unlink() and rmdir() more race resistant and did some more
  1153. work on the still incomplete code for rename().
  1154. * btree.c, bnode.c:
  1155. There was a serious race condition in the bnode cache, so
  1156. hfs_bnode_find() is now modeled after Linus's inode cache.
  1157. Mon Jul  8 10:33:38 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1158. * hfs_fs_i.h, inode.c, file_cap.c, file_dbl.c, file_nat.c, dir_dbl.c,
  1159.   dir_nat.c, file.c, dir.c, dir_cap.c:
  1160. More changes to layout of (struct hfs_inode_info).
  1161. * super.c, inode_cap.c, inode_dbl.c, inode_nat.c, inode.c, hfs_fs_i.h,
  1162.   hfs_fs_sb.h, file_nat.c, hfs_fs.h, file.c, file_cap.c, file_dbl.c,
  1163.   Makefile, catalog.c:
  1164. Implemented new layout for (struct hfs_inode_info) resulting in the
  1165. elimination of lots of duplicated code for hfs_*_write_inode(),
  1166. hfs_*_put_inode() and *_open() functions.
  1167. Merged inode_*.c files back into inode.c.
  1168. Not fully tested.
  1169. * TODO:
  1170. Add a few more of my goals to the list.
  1171. * README:
  1172. Documentation updates.
  1173. * inode_nat.c, inode_cap.c, inode_dbl.c, inode.c, hfs_fs.h, hfs_fs_i.h,
  1174.   file.c, file_cap.c, file_dbl.c, file_nat.c, catalog.c:
  1175. (struct hfs_file) and metadata are read when file is opened or
  1176. truncated and are released by iput().
  1177. Sun Jul  7 23:55:43 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1178. * inode_nat.c, inode_cap.c, inode_dbl.c, inode.c, dir_nat.c, hfs_fs.h,
  1179.   hfs_fs_i.h, dir_cap.c, dir_dbl.c, catalog.c, dir.c:
  1180. (struct hfs_dir) is now inside (struct hfs_inode_info) once again.
  1181. * inode_nat.c, super.c, inode_cap.c, inode_dbl.c, inode.c, file_nat.c,
  1182.   hfs_btree.h, hfs_fs.h, extent.c, file_cap.c, file_dbl.c, dir_nat.c,
  1183.   dir_cap.c, dir_dbl.c, btree.c, catalog.c, dir.c, bpath.c, brec.c,
  1184.   bins_del.c, binsert.c, bnode.c, bfind.c, balloc.c, bdelete.c,
  1185.   Makefile:
  1186. Remerged (struct hfs_bpath) and (struct hfs_brec), merging the
  1187. files bfind.c and bpath.c as a resurrected brec.c.
  1188. Sat Jul  6 21:47:05 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1189. * inode_cap.c, inode_dbl.c, inode_nat.c, inode.c, hfs_fs.h, hfs_fs_i.h,
  1190.   file_cap.c, file_dbl.c, file_nat.c, hfs_btree.h, dir_nat.c, extent.c,
  1191.   dir.c, dir_cap.c, dir_dbl.c, btree.c, catalog.c, bfind.c, bpath.c,
  1192.   binsert.c, bdelete.c:
  1193. Renamed (struct hfs_brec_key) to (struct hfs_bkey).
  1194. Tue May 28 07:53:24 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1195. * inode_cap.c, catalog.c:
  1196. Spelling fixes.
  1197. * inode_nat.c, super.c, inode_cap.c, inode_dbl.c, inode.c, hfs_fs.h,
  1198.   hfs_fs_i.h, hfs_fs_sb.h, file.c, file_dbl.c, file_nat.c, dir_dbl.c,
  1199.   dir_nat.c, extent.c, dir.c, dir_cap.c, catalog.c:
  1200. Structures got too big, so I had to add a layer of indirection
  1201. to (struct hfs_inode_info).
  1202. This means we must clear_inode() in inode_put().
  1203. Mon May 27 01:32:42 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1204. * catalog.c, file_cap.c:
  1205. Some sizeof() stuff now uses variable not type.
  1206. * hfs_fs.h:
  1207. Make HFS_I() and HFS_SB() inline to gain type checking.
  1208. Sun May 26 13:34:17 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1209. * dir_nat.c:
  1210. Oops.  Had left some debugging printk()s in place.
  1211. * file_dbl.c, file_nat.c, file_cap.c:
  1212. Cleaned up variable names for consistency.
  1213. * hfs_fs_sb.h:
  1214. Add a couple 'const's to function typedefs.
  1215. * hfs_fs.h:
  1216. Add and update function prototypes.
  1217. Cleaned up type names.
  1218. Fix debugging malloc code.
  1219. Add hfs_iget_by_name() as an inline function.
  1220. * sysdep.h:
  1221. Remove extra semicolon from macro definitions.
  1222. * super.c:
  1223. Use new hfs_iget_by_name() to get root inode.
  1224. * extent.c:
  1225. Cleaned up some variable naming for consistency.
  1226. * catalog.c:
  1227. Added (untested) code for hfs_cat_move_file().
  1228. * catalog.c:
  1229. Fix one missed call to hfs_cat_build_key().
  1230. Make hfs_cat_add_{file,dir}() take a cat_entry as an argument.
  1231. Add hfs_cat_new_{file,dir}() to generate new cat_entry's.
  1232. * dir_dbl.c, dir_nat.c, dir.c, dir_cap.c:
  1233. Cleaned up type and variable names.
  1234. Updated calls to hfs_cat_build_key() and NAMEOUT()
  1235. Use new hfs_iget_by_*() calls.
  1236. * inode_cap.c, inode_dbl.c, inode_nat.c:
  1237. Cleaned up type and variable names.
  1238. * inode.c:
  1239. Update calls to hfs_cat_build_key().
  1240. Cleaned up type and variable names.
  1241. Implemented a hierarchy of hfs_iget_by*() calls.
  1242. * catalog.c:
  1243. Change hfs_cat_build_key() to take a HFS_CNAME as input.
  1244. * btree.c:
  1245. Initialize lsize and psize fields of file.
  1246. * trans.c:
  1247. Now passes type HFS_CNAME and has name/len in "normal" order.
  1248. Tue May 21 07:02:34 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1249. * bnode.c:
  1250. Attempt to read invalid bnode would have led to an infinite loop under
  1251. certain circumstances.  One way to cause this was with an invalid
  1252. partition table which points beyond the end of the device.
  1253. Sat May 11 12:38:42 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1254. * sysdep.h, sysdep.c, inode_dbl.c, inode_nat.c, super.c, inode_cap.c,
  1255.   inode.c, hfs_fs.h, hfs_fs_i.h, hfs_fs_sb.h, file_dbl.c, file_nat.c,
  1256.   hfs_btree.h, extent.c, file.c, file_cap.c, dir_nat.c, dir.c,
  1257.   dir_cap.c, dir_dbl.c, btree.c, catalog.c, bitmap.c, bitops.c,
  1258.   bnode.c, bfind.c, bins_del.c, binsert.c, balloc.c, bdelete.c:
  1259. Another big wave of portability-oriented changes.
  1260. Tue May  7 11:28:35 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1261. * super.c, sysdep.c, sysdep.h, inode_cap.c, inode_dbl.c, inode_nat.c,
  1262.   hfs_fs_i.h, inode.c, file_nat.c, hfs_btree.h, hfs_fs.h, file.c,
  1263.   file_cap.c, file_dbl.c, dir_nat.c, extent.c, dir_cap.c, dir_dbl.c,
  1264.   btree.c, catalog.c, dir.c, bnode.c, bpath.c, binsert.c, bitmap.c,
  1265.   bitops.c, bdelete.c, bfind.c, bins_del.c, Makefile, balloc.c:
  1266. Start a big move to abstract all the Linux-specific stuff
  1267. out of the lower levels.  Created sysdep.[ch] to hold it.
  1268. * FAQ, TODO:
  1269. Bring some documentation up-to-date.
  1270. Fri May  3 20:15:29 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1271. * super.c, inode_dbl.c, inode_nat.c, inode.c, inode_cap.c, extent.c,
  1272.   hfs_fs.h, hfs_fs_i.h, dir_dbl.c, dir_nat.c, catalog.c, dir.c,
  1273.   dir_cap.c, bpath.c, btree.c, binsert.c, bnode.c:
  1274. "FID reform": 'fid' became 'cnid' (Catalog Node ID), and is now
  1275. a field in (struct hfs_file).  The new name is more consistent
  1276. with Apple's documentation.  The presence of 'cnid' in (struct
  1277. hfs_file) help move more of the code toward OS-independence.
  1278. * inode_nat.c, super.c, trans.c, inode.c, inode_cap.c, inode_dbl.c,
  1279.   hfs_fs.h, file_cap.c, file_dbl.c, file_nat.c, dir_nat.c, extent.c,
  1280.   file.c, dir.c, dir_cap.c, dir_dbl.c, btree.c, catalog.c, bnode.c,
  1281.   bpath.c, bins_del.c, binsert.c, bitmap.c, bitops.c, bdelete.c,
  1282.   bfind.c, balloc.c:
  1283. A lot of changes in what headers are included and in what order.
  1284. Sat Apr 27 12:28:54 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1285. * FAQ:
  1286. Updated for current writability status.
  1287. * .cvsignore:
  1288. Added ChangeLog.
  1289. * file_dbl.c, file_nat.c, file_cap.c, file.c, dir_dbl.c, dir_nat.c,
  1290.   dir_cap.c:
  1291. Added the default fsync() to all file_operations structures.
  1292. * dir_nat.c, hfs_fs.h, dir.c, dir_cap.c, dir_dbl.c:
  1293. Add rmdir() for normal directories.
  1294. * binsert.c:
  1295. I had messed up insertion so that is would sometime fail to
  1296. split the root, but its OK now.
  1297. * dir.c:
  1298. hfs_do_unlink() decremented directory counts rather than file counts.
  1299. Wed Apr 24 13:20:08 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1300. * hfs_fs.h, bnode.c, hfs_btree.h:
  1301. Fixed a couple more type size assumptions.
  1302. * hfs_fs.h, balloc.c, bitmap.c, bitops.c:
  1303. "Portable" bitmap handling was wrong for just about everything but
  1304. the i386 and the "inverse big-endian" bit ordering that I thought
  1305. the m68k port was using.  It seems the m68k port is now using standard
  1306. big-endian bit-numbering conventions.
  1307. This code is now correct for the standard big- and little-endian bit
  1308. orderings. (which should cover all Linux systems?)
  1309. Also no longer assumes sizeof(long) == 4, though that might still be
  1310. a problem in other parts of the code.
  1311. Tue Apr 23 19:19:27 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1312. * FAQ:
  1313. Bring uptodate for this snapshot.
  1314. * Makefile:
  1315. Add FAQ to $(MISC)
  1316. * README, TODO:
  1317. Documentation updates.
  1318. * bdelete.c:
  1319. Spelling fixes.
  1320. * dir_cap.c:
  1321. In unlink() don't force metadata into memory if not present.
  1322. * bdelete.c:
  1323. Some function comments and some clean up.
  1324. * bins_del.c:
  1325. Added missing function comment for hfs_bnode_update_key().
  1326. * binsert.c, bitmap.c:
  1327. Spelling and grammar corrections to comments.
  1328. * hfs_btree.h, hfs_fs.h, bins_del.c, binsert.c, Makefile, bdelete.c:
  1329. Clean up of hfs_bdelete(), splitting bins_del.c into three files:
  1330. bins_del.c, binsert.c and bdelete.c
  1331. * bpath.c, bins_del.c:
  1332. hfs_bdelete() is now working "correctly", but needs some cleaning up.
  1333. Mon Apr 22 05:35:41 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1334. * hfs_fs.h, bpath.c, hfs_btree.h, bins_del.c, bnode.c, balloc.c,
  1335.   bfind.c:
  1336. Rewrite bnode handling, heading toward a more write-behind approach.
  1337. Have done away with HFS_LOCK_BLIND.
  1338. * inode_dbl.c, inode_nat.c, extent.c, hfs_fs_i.h, inode_cap.c:
  1339. Was trying to truncate resource fork of directories!
  1340. Sun Apr 21 08:15:43 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1341. * balloc.c:
  1342. Updated to use truncate() to grow full trees.
  1343. * extent.c, hfs_fs.h, file.c, inode.c:
  1344. Added truncate() for normal files.
  1345. * bins_del.c:
  1346. hfs_bdelete() fixes for handling removal of root.
  1347. * inode_cap.c, inode_dbl.c, inode_nat.c:
  1348. Release storage for deleted files in hfs_*_put_inode().
  1349. * bitmap.c:
  1350. Make len=0 valid for hfs_{set,clear}_vbm_bits().
  1351. * super.c, inode.c, hfs_fs_i.h, hfs_fs_sb.h, btree.c, balloc.c:
  1352. Changed from clumpsize to clumpblks.
  1353. * inode_nat.c, hfs_fs.h, inode_cap.c, inode_dbl.c, btree.c, extent.c,
  1354.   balloc.c:
  1355. Some extent-related changes in preparation for truncate() support.
  1356. Sat Apr 20 10:59:13 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1357. * inode_nat.c, hfs_fs_i.h, inode.c, inode_cap.c, inode_dbl.c,
  1358.   dir_nat.c, hfs_fs.h, dir.c, dir_cap.c, dir_dbl.c:
  1359. Removed dir.valence from hfs inode.
  1360. Added unlink(), but still need truncate() and some more support
  1361. in hfs_*_put_inode() to free the disk space used by deleted files.
  1362. * bnode.c:
  1363. Check for NULL bnode in hfs_bnode_relse().
  1364. * bins_del.c:
  1365. Fixed a byte-order problem in bdelete_nonempty().
  1366. * hfs_fs.h, bnode.c, bpath.c, hfs_btree.h, balloc.c, bins_del.c:
  1367. First attempt at hfs_bdelete().
  1368. * dir.c:
  1369. The Finder would display strange things if it couldn't set frView.
  1370. Therefore initialize frView field for new directories.
  1371. * file_cap.c, file_dbl.c, file_nat.c, hfs_fs.h:
  1372. Define User/Finder info fields of catalog entry in more detail.
  1373. * hfs_fs.h:
  1374. HFS_BFIND_DELETE should require exact match.
  1375. * dir.c:
  1376. Set "record in use" bit of filFlags for new files.
  1377. * inode.c:
  1378. Was doing the wrong thing with i_ctime.
  1379. * dir_nat.c, dir_cap.c, dir_dbl.c:
  1380. Added some missing updates to the inode in hfs_*_{create,mkdir}().
  1381. Sun Apr 14 00:10:52 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1382. * hfs_fs.h, file_dbl.c, file_nat.c, file.c:
  1383. Work around the ever-changing type of f_reada.
  1384. Sat Apr 13 00:43:41 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1385. * bpath.c, bfind.c:
  1386. Spelling corrections in comments.
  1387. * bins_del.c:
  1388. ifdef out shift_left() until it is actually used.
  1389. * hfs_btree.h, hfs_fs.h, bins_del.c, bpath.c, bfind.c:
  1390. Cleaned up code related to 'flags' argument to hfs_bpath_find().
  1391. Fri Apr 12 23:30:01 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1392. * bpath.c:
  1393. Updated comments.
  1394. Rewrote hfs_bpath_init() and hfs_bpath_next().
  1395. * hfs_btree.h:
  1396. Updated prototype for hfs_bpath_init().
  1397. * bins_del.c:
  1398. Updated call to hfs_bpath_init().
  1399. * inode.c, inode_cap.c, inode_dbl.c, inode_nat.c, extent.c, file_cap.c,
  1400.   file_dbl.c, file_nat.c, dir_cap.c, dir_dbl.c, dir_nat.c, catalog.c,
  1401.   dir.c:
  1402. Renamed hfs_brec_relse() to hfs_brelse().
  1403. * hfs_fs.h, hfs_btree.h:
  1404. Updated prototypes to reflect new names in bpath.c
  1405. * bins_del.c:
  1406. Updated calls to functions in bpath.c
  1407. Updated comments.
  1408. * Makefile:
  1409. Renamed brec.c to bpath.c
  1410. * bfind.c:
  1411. Updated calls to functions in bpath.c
  1412. Added hfs_brelse() which was previously hfs_brec_relse() in brec.c
  1413. * bpath.c:
  1414. brec.c renamed to bpath.c
  1415. Functions renamed to reflect their current actions.
  1416. Comments are still out of date.
  1417. hfs_brec_relse() renamed to hfs_brelse() and moved to bfind.c
  1418. * brec.c:
  1419. brec.c renamed to bpath.c
  1420. Wed Apr 10 07:20:28 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1421. * hfs_fs.h, extent.c, hfs_btree.h, brec.c, dir.c, bfind.c,
  1422.   bins_del.c:
  1423. Backed-out changes to hfs_binsert() that added the ability to
  1424. return the new record, since it will probably not ever be needed.
  1425. * extent.c:
  1426. Since 1.3.45 truncate() has locked the file, so there is no need
  1427. for all the things I've been doing to hfs_file_extend() & new_extent().
  1428. Those two functions have been cleaned up a bit (similar to older forms).
  1429. * extent.c:
  1430. hfs_file_extend() now more "robust", but new_extent() is still
  1431. not fully "concurrency safe."
  1432. Tue Apr  9 09:01:18 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1433. * bins_del.c:
  1434. Made split() inline.
  1435. * inode.c, dir_nat.c, hfs_fs.h, dir_cap.c:
  1436. Added hfs_itry() to get in-core inodes.
  1437. * inode_dbl.c, inode_nat.c, hfs_fs.h, inode.c, inode_cap.c, file_dbl.c,
  1438.   file_nat.c, hfs_btree.h, extent.c, file_cap.c, dir_cap.c, dir_dbl.c,
  1439.   dir_nat.c, brec.c, catalog.c, dir.c, bins_del.c, bnode.c,
  1440.   bfind.c:
  1441. Rewrite of all the (struct hfs_brec) stuff.
  1442. Mon Apr  8 21:50:01 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1443. * btree.c, extent.c, bnode.c:
  1444. Fixed format strings in a few debugging printk()'s.
  1445. * brec.c, hfs_fs.h:
  1446. Removed hfs_brec_relse_one().
  1447. * hfs_fs.h, bnode.c, brec.c, hfs_btree.h, bfind.c, bins_del.c, balloc.c:
  1448. (struct hfs_bnode_ref)s are now returned by value rather than reference
  1449. and they are in (struct hfs_brec) rather than pointed to.  Cuts down on
  1450. a lot of kmalloc() and kfree() traffic.
  1451. * hfs_fs.h, dir.c, extent.c, bins_del.c:
  1452. Modified hfs_binsert() to be able to return the new record.
  1453. * bins_del.c, hfs_btree.h:
  1454. Added shift_left(), still untested.
  1455. * bins_del.c:
  1456. new_root() was missing its comment.
  1457. * super.c, trans.c, hfs_fs_i.h, inode.c, inode_dbl.c, inode_nat.c,
  1458.   file_nat.c, hfs_btree.h, hfs_fs.h, file.c, file_dbl.c, dir_dbl.c,
  1459.   dir_nat.c, extent.c, dir.c, dir_cap.c, bitops.c, bnode.c, brec.c,
  1460.   bfind.c, bins_del.c, bitmap.c, balloc.c:
  1461. Fixed lines over 80 characters and tabified files.
  1462. * bins_del.c:
  1463. Fixed line(s) over 80 columns.
  1464. * trans.c, inode_nat.c, string.c, super.c, inode.c, inode_cap.c,
  1465.   inode_dbl.c, hfs_fs_i.h, hfs_fs_sb.h, hfs_btree.h, hfs_fs.h, file.c,
  1466.   file_cap.c, file_dbl.c, file_nat.c, dir_dbl.c, extent.c, btree.c,
  1467.   dir_cap.c, bitops.c, bnode.c, brec.c, bfind.c, bins_del.c, bitmap.c,
  1468.   DOC, README, TODO, balloc.c, CHANGES:
  1469. About 150 spelling corrections.
  1470. Sun Apr  7 23:14:28 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1471. * dir_cap.c, dir_dbl.c, dir_nat.c, dir.c:
  1472. Cleaned-up check for special names in mkdir().
  1473. * extent.c:
  1474. More verbose error message.
  1475. * inode_dbl.c, inode_nat.c, hfs_fs_i.h, inode.c, inode_cap.c, dir.c,
  1476.   hfs_fs.h:
  1477. Limit directories to 32767 entries, since Mac uses 16-bit integer.
  1478. Fri Apr  5 07:27:57 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1479. * FAQ:
  1480. Initial version.
  1481. * dir_dbl.c, dir_nat.c, bins_del.c, dir.c, dir_cap.c:
  1482. Added missing function comments.
  1483. Wed Apr  3 06:38:36 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1484. * brec.c:
  1485. Cleaned-up code for brec->flags.
  1486. * extent.c:
  1487. Added function comments.
  1488. * bins_del.c:
  1489. Added function comments.
  1490. hfs_binsert() was incrementing record count even on failure.
  1491. Mon Apr  1 08:35:51 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1492. * extent.c:
  1493. Rewrote find_ext() and new_extent() for new hfs_btree_extend().
  1494. Moved hfs_btree_extend() to balloc.c
  1495. Fixed potential kernel OOPS in new_extent().
  1496. * brec.c:
  1497. Fixed potential kernel OOPS in hfs_brec_get_root().
  1498. Removed hfs_brec_find_first().
  1499. Fixed return value of hfs_brec_find().
  1500. * bins_del.c:
  1501. Updated call to hfs_btree_extend().
  1502. * balloc.c:
  1503. Merged hfs_bnode_add() and hfs_btree_extend() into the later.
  1504. Commented init_mapnode().
  1505. * bfind.c:
  1506. Removed hfs_bfind_first().
  1507. * hfs_fs.h, hfs_btree.h:
  1508. Updated prototypes.
  1509. Sat Mar 30 22:56:47 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1510. * CHANGES, README, TODO:
  1511. Updated documentation in preparation for 0.6 release.
  1512. * inode.c, hfs_fs.h:
  1513. Got rid of HFS_FAKE_EXEC in favor of noexec mount option.
  1514. * inode.c, super.c, DOC, hfs_fs_sb.h:
  1515. Added "quiet" mount option, like the fat filesystem.
  1516. * inode.c, dir_cap.c, dir_nat.c:
  1517. Pseudo-directories are read-only (at least for now).
  1518. * hfs_fs.h, dir_dbl.c, dir_nat.c, dir.c, dir_cap.c:
  1519. mkdir() updated to check against reserved names, but the
  1520. AppleDouble scheme still has problems with names starting with '%'.
  1521. * dir_dbl.c, dir_nat.c, hfs_fs.h, dir.c, dir_cap.c:
  1522. Added mkdir(). (It only took 2 tries to get it right!!)
  1523. Only works in "normal" directories and doesn't yet stop
  1524. one from creating dirs with the reserved names.
  1525. * brec.c, extent.c, bins_del.c:
  1526. Now have a way to get an EEXIST back from hfs_binsert().
  1527. * btree.c, inode.c, hfs_fs_i.h, file.c, bfind.c, bnode.c, balloc.c:
  1528. Added 'dev' field to struct hfs_file.
  1529. * hfs_fs_i.h, inode.c, btree.c, extent.c, file.c, bnode.c, brec.c,
  1530.   balloc.c:
  1531. Removed duplicated fields from struct hfs_file since
  1532. even B*-trees now have that information in the inode.
  1533. * extent.c:
  1534. zero_blocks() neglected allocation block size in computing start.
  1535. Fri Mar 29 16:04:37 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1536. * super.c:
  1537. hfs_statfs(): f_files and f_ffree fields are now -1, which is
  1538. documented as the value for "undefined" fields in struct statfs.
  1539. * trans.c, inode_nat.c, string.c, super.c, inode_dbl.c, inode_cap.c,
  1540.   inode.c, file_nat.c, file_dbl.c, file_cap.c, file.c, dir_dbl.c,
  1541.   extent.c, dir_cap.c, catalog.c, btree.c, brec.c, bnode.c, bitops.c,
  1542.   bitmap.c, bins_del.c, balloc.c:
  1543. Stylistic editing: {} for all 'for', 'while' and 'if' blocks.
  1544. I hope I didn't screw-up anything.
  1545. * hfs_fs.h, dir.c, dir_cap.c, dir_dbl.c, dir_nat.c:
  1546. Added creation of normal files to all three fork schemes!
  1547. Strange things may happen when trying to create "non-normal" files.
  1548. * brec.c:
  1549. Cleaned up some debugging code.
  1550. * hfs_fs_i.h:
  1551. File and directory counts could have overflown 16-bit integer.
  1552. * hfs_btree.h:
  1553. Added HFS_BREC_RIGHT to help fix insertion problem.
  1554. * extent.c:
  1555. Various fixes to hfs_{file,btree}_extend().
  1556. * catalog.c:
  1557. Made hfs_build_cat_key() more "correct".
  1558. * btree.c:
  1559. Added and fixed debugging code.
  1560. * brec.c:
  1561. Fixed overflow detection.
  1562. Added some debugging code.
  1563. * bnode.c:
  1564. Dirtied some buffers in places that might have been missed.
  1565. Fixed some debugging code that had broken.
  1566. * bitops.c:
  1567. hfs_count_free_bits() was running off end of bitmap.
  1568. * bins_del.c:
  1569. Fixed various bugs, mostly related to variable-length keys.
  1570. * balloc.c:
  1571. Had forgotten to set a bit in new mapnodes.
  1572. Node counts were overflowing 16-bit integers.
  1573. * bitmap.c:
  1574. Oops! clear/set did opposite operation on full words.
  1575. Wed Mar 27 10:59:07 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1576. * hfs_fs_i.h:
  1577. Updated struct hfs_extent for concurrent access.
  1578. Also caused a slight modification to struct hfs_file.
  1579. * hfs_fs.h, hfs_btree.h:
  1580. Added/updated prototypes.
  1581. * balloc.c:
  1582. hfs_bnode_alloc() finished but still untested.
  1583. * bins_del.c:
  1584. Fixed up deadlock avoidance in hfs_binsert() again.
  1585. Perhaps I even got it right this time.
  1586. * extent.c:
  1587. hfs_file_extend() now safe under concurrent operations?
  1588. * file.c:
  1589. hfs_getblk() now safe under concurrent operations?
  1590. Tue Mar 26 23:26:35 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1591. * btree.c:
  1592. Added call to hfs_extent_trim() to fix memory leak.
  1593. * extent.c:
  1594. Oops, had left a "#define static" in from debugging.
  1595. * bins_del.c:
  1596. hfs_binsert() rewritten to avoid deadlock when extending
  1597. the extents B*-tree.
  1598. * btree.c:
  1599. Moved hfs_btree_extend() to extent.c
  1600. * inode_nat.c, inode_cap.c, inode_dbl.c:
  1601. hfs_*_put_inode() rewritten to call hfs_extent_trim().
  1602. * extent.c:
  1603. Big rewrite for new struct hfs_extent:
  1604. Now keep linked list of extents.
  1605. Cache is now a pointer to a list element.
  1606. Now have 'end' field to aid decode_extent().
  1607. New functions:
  1608. hfs_extent_trim(): frees linked list.
  1609. hfs_btree_extend(): for extending B*-trees.
  1610. Improved debugging output.
  1611. * balloc.c:
  1612. Added hfs_bnode_add() (incomplete and uncommented).
  1613. * btree.c:
  1614. Moved some work from hfs_btree_extend() to hfs_bnode_add().
  1615. * bfind.c:
  1616. Added hfs_bfind_first() as wrapper for hfs_brec_find_first().
  1617. * brec.c:
  1618. Added hfs_brec_find_first() to search first leaf node.
  1619. * bins_del.c:
  1620. Added error returns to hfs_binsert() and binsert().
  1621. * bins_del.c:
  1622. Check to see that we really need ancestors before starting.
  1623. Check that hfs_btree_alloc() gave us enough nodes.
  1624. binsert() uses info precomputed by hfs_binsert().
  1625. Mon Mar 25 11:33:53 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1626. * bnode.c:
  1627. Collected together the error returns in hfs_bnode_lock().
  1628. * Makefile:
  1629. Added ChangeLog to $(MISC).
  1630. Wed Mar 20 19:41:45 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1631. * super.c, hfs_fs.h, file.c, dir_dbl.c, dir_nat.c, dir.c, dir_cap.c:
  1632. Removed support for kernels older than about 1.3.70
  1633. Most of that support had been broken recently anyway.
  1634. * super.c:
  1635. Fixed so DEBUG_MEM works w/o DEBUG_ALL.
  1636. Updated call to hfs_btree_init().
  1637. * hfs_fs.h:
  1638. Updated/added prototypes.
  1639. * hfs_btree.h:
  1640. HFS_BFIND_CHAIN removed.
  1641. struct hfs_brec gets new 'flags' field with bits:
  1642. HFS_BREC_{FIRST,OVERFLOW,UNDERFLOW,UNINITIALIZED}
  1643. Removed bitmap size constants.
  1644. Changes to struct hfs_btree:
  1645.         'file' and 'cache' now structs rather than pointers.
  1646. Added 'reserved' field (used during insertion).
  1647. Added pointers to size and extent in MDB.
  1648. * file.c:
  1649. Made hfs_getblk() public.
  1650. Removed (fil->inode == NULL) special cases.
  1651. * extent.c:
  1652. {find,update}_ext() are no longer inline.
  1653. new_extent() fails when called for the extents tree;
  1654. previously it would hanging calling hfs_binsert().
  1655. extend_file():
  1656. renamed to hfs_file_extend() and made public.
  1657. fixed to work for B*-trees.
  1658. zeros-out blocks as they are allocated.
  1659. fixed bugs for (allocation block) != (physical block).
  1660. * btree.c:
  1661. hfs_btree_{init,free}() modified for changes to struct:
  1662. 'file' and 'cache' moved back into structure
  1663. file.inode initialized to reduce special cases
  1664. hfs_btree_init() gets pointer to size in MDB instead of size.
  1665. Added hfs_btree_extend() (incomplete and uncommented).
  1666. * bnode.c:
  1667. hfs_bnode_{alloc,free}() moved to separate file.
  1668. Removed 'const' from some function arguments
  1669. due to change in struct hfs_btree.
  1670. hfs_bnode_lock(): added WRITE/RESRV->READ transition.
  1671. * brec.c:
  1672. hfs_brec_get_{root,child}() now take a 'keep_mask' argument
  1673. indicating when to keep ancestor nodes, and store
  1674. information about why ancestors were kept.
  1675. HFS_BFIND_CHAIN eliminated in favor of HFS_BFIND_{INSERT,DELETE}
  1676. which are now implemented using 'keep_mask'.
  1677. Added hfs_brec_relse_one() that doesn't release ancestors.
  1678. * bins_del.c:
  1679. Lots of rewrites to cleanup insertion.
  1680. Now tries to extend tree before insertion starts.
  1681. binsert() iterative rather than recursive.
  1682. No point in keeping track as it is still not "stable".
  1683. * balloc.c:
  1684. New file: started with hfs_bnode_{free,alloc}()
  1685. Added hfs_bnode_init() to initialize a newly allocated bnode.
  1686. hfs_bnode_free():
  1687. Renamed hfs_bnode_bitop().
  1688. Can set or clear a specified bit.
  1689. Gets bitmap sizes from nodes directly.
  1690. hfs_bnode_alloc():
  1691. Returns actual node, calling hfs_bnode_init().
  1692. Gets bitmap sizes from nodes directly.
  1693. * bfind.c:
  1694. Removed obsolete comment from hfs_bsucc()
  1695. Removed 'const' from tree arg of hfs_bfind()
  1696. due to changes in struct hfs_btree.
  1697. * Makefile:
  1698. Added new file: balloc.c
  1699. Sat Mar  9 22:03:53 1996  Paul H. Hargrove  <hargrove@sccm.stanford.edu>
  1700. * Start of detailed CVS logging.
  1701. Mar 09, 1996: snapshot-09Mar96 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1702. NOT AN OFFICIAL RELEASE
  1703. Fixed up debugging code that was broken by split of btree.c
  1704. Added debugging kmalloc/kfree
  1705. Fixed memory leak in hfs_bnode_relse()
  1706. Mar 08, 1996: snapshot-08Mar96 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1707. NOT AN OFFICIAL RELEASE
  1708. now reset blocksize on device when done.
  1709. hfs_binsert done (except for the full tree case).
  1710. btree.c split up into manageable pieces (need to sort out hfs_btree.h)
  1711. Feb 26, 1996: snapshot-26Feb96 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1712. NOT AN OFFICIAL RELEASE
  1713. Some writability.
  1714. Bug with multiple opens of meta data fixed.
  1715. Netatalk support no longer considered experimental.
  1716. Virtually everything has changed, so I've lost track here.
  1717. Nov 16, 1995: snapshot-16Nov95 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1718. NOT AN OFFICIAL RELEASE
  1719. Still more comments.
  1720. btree.c back to 80 columns.  will do same to other files soon.
  1721. Starting with btree.c have begun to put file contents into some
  1722. sort of standard order.
  1723. Moved metadata reading to VFS open() routine and now free it in
  1724. the VFS release() routine.  Much cleaner than the old way.
  1725. Unified hfs_iget by shifting scheme-dependent code into a function
  1726. pointer in the superblock.  This could/should be shifted to
  1727. a VFS read_inode() routine if that can be done cleanly.
  1728. Probably lots of other changes; I've lost track.
  1729. Nov 05, 1995: version 0.5.3 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1730. NOT AN OFFICIAL RELEASE
  1731. 1.2.x compatibility removed
  1732. Added lots of comments to btree.c and cleanup some code.  The result
  1733. is that the source file doubled in size while the object
  1734. file dropped in size by 20%.
  1735. Added some comments to super.c and dir.c as well.
  1736. Cleaned up some stuff in dir.c adding some additional error checking
  1737. and moving closer to using a unified hfs_iget by migrating
  1738. common code into lookup_parent().
  1739. Changed btree.c to use a separate bnode cache per filesystem.
  1740. Renamed a bunch of the bnode functions in btree.c
  1741. Jun 29, 1995: version 0.5.2 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1742. BUG FIX and 1.3.x-compatibility release.
  1743. Will compile under 1.2.x or 1.3.x by changing one line in Makefile.
  1744. Started adding magic numbers to structures for "safety".
  1745. Don't strip internal symbols when linking or loading, as this made
  1746. good bug reports rather difficult.
  1747. Fixed a bug that could cause the fs to lock-up after trying to open
  1748. a non-existent file.
  1749. Fixed a bug that allowed files to appear truncated, when in fact it
  1750. is still not possible to truncate a file.
  1751. Added more/better comments to header files.
  1752. Deal with volume and b-tree bitmaps in preparation for writing.
  1753. Fixed readdir() to deal properly with the case where the directory
  1754. changes while writing to user-space. (which can't yet
  1755. actually happen, until directories are writable).
  1756. Jun 23, 1995: version 0.5.1 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1757. BUG FIX RELEASE
  1758. Removed two debugging messages that didn't belong.
  1759. Fixed a typo that prevented modified inodes from being written to disk.
  1760. Added a missing line which prevented rmmod'ing sometimes.
  1761. Added a missing line which caused errors when modifying .finderinfo or
  1762. .resource under the CAP system.
  1763. Added a notify_change() to keep mode bits sensible, and to cause
  1764. changes to an inode to affect the data fork and resource fork
  1765. of a file together.
  1766. Jun 22, 1995: version 0.5 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1767. Fixed a bug that was giving wrong values for i_blocks
  1768. Partly writable (can only 'touch' existing files, so far)
  1769. Removed case= mount option.  It will be back eventually.
  1770. Can now deal with CDROMs (and hard disks?), many thanks to
  1771. Holger Schemel for this work.
  1772. Latin-1 filename conversion also due to Holger Schemel.
  1773. Rewritten btree operations.
  1774. Feb 28, 1995: version 0.4 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1775. Requires Linux >= 1.1.94: depends on changes made to asm/byteorder.h
  1776. Now using string comparison code donated by ARDI (see string.c)
  1777. Code reorganized to use data structures more like ARDI's.
  1778. More code reorganization to abstract the btree operations.
  1779. Added the fork= mount option.
  1780. Added AppleDouble support.  Executor, from ARDI, can now run programs
  1781. from HFS filesystems mounted with the HFS module.
  1782. Jan 28, 1995: version 0.3 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1783. Major code reorganization.
  1784. Known for certain to work ONLY on floppies.
  1785. Started caching extents, so got faster on long file reads.
  1786. Now compiles separate from kernel tree.
  1787. Supports 5 filename conversion methods.
  1788. Supports forks, using the method from CAP.
  1789. All external symbols now start with HFS_ or hfs_
  1790. Jan 12, 1995: version 0.2 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1791. Should now work on all HFS volumes, but still only tested on floppies.
  1792. Got smaller and faster with some code reorganization.
  1793. Since Linus moved htons() and friends to an asm file, should now be
  1794.  truly endian-independent, but still only tested on Intel machines.
  1795. Requires Linux >= 1.1.77, since Linus moved htons().
  1796. Jan 05, 1995: version 0.1 hargrove@sccm.stanford.edu (Paul H. Hargrove)
  1797. First release.
  1798. 1.44Mb floppies only
  1799. no resource forks
  1800. trivial name mangling only
  1801. read only
  1802. for Linux >= 1.1.75