Commit 7450aa7e authored by Linus Torvalds's avatar Linus Torvalds

Import 1.1.3

parent a92264df
...@@ -11,87 +11,6 @@ ...@@ -11,87 +11,6 @@
# #
# Each line in the config file is a command. # Each line in the config file is a command.
# #
# # internal comment
#
# Lines beginning with a `#' are ignored.
#
# : message
#
# `:' causes the line to be echoed to the screen.
#
# * external comment
#
# `*' causes the line to be placed in the output
# configuration file as a comment as well as being
# echoed to the screen.
#
# if condition
# ... commands ...
# else
# ... commands ...
# fi
#
# This does the obvious thing. The `else' clause is
# optional. Conditionals can be nested.
#
# The `condition' can be any valid bash expression.
# They typically involve tests against environment
# variables set by configuration options. For example,
#
# if [ "$CONFIG_SCSI" = "y" ]
# ...More stuff...
# fi
#
# Note! That there is no `then' keyword.
#
# bool 'prompt' CONFIG_VARIABLE default
#
# This prompts the user for a boolean value.
# The prompt may not contain an apostrophe.
# `default' should be either `y' or `n'.
# The user's response is recorded in four places.
#
# In .config, if `y'
# CONFIG_VARIABLE = CONFIG_VARIABLE
# In .config, if `n'
# # CONFIG_VARIABLE is not set
#
# In autoconf.h, if `y'
# #define CONFIG_VARIABLE 1
# In autoconf.h, if `n'
# #undef CONFIG_VARIABLE
#
# In config.in, if `y'
# bool 'prompt' CONFIG_VARIABLE y
# In config.in, if `n'
# bool 'prompt' CONFIG_VARIABLE n
#
# In the environment of the Configure script, if `y'
# CONFIG_VARIABLE = y
# In the environment of the Configure script, if `n'
# CONFIG_VARIABLE = n
#
# The value is placed into the environment of the Configure
# script so that later parts of config.in can use the `if'
# command to inspect the results of previous queries.
#
# int 'prompt' CONFIG_VARIABLE default
#
# This prompts the user for an integer value.
# The prompt may not contain an apostrophe.
# `default' should be an integer.
#
# The response is recorded as follows.
#
# In .config
# CONFIG_VARIABLE = response
# In autoconf.h
# #define CONFIG_VARIABLE (response)
# In config.in
# int 'prompt' CONFIG_VARIABLE response
# In the environment of the Configure script
# CONFIG_VARIABLE = response
#
# 050793 - use IFS='@' to get around a bug in a pre-version of bash-1.13 # 050793 - use IFS='@' to get around a bug in a pre-version of bash-1.13
# with an empty IFS. # with an empty IFS.
...@@ -114,58 +33,85 @@ set -f -h ...@@ -114,58 +33,85 @@ set -f -h
# readln prompt default # readln prompt default
# #
function readln () { function readln () {
echo -n "$1" if [ "$DEFAULT" = "-d" ]; then
IFS='@' read ans </dev/tty || exit 1 echo "$1"
[ -z "$ans" ] && ans=$2 ans=$2
else
echo -n "$1"
IFS='@' read ans </dev/tty || exit 1
[ -z "$ans" ] && ans=$2
fi
}
#
# change updates the "config.new" file according to the answer
#
# change define old new
#
function change () {
if [ "$2" != "$3" ]; then
sed "s/$1 $2$/$1 $3/" < $CONFIG_NEW > .tmpc
mv .tmpc $CONFIG_NEW
fi
} }
#
# comment does some pretty-printing
#
# comment 'xxx'
#
function comment () {
echo "*"; echo "* $1" ; echo "*"
(echo "" ; echo "#"; echo "# $1" ; echo "#") >>$CONFIG
(echo "" ; echo "/*"; echo " * $1" ; echo " */") >>$CONFIG_H
}
#
# bool processes a boolean argument # bool processes a boolean argument
# #
# bool tail # bool question define default
# #
function bool () { function bool () {
# Slimier hack to get bash to rescan a line.
eval "set -- $1"
ans="" ans=""
while [ "$ans" != "y" -a "$ans" != "n" ]; do while [ "$ans" != "y" -a "$ans" != "n" ]; do
readln "$1 ($2) [$3] " "$3" readln "$1 ($2) [$3] " "$3"
done done
if [ "$ans" = "y" ]; then if [ "$ans" = "y" ]; then
echo "$2 = $2" >>$CONFIG echo " $2 = $2" >>$CONFIG
echo "#define $2 1" >>$CONFIG_H echo "#define $2 1" >>$CONFIG_H
else else
echo "# $2 is not set" >>$CONFIG echo "# $2 is not set" >>$CONFIG
echo "#undef $2" >>$CONFIG_H echo "#undef $2" >>$CONFIG_H
fi fi
raw_input_line="bool '$1' $2 $ans" change $2 $3 $ans
eval "$2=$ans" eval "$2=$ans"
} }
#
# int processes an integer argument # int processes an integer argument
# #
# int tail # int question define default
# #
function int () { function int () {
# Slimier hack to get bash to rescan a line. # Slimier hack to get bash to rescan a line.
eval "set -- $1"
ans="x" ans="x"
while [ $[$ans+0] != "$ans" ]; do while [ $[$ans+0] != "$ans" ]; do
readln "$1 ($2) [$3] " "$3" readln "$1 ($2) [$3] " "$3"
done done
echo "$2 = $ans" >>$CONFIG echo " $2 = $ans" >>$CONFIG
echo "#define $2 ($ans)" >>$CONFIG_H echo "#define $2 ($ans)" >>$CONFIG_H
raw_input_line="int '$1' $2 $ans"
eval "$2=$ans" eval "$2=$ans"
} }
CONFIG=.tmpconfig CONFIG=.tmpconfig
CONFIG_H=include/linux/autoconf.h CONFIG_H=.tmpconfig.h
trap "rm -f $CONFIG $CONFIG_H config.new ; exit 1" 1 2 CONFIG_NEW=config.new
trap "rm -f $CONFIG $CONFIG_H $CONFIG_NEW ; exit 1" 1 2
# #
# Make sure we start out with a clean slate. # Make sure we start out with a clean slate.
# #
> config.new cp config.in $CONFIG_NEW
echo "#" > $CONFIG echo "#" > $CONFIG
echo "# Automatically generated make config: don't edit" >> $CONFIG echo "# Automatically generated make config: don't edit" >> $CONFIG
echo "#" >> $CONFIG echo "#" >> $CONFIG
...@@ -174,62 +120,16 @@ echo "/*" > $CONFIG_H ...@@ -174,62 +120,16 @@ echo "/*" > $CONFIG_H
echo " * Automatically generated C config: don't edit" >> $CONFIG_H echo " * Automatically generated C config: don't edit" >> $CONFIG_H
echo " */" >> $CONFIG_H echo " */" >> $CONFIG_H
stack='' DEFAULT=$1
branch='t'
. ./config.in
while IFS='@' read raw_input_line
do
# Slimy hack to get bash to rescan a line.
read cmd rest <<-END_OF_COMMAND
$raw_input_line
END_OF_COMMAND
if [ "$cmd" = "*" ]; then
if [ "$branch" = "t" ]; then
echo "$raw_input_line"
echo "# $rest" >>$CONFIG
if [ "$prevcmd" != "*" ]; then
echo >>$CONFIG_H
echo "/* $rest" >>$CONFIG_H
else
echo " * $rest" >>$CONFIG_H
fi
prevcmd="*"
fi
else
[ "$prevcmd" = "*" ] && echo " */" >>$CONFIG_H
prevcmd=""
case "$cmd" in
:) [ "$branch" = "t" ] && echo "$raw_input_line" ;;
int) [ "$branch" = "t" ] && int "$rest" ;;
bool) [ "$branch" = "t" ] && bool "$rest" ;;
exec) [ "$branch" = "t" ] && ( sh -c "$rest" ) ;;
if) stack="$branch $stack"
if [ "$branch" = "t" ] && eval "$rest"; then
branch=t
else
branch=f
fi ;;
else) if [ "$branch" = "t" ]; then
branch=f
else
read branch rest <<-END_OF_STACK
$stack
END_OF_STACK
fi ;;
fi) [ -z "$stack" ] && echo "Error! Extra fi." 1>&2
read branch stack <<-END_OF_STACK
$stack
END_OF_STACK
;;
esac
fi
echo "$raw_input_line" >>config.new
done
[ "$prevcmd" = "*" ] && echo " */" >>$CONFIG_H
[ -z "$stack" ] || echo "Error! Untermiated if." 1>&2 if [ "$CONFIG_SOUND" = "y" ] ; then
$MAKE -C drivers/sound config || exit 1
fi
mv .tmpconfig .config
mv .tmpconfig.h include/linux/autoconf.h
mv config.in config.old mv config.in config.old
mv config.new config.in mv config.new config.in
......
VERSION = 1 VERSION = 1
PATCHLEVEL = 1 PATCHLEVEL = 1
SUBLEVEL = 2 SUBLEVEL = 3
all: Version zImage all: Version zImage
...@@ -116,12 +116,11 @@ endif ...@@ -116,12 +116,11 @@ endif
Version: dummy Version: dummy
rm -f tools/version.h rm -f tools/version.h
oldconfig:
$(CONFIG_SHELL) Configure -d $(OPTS)
config: config:
$(CONFIG_SHELL) Configure $(OPTS) < config.in $(CONFIG_SHELL) Configure $(OPTS)
@if grep -s '^CONFIG_SOUND' .tmpconfig ; then \
$(MAKE) -C drivers/sound config; \
else : ; fi
mv .tmpconfig .config
linuxsubdirs: dummy linuxsubdirs: dummy
set -e; for i in $(SUBDIRS); do $(MAKE) -C $$i; done set -e; for i in $(SUBDIRS); do $(MAKE) -C $$i; done
......
...@@ -2,9 +2,9 @@ ...@@ -2,9 +2,9 @@
# For a description of the syntax of this configuration file, # For a description of the syntax of this configuration file,
# see the Configure script. # see the Configure script.
# #
*
* General setup comment 'General setup'
*
bool 'Kernel math emulation' CONFIG_MATH_EMULATION y bool 'Kernel math emulation' CONFIG_MATH_EMULATION y
bool 'Normal harddisk support' CONFIG_BLK_DEV_HD y bool 'Normal harddisk support' CONFIG_BLK_DEV_HD y
bool 'XT harddisk support' CONFIG_BLK_DEV_XD n bool 'XT harddisk support' CONFIG_BLK_DEV_XD n
...@@ -12,59 +12,60 @@ bool 'TCP/IP networking' CONFIG_INET y ...@@ -12,59 +12,60 @@ bool 'TCP/IP networking' CONFIG_INET y
bool 'Limit memory to low 16MB' CONFIG_MAX_16M n bool 'Limit memory to low 16MB' CONFIG_MAX_16M n
bool 'System V IPC' CONFIG_SYSVIPC y bool 'System V IPC' CONFIG_SYSVIPC y
bool 'Use -m486 flag for 486-specific optimizations' CONFIG_M486 y bool 'Use -m486 flag for 486-specific optimizations' CONFIG_M486 y
*
* Program binary formats comment 'Program binary formats'
*
bool 'Elf executables' CONFIG_BINFMT_ELF y bool 'Elf executables' CONFIG_BINFMT_ELF y
bool 'COFF executables' CONFIG_BINFMT_COFF y bool 'COFF executables' CONFIG_BINFMT_COFF y
*
* SCSI support comment 'SCSI support'
*
bool 'SCSI support?' CONFIG_SCSI n bool 'SCSI support?' CONFIG_SCSI n
if [ "$CONFIG_SCSI" = "n" ]
: if [ "$CONFIG_SCSI" = "n" ]; then
: Skipping SCSI configuration options...
: comment 'Skipping SCSI configuration options...'
else else
*
* SCSI support type (disk, tape, CDrom) comment 'SCSI support type (disk, tape, CDrom)'
*
bool 'Scsi disk support' CONFIG_BLK_DEV_SD y bool 'Scsi disk support' CONFIG_BLK_DEV_SD y
bool 'Scsi tape support' CONFIG_CHR_DEV_ST y bool 'Scsi tape support' CONFIG_CHR_DEV_ST n
bool 'Scsi CDROM support' CONFIG_BLK_DEV_SR y bool 'Scsi CDROM support' CONFIG_BLK_DEV_SR n
bool 'Scsi generic support' CONFIG_CHR_DEV_SG y bool 'Scsi generic support' CONFIG_CHR_DEV_SG n
*
* SCSI low-level drivers comment 'SCSI low-level drivers'
*
bool 'Adaptec AHA152X support' CONFIG_SCSI_AHA152X y bool 'Adaptec AHA152X support' CONFIG_SCSI_AHA152X n
bool 'Adaptec AHA1542 support' CONFIG_SCSI_AHA1542 y bool 'Adaptec AHA1542 support' CONFIG_SCSI_AHA1542 y
bool 'Adaptec AHA1740 support' CONFIG_SCSI_AHA1740 y bool 'Adaptec AHA1740 support' CONFIG_SCSI_AHA1740 n
bool 'Future Domain 16xx SCSI support' CONFIG_SCSI_FUTURE_DOMAIN y bool 'Future Domain 16xx SCSI support' CONFIG_SCSI_FUTURE_DOMAIN n
bool 'Generic NCR5380 SCSI support' CONFIG_SCSI_GENERIC_NCR5380 y bool 'Generic NCR5380 SCSI support' CONFIG_SCSI_GENERIC_NCR5380 n
bool 'PAS16 SCSI support' CONFIG_SCSI_PAS16 y bool 'PAS16 SCSI support' CONFIG_SCSI_PAS16 n
bool 'Seagate ST-02 and Future Domain TMC-8xx SCSI support' CONFIG_SCSI_SEAGATE y bool 'Seagate ST-02 and Future Domain TMC-8xx SCSI support' CONFIG_SCSI_SEAGATE n
bool 'Trantor T128/T128F/T228 SCSI support' CONFIG_SCSI_T128 y bool 'Trantor T128/T128F/T228 SCSI support' CONFIG_SCSI_T128 n
bool 'UltraStor SCSI support' CONFIG_SCSI_ULTRASTOR y bool 'UltraStor SCSI support' CONFIG_SCSI_ULTRASTOR n
bool '7000FASST SCSI support' CONFIG_SCSI_7000FASST y bool '7000FASST SCSI support' CONFIG_SCSI_7000FASST n
fi fi
*
* Network device support comment 'Network device support'
*
bool 'Network device support?' CONFIG_ETHERCARDS y bool 'Network device support?' CONFIG_ETHERCARDS y
if [ "$CONFIG_ETHERCARDS" = "n" ] if [ "$CONFIG_ETHERCARDS" = "n" ]; then
:
: Skipping ethercard configuration options... comment 'Skipping ethercard configuration options...'
:
else else
bool 'SLIP (serial line) support' CONFIG_SLIP n bool 'SLIP (serial line) support' CONFIG_SLIP n
if [ "$CONFIG_SLIP" = "y" ] if [ "$CONFIG_SLIP" = "y" ]; then
bool ' CSLIP compressed headers' SL_COMPRESSED y bool ' CSLIP compressed headers' SL_COMPRESSED y
# bool ' SLIP debugging on' SL_DUMP y # bool ' SLIP debugging on' SL_DUMP y
fi fi
#bool 'PPP (point-to-point) support' CONFIG_PPP n #bool 'PPP (point-to-point) support' CONFIG_PPP n
bool 'PLIP (parallel port) support' CONFIG_PLIP n bool 'PLIP (parallel port) support' CONFIG_PLIP n
bool 'NE2000/NE1000 support' CONFIG_NE2000 n bool 'NE2000/NE1000 support' CONFIG_NE2000 n
bool 'WD80*3 support' CONFIG_WD80x3 y bool 'WD80E3 support' CONFIG_WD80x3 y
bool 'SMC Ultra support' CONFIG_ULTRA n bool 'SMC Ultra support' CONFIG_ULTRA n
bool '3c501 support' CONFIG_EL1 n bool '3c501 support' CONFIG_EL1 n
bool '3c503 support' CONFIG_EL2 n bool '3c503 support' CONFIG_EL2 n
...@@ -77,20 +78,22 @@ bool 'AT1700 support' CONFIG_AT1700 n ...@@ -77,20 +78,22 @@ bool 'AT1700 support' CONFIG_AT1700 n
#bool 'Zenith Z-Note support' CONFIG_ZNET n #bool 'Zenith Z-Note support' CONFIG_ZNET n
#bool 'EtherExpress support' CONFIG_EEXPRESS n #bool 'EtherExpress support' CONFIG_EEXPRESS n
bool 'DEPCA support' CONFIG_DEPCA n bool 'DEPCA support' CONFIG_DEPCA n
#bool 'NI52** support' CONFIG_NI52 n #bool 'NI52EE support' CONFIG_NI52 n
#bool 'NI65** support' CONFIG_NI65 n #bool 'NI65EE support' CONFIG_NI65 n
#bool 'Ansel Communications EISA 3200 support' CONFIG_AC3200 n #bool 'Ansel Communications EISA 3200 support' CONFIG_AC3200 n
#bool 'Cabletron E21xx support (not recommended)' CONFIG_E21 n #bool 'Cabletron E21xx support (not recommended)' CONFIG_E21 n
bool 'D-Link DE600 pocket adaptor support' CONFIG_DE600 n bool 'D-Link DE600 pocket adaptor support' CONFIG_DE600 n
bool 'AT-LAN-TEC/RealTek pocket adaptor support' CONFIG_ATP n bool 'AT-LAN-TEC/RealTek pocket adaptor support' CONFIG_ATP n
fi fi
*
comment 'CD-ROM drivers'
bool 'Sony CDU31A CDROM driver support' CONFIG_CDU31A n bool 'Sony CDU31A CDROM driver support' CONFIG_CDU31A n
bool 'Mitsumi CDROM driver support' CONFIG_MCD n bool 'Mitsumi CDROM driver support' CONFIG_MCD n
bool 'Matsushita/Panasonic CDROM driver support' CONFIG_SBPCD n bool 'Matsushita/Panasonic CDROM driver support' CONFIG_SBPCD n
*
* Filesystems comment 'Filesystems'
*
bool 'Standard (minix) fs support' CONFIG_MINIX_FS y bool 'Standard (minix) fs support' CONFIG_MINIX_FS y
bool 'Extended fs support' CONFIG_EXT_FS n bool 'Extended fs support' CONFIG_EXT_FS n
bool 'Second extended fs support' CONFIG_EXT2_FS y bool 'Second extended fs support' CONFIG_EXT2_FS y
...@@ -101,13 +104,13 @@ bool 'NFS filesystem support' CONFIG_NFS_FS y ...@@ -101,13 +104,13 @@ bool 'NFS filesystem support' CONFIG_NFS_FS y
bool 'ISO9660 cdrom filesystem support' CONFIG_ISO9660_FS n bool 'ISO9660 cdrom filesystem support' CONFIG_ISO9660_FS n
bool 'OS/2 HPFS filesystem support (read only)' CONFIG_HPFS_FS n bool 'OS/2 HPFS filesystem support (read only)' CONFIG_HPFS_FS n
bool 'System V and Coherent filesystem support' CONFIG_SYSV_FS n bool 'System V and Coherent filesystem support' CONFIG_SYSV_FS n
*
* character devices comment 'character devices'
*
bool 'Parallel printer support' CONFIG_PRINTER n bool 'Parallel printer support' CONFIG_PRINTER n
bool 'Logitech busmouse support' CONFIG_BUSMOUSE n bool 'Logitech busmouse support' CONFIG_BUSMOUSE n
bool 'PS/2 mouse (aka "auxiliary device") support' CONFIG_PSMOUSE y bool 'PS/2 mouse (aka "auxiliary device") support' CONFIG_PSMOUSE y
if [ "$CONFIG_PSMOUSE" = "y" ] if [ "$CONFIG_PSMOUSE" = "y" ]; then
bool 'C&T 82C710 mouse port support (as on TI Travelmate)' CONFIG_82C710_MOUSE y bool 'C&T 82C710 mouse port support (as on TI Travelmate)' CONFIG_82C710_MOUSE y
fi fi
bool 'Microsoft busmouse support' CONFIG_MS_BUSMOUSE n bool 'Microsoft busmouse support' CONFIG_MS_BUSMOUSE n
...@@ -115,23 +118,18 @@ bool 'ATIXL busmouse support' CONFIG_ATIXL_BUSMOUSE n ...@@ -115,23 +118,18 @@ bool 'ATIXL busmouse support' CONFIG_ATIXL_BUSMOUSE n
bool 'Selection (cut and paste for virtual consoles)' CONFIG_SELECTION n bool 'Selection (cut and paste for virtual consoles)' CONFIG_SELECTION n
bool 'QIC-02 tape support' CONFIG_TAPE_QIC02 n bool 'QIC-02 tape support' CONFIG_TAPE_QIC02 n
bool 'QIC-117 tape support' CONFIG_FTAPE n bool 'QIC-117 tape support' CONFIG_FTAPE n
if [ "$CONFIG_FTAPE" = "y" ] if [ "$CONFIG_FTAPE" = "y" ]; then
int ' number of ftape buffers' NR_FTAPE_BUFFERS 3 int ' number of ftape buffers' NR_FTAPE_BUFFERS 3
fi fi
*
* Sound comment 'Sound'
*
bool 'Sound card support' CONFIG_SOUND n bool 'Sound card support' CONFIG_SOUND n
*
* Kernel hacking comment 'Kernel hacking'
*
#bool 'Debug kmalloc/kfree' CONFIG_DEBUG_MALLOC n #bool 'Debug kmalloc/kfree' CONFIG_DEBUG_MALLOC n
bool 'Kernel profiling support' CONFIG_PROFILE n bool 'Kernel profiling support' CONFIG_PROFILE n
if [ "$CONFIG_SCSI" = "y" ] if [ "$CONFIG_SCSI" = "y" ]; then
bool 'Verbose scsi error reporting (kernel size +=12K)' CONFIG_SCSI_CONSTANTS y bool 'Verbose scsi error reporting (kernel size +=12K)' CONFIG_SCSI_CONSTANTS y
fi fi
if [ "$CONFIG_SOUND" = "y" ]
exec touch .makesound
else
exec rm -f .makesound
fi
...@@ -156,7 +156,7 @@ static void add_request(struct blk_dev_struct * dev, struct request * req) ...@@ -156,7 +156,7 @@ static void add_request(struct blk_dev_struct * dev, struct request * req)
req->next = NULL; req->next = NULL;
cli(); cli();
if (req->bh) if (req->bh)
req->bh->b_dirt = 0; mark_buffer_clean(req->bh);
if (!(tmp = dev->current_request)) { if (!(tmp = dev->current_request)) {
dev->current_request = req; dev->current_request = req;
(dev->request_fn)(); (dev->request_fn)();
...@@ -240,12 +240,12 @@ static void make_request(int major,int rw, struct buffer_head * bh) ...@@ -240,12 +240,12 @@ static void make_request(int major,int rw, struct buffer_head * bh)
!req->waiting && !req->waiting &&
req->cmd == rw && req->cmd == rw &&
req->sector + req->nr_sectors == sector && req->sector + req->nr_sectors == sector &&
req->nr_sectors < 254) req->nr_sectors < 244)
{ {
req->bhtail->b_reqnext = bh; req->bhtail->b_reqnext = bh;
req->bhtail = bh; req->bhtail = bh;
req->nr_sectors += count; req->nr_sectors += count;
bh->b_dirt = 0; mark_buffer_clean(bh);
sti(); sti();
return; return;
} }
...@@ -254,14 +254,14 @@ static void make_request(int major,int rw, struct buffer_head * bh) ...@@ -254,14 +254,14 @@ static void make_request(int major,int rw, struct buffer_head * bh)
!req->waiting && !req->waiting &&
req->cmd == rw && req->cmd == rw &&
req->sector - count == sector && req->sector - count == sector &&
req->nr_sectors < 254) req->nr_sectors < 244)
{ {
req->nr_sectors += count; req->nr_sectors += count;
bh->b_reqnext = req->bh; bh->b_reqnext = req->bh;
req->buffer = bh->b_data; req->buffer = bh->b_data;
req->current_nr_sectors = count; req->current_nr_sectors = count;
req->sector = sector; req->sector = sector;
bh->b_dirt = 0; mark_buffer_clean(bh);
req->bh = bh; req->bh = bh;
sti(); sti();
return; return;
......
/* fdomain.c -- Future Domain TMC-16x0 SCSI driver /* fdomain.c -- Future Domain TMC-16x0 SCSI driver
* Created: Sun May 3 18:53:19 1992 by faith@cs.unc.edu * Created: Sun May 3 18:53:19 1992 by faith@cs.unc.edu
* Revised: Fri Apr 1 23:47:55 1994 by faith@cs.unc.edu * Revised: Thu Apr 7 20:30:09 1994 by faith@cs.unc.edu
* Author: Rickard E. Faith, faith@cs.unc.edu * Author: Rickard E. Faith, faith@cs.unc.edu
* Copyright 1992, 1993, 1994 Rickard E. Faith * Copyright 1992, 1993, 1994 Rickard E. Faith
* *
* $Id: fdomain.c,v 5.15 1994/04/02 04:48:04 root Exp $ * $Id: fdomain.c,v 5.16 1994/04/08 00:30:15 root Exp $
* This program is free software; you can redistribute it and/or modify it * This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the * under the terms of the GNU General Public License as published by the
...@@ -168,7 +168,7 @@ ...@@ -168,7 +168,7 @@
#include <linux/string.h> #include <linux/string.h>
#include <linux/ioport.h> #include <linux/ioport.h>
#define VERSION "$Revision: 5.15 $" #define VERSION "$Revision: 5.16 $"
/* START OF USER DEFINABLE OPTIONS */ /* START OF USER DEFINABLE OPTIONS */
...@@ -282,6 +282,9 @@ static int TMC_Status_port; ...@@ -282,6 +282,9 @@ static int TMC_Status_port;
static int Write_FIFO_port; static int Write_FIFO_port;
static int Write_SCSI_Data_port; static int Write_SCSI_Data_port;
static int FIFO_Size = 0x2000; /* 8k FIFO for
pre-tmc18c30 chips */
extern void fdomain_16x0_intr( int unused ); extern void fdomain_16x0_intr( int unused );
static void *addresses[] = { static void *addresses[] = {
...@@ -421,7 +424,10 @@ static int fdomain_is_valid_port( int port ) ...@@ -421,7 +424,10 @@ static int fdomain_is_valid_port( int port )
outb( 0x80, port + IO_Control ); outb( 0x80, port + IO_Control );
if (inb( port + Configuration2 ) & 0x80 == 0x80) { if (inb( port + Configuration2 ) & 0x80 == 0x80) {
outb( 0x00, port + IO_Control ); outb( 0x00, port + IO_Control );
if (inb( port + Configuration2 ) & 0x80 == 0x00) chip = tmc18c30; if (inb( port + Configuration2 ) & 0x80 == 0x00) {
chip = tmc18c30;
FIFO_Size = 0x800; /* 2k FIFO */
}
} }
#else #else
...@@ -429,7 +435,10 @@ static int fdomain_is_valid_port( int port ) ...@@ -429,7 +435,10 @@ static int fdomain_is_valid_port( int port )
have problems. Lets assume it is an have problems. Lets assume it is an
18c30 if the RAM is disabled. */ 18c30 if the RAM is disabled. */
if (inb( port + Configuration2 ) & 0x02) chip = tmc18c30; if (inb( port + Configuration2 ) & 0x02) {
chip = tmc18c30;
FIFO_Size = 0x800; /* 2k FIFO */
}
#endif #endif
/* If that failed, we are an 18c50. */ /* If that failed, we are an 18c50. */
} }
...@@ -1127,7 +1136,7 @@ void fdomain_16x0_intr( int unused ) ...@@ -1127,7 +1136,7 @@ void fdomain_16x0_intr( int unused )
} }
if (current_SC->SCp.have_data_in == -1) { /* DATA OUT */ if (current_SC->SCp.have_data_in == -1) { /* DATA OUT */
while ( (data_count = 0x2000 - inw( FIFO_Data_Count_port )) > 512 ) { while ( (data_count = FIFO_Size - inw( FIFO_Data_Count_port )) > 512 ) {
#if EVERY_ACCESS #if EVERY_ACCESS
printk( "DC=%d, ", data_count ) ; printk( "DC=%d, ", data_count ) ;
#endif #endif
......
...@@ -14,13 +14,18 @@ ...@@ -14,13 +14,18 @@
extern int *blk_size[]; extern int *blk_size[];
extern int *blksize_size[]; extern int *blksize_size[];
#define NBUF 64
int block_write(struct inode * inode, struct file * filp, char * buf, int count) int block_write(struct inode * inode, struct file * filp, char * buf, int count)
{ {
int blocksize, blocksize_bits, i; int blocksize, blocksize_bits, i, j;
int block; int block, blocks;
int offset; int offset;
int chars; int chars;
int written = 0; int written = 0;
int cluster_list[4];
struct buffer_head * bhlist[NBUF];
int blocks_per_cluster;
unsigned int size; unsigned int size;
unsigned int dev; unsigned int dev;
struct buffer_head * bh; struct buffer_head * bh;
...@@ -38,6 +43,8 @@ int block_write(struct inode * inode, struct file * filp, char * buf, int count) ...@@ -38,6 +43,8 @@ int block_write(struct inode * inode, struct file * filp, char * buf, int count)
i >>= 1; i >>= 1;
} }
blocks_per_cluster = PAGE_SIZE / blocksize;
block = filp->f_pos >> blocksize_bits; block = filp->f_pos >> blocksize_bits;
offset = filp->f_pos & (blocksize-1); offset = filp->f_pos & (blocksize-1);
...@@ -51,11 +58,50 @@ int block_write(struct inode * inode, struct file * filp, char * buf, int count) ...@@ -51,11 +58,50 @@ int block_write(struct inode * inode, struct file * filp, char * buf, int count)
chars = blocksize - offset; chars = blocksize - offset;
if (chars > count) if (chars > count)
chars=count; chars=count;
#if 0
if (chars == blocksize) if (chars == blocksize)
bh = getblk(dev, block, blocksize); bh = getblk(dev, block, blocksize);
else else
bh = breada(dev, block, blocksize, offset, bh = breada(dev,block,block+1,block+2,-1);
size << blocksize_bits);
#else
for(i=0; i<blocks_per_cluster; i++) cluster_list[i] = block+i;
if((block % blocks_per_cluster) == 0)
generate_cluster(dev, cluster_list, blocksize);
bh = getblk(dev, block, blocksize);
if (chars != blocksize && !bh->b_uptodate) {
if(!filp->f_reada ||
!read_ahead[MAJOR(dev)]) {
/* We do this to force the read of a single buffer */
brelse(bh);
bh = bread(dev,block,blocksize);
} else {
/* Read-ahead before write */
blocks = read_ahead[MAJOR(dev)] / (blocksize >> 9) / 2;
if (block + blocks > size) blocks = size - block;
if (blocks > NBUF) blocks=NBUF;
blocks -= (block % blocks_per_cluster);
if(!blocks) blocks = 1;
bhlist[0] = bh;
for(i=1; i<blocks; i++){
if(((i+block) % blocks_per_cluster) == 0) {
for(j=0; j<blocks_per_cluster; j++) cluster_list[j] = block+i+j;
generate_cluster(dev, cluster_list, blocksize);
};
bhlist[i] = getblk (dev, block+i, blocksize);
if(!bhlist[i]){
while(i >= 0) brelse(bhlist[i--]);
return written? written: -EIO;
};
};
ll_rw_block(READ, blocks, bhlist);
for(i=1; i<blocks; i++) brelse(bhlist[i]);
};
};
#endif
block++; block++;
if (!bh) if (!bh)
return written?written:-EIO; return written?written:-EIO;
...@@ -68,23 +114,23 @@ int block_write(struct inode * inode, struct file * filp, char * buf, int count) ...@@ -68,23 +114,23 @@ int block_write(struct inode * inode, struct file * filp, char * buf, int count)
p += chars; p += chars;
buf += chars; buf += chars;
bh->b_uptodate = 1; bh->b_uptodate = 1;
dirtify_buffer(bh, 0); mark_buffer_dirty(bh, 0);
brelse(bh); brelse(bh);
} }
filp->f_reada = 1;
return written; return written;
} }
#define NBUF 32
int block_read(struct inode * inode, struct file * filp, char * buf, int count) int block_read(struct inode * inode, struct file * filp, char * buf, int count)
{ {
unsigned int block; unsigned int block;
unsigned int offset; unsigned int offset;
int blocksize; int blocksize;
int blocksize_bits, i; int blocksize_bits, i;
unsigned int left; unsigned int blocks, rblocks, left;
unsigned int blocks;
int bhrequest, uptodate; int bhrequest, uptodate;
int cluster_list[4];
int blocks_per_cluster;
struct buffer_head ** bhb, ** bhe; struct buffer_head ** bhb, ** bhe;
struct buffer_head * buflist[NBUF]; struct buffer_head * buflist[NBUF];
struct buffer_head * bhreq[NBUF]; struct buffer_head * bhreq[NBUF];
...@@ -110,6 +156,8 @@ int block_read(struct inode * inode, struct file * filp, char * buf, int count) ...@@ -110,6 +156,8 @@ int block_read(struct inode * inode, struct file * filp, char * buf, int count)
else else
size = INT_MAX; size = INT_MAX;
blocks_per_cluster = PAGE_SIZE / blocksize;
if (offset > size) if (offset > size)
left = 0; left = 0;
else else
...@@ -122,12 +170,16 @@ int block_read(struct inode * inode, struct file * filp, char * buf, int count) ...@@ -122,12 +170,16 @@ int block_read(struct inode * inode, struct file * filp, char * buf, int count)
block = offset >> blocksize_bits; block = offset >> blocksize_bits;
offset &= blocksize-1; offset &= blocksize-1;
size >>= blocksize_bits; size >>= blocksize_bits;
blocks = (left + offset + blocksize - 1) >> blocksize_bits; rblocks = blocks = (left + offset + blocksize - 1) >> blocksize_bits;
bhb = bhe = buflist; bhb = bhe = buflist;
if (filp->f_reada) { if (filp->f_reada) {
blocks += read_ahead[MAJOR(dev)] / (blocksize >> 9); if(blocks < read_ahead[MAJOR(dev)] / (blocksize >> 9))
blocks = read_ahead[MAJOR(dev)] / (blocksize >> 9);
if (block + blocks > size) if (block + blocks > size)
blocks = size - block; blocks = size - block;
blocks -= (block % blocks_per_cluster);
if(rblocks > blocks) blocks = rblocks;
} }
/* We do this in a two stage process. We first try and request /* We do this in a two stage process. We first try and request
...@@ -145,6 +197,12 @@ int block_read(struct inode * inode, struct file * filp, char * buf, int count) ...@@ -145,6 +197,12 @@ int block_read(struct inode * inode, struct file * filp, char * buf, int count)
uptodate = 1; uptodate = 1;
while (blocks) { while (blocks) {
--blocks; --blocks;
#if 1
if((block % blocks_per_cluster) == 0) {
for(i=0; i<blocks_per_cluster; i++) cluster_list[i] = block+i;
generate_cluster(dev, cluster_list, blocksize);
}
#endif
*bhb = getblk(dev, block++, blocksize); *bhb = getblk(dev, block++, blocksize);
if (*bhb && !(*bhb)->b_uptodate) { if (*bhb && !(*bhb)->b_uptodate) {
uptodate = 0; uptodate = 0;
...@@ -163,8 +221,10 @@ int block_read(struct inode * inode, struct file * filp, char * buf, int count) ...@@ -163,8 +221,10 @@ int block_read(struct inode * inode, struct file * filp, char * buf, int count)
} }
/* Now request them all */ /* Now request them all */
if (bhrequest) if (bhrequest) {
ll_rw_block(READ, bhrequest, bhreq); ll_rw_block(READ, bhrequest, bhreq);
refill_freelist(blocksize);
}
do { /* Finish off all I/O that has actually completed */ do { /* Finish off all I/O that has actually completed */
if (*bhe) { if (*bhe) {
......
This diff is collapsed.
...@@ -28,6 +28,26 @@ static struct device_struct blkdevs[MAX_BLKDEV] = { ...@@ -28,6 +28,26 @@ static struct device_struct blkdevs[MAX_BLKDEV] = {
{ NULL, NULL }, { NULL, NULL },
}; };
int get_device_list(char * page)
{
int i;
int len;
len = sprintf(page, "Character devices:\n");
for (i = 0; i < MAX_CHRDEV ; i++) {
if (chrdevs[i].fops) {
len += sprintf(page+len, "%2d %s\n", i, chrdevs[i].name);
}
}
len += sprintf(page+len, "\nBlock devices:\n");
for (i = 0; i < MAX_BLKDEV ; i++) {
if (blkdevs[i].fops) {
len += sprintf(page+len, "%2d %s\n", i, blkdevs[i].name);
}
}
return len;
}
struct file_operations * get_blkfops(unsigned int major) struct file_operations * get_blkfops(unsigned int major)
{ {
if (major >= MAX_BLKDEV) if (major >= MAX_BLKDEV)
......
...@@ -248,7 +248,7 @@ static int ext_file_write(struct inode * inode, struct file * filp, char * buf, ...@@ -248,7 +248,7 @@ static int ext_file_write(struct inode * inode, struct file * filp, char * buf,
memcpy_fromfs(p,buf,c); memcpy_fromfs(p,buf,c);
buf += c; buf += c;
bh->b_uptodate = 1; bh->b_uptodate = 1;
dirtify_buffer(bh, 0); mark_buffer_dirty(bh, 0);
brelse(bh); brelse(bh);
} }
inode->i_mtime = inode->i_ctime = CURRENT_TIME; inode->i_mtime = inode->i_ctime = CURRENT_TIME;
......
...@@ -83,7 +83,7 @@ printk("ext_free_block: block full, skipping to %d\n", block); ...@@ -83,7 +83,7 @@ printk("ext_free_block: block full, skipping to %d\n", block);
} }
sb->u.ext_sb.s_freeblockscount ++; sb->u.ext_sb.s_freeblockscount ++;
sb->s_dirt = 1; sb->s_dirt = 1;
dirtify_buffer(sb->u.ext_sb.s_firstfreeblock, 1); mark_buffer_dirty(sb->u.ext_sb.s_firstfreeblock, 1);
unlock_super (sb); unlock_super (sb);
return; return;
} }
...@@ -104,7 +104,7 @@ int ext_new_block(struct super_block * sb) ...@@ -104,7 +104,7 @@ int ext_new_block(struct super_block * sb)
efb = (struct ext_free_block *) sb->u.ext_sb.s_firstfreeblock->b_data; efb = (struct ext_free_block *) sb->u.ext_sb.s_firstfreeblock->b_data;
if (efb->count) { if (efb->count) {
j = efb->free[--efb->count]; j = efb->free[--efb->count];
dirtify_buffer(sb->u.ext_sb.s_firstfreeblock, 1); mark_buffer_dirty(sb->u.ext_sb.s_firstfreeblock, 1);
} else { } else {
#ifdef EXTFS_DEBUG #ifdef EXTFS_DEBUG
printk("ext_new_block: block empty, skipping to %d\n", efb->next); printk("ext_new_block: block empty, skipping to %d\n", efb->next);
...@@ -135,7 +135,7 @@ printk("ext_new_block: block empty, skipping to %d\n", efb->next); ...@@ -135,7 +135,7 @@ printk("ext_new_block: block empty, skipping to %d\n", efb->next);
} }
clear_block(bh->b_data); clear_block(bh->b_data);
bh->b_uptodate = 1; bh->b_uptodate = 1;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
#ifdef EXTFS_DEBUG #ifdef EXTFS_DEBUG
printk("ext_new_block: allocating block %d\n", j); printk("ext_new_block: allocating block %d\n", j);
...@@ -239,7 +239,7 @@ printk("ext_free_inode: inode full, skipping to %d\n", ino); ...@@ -239,7 +239,7 @@ printk("ext_free_inode: inode full, skipping to %d\n", ino);
} }
sb->u.ext_sb.s_freeinodescount ++; sb->u.ext_sb.s_freeinodescount ++;
sb->s_dirt = 1; sb->s_dirt = 1;
dirtify_buffer(sb->u.ext_sb.s_firstfreeinodeblock, 1); mark_buffer_dirty(sb->u.ext_sb.s_firstfreeinodeblock, 1);
unlock_super (sb); unlock_super (sb);
} }
...@@ -263,7 +263,7 @@ struct inode * ext_new_inode(const struct inode * dir) ...@@ -263,7 +263,7 @@ struct inode * ext_new_inode(const struct inode * dir)
(sb->u.ext_sb.s_firstfreeinodenumber-1)%EXT_INODES_PER_BLOCK; (sb->u.ext_sb.s_firstfreeinodenumber-1)%EXT_INODES_PER_BLOCK;
if (efi->count) { if (efi->count) {
j = efi->free[--efi->count]; j = efi->free[--efi->count];
dirtify_buffer(sb->u.ext_sb.s_firstfreeinodeblock, 1); mark_buffer_dirty(sb->u.ext_sb.s_firstfreeinodeblock, 1);
} else { } else {
#ifdef EXTFS_DEBUG #ifdef EXTFS_DEBUG
printk("ext_free_inode: inode empty, skipping to %d\n", efi->next); printk("ext_free_inode: inode empty, skipping to %d\n", efi->next);
......
...@@ -139,7 +139,7 @@ void ext_write_super (struct super_block *sb) ...@@ -139,7 +139,7 @@ void ext_write_super (struct super_block *sb)
es->s_freeblockscount = sb->u.ext_sb.s_freeblockscount; es->s_freeblockscount = sb->u.ext_sb.s_freeblockscount;
es->s_firstfreeinode = sb->u.ext_sb.s_firstfreeinodenumber; es->s_firstfreeinode = sb->u.ext_sb.s_firstfreeinodenumber;
es->s_freeinodescount = sb->u.ext_sb.s_freeinodescount; es->s_freeinodescount = sb->u.ext_sb.s_freeinodescount;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse (bh); brelse (bh);
sb->s_dirt = 0; sb->s_dirt = 0;
} }
...@@ -296,7 +296,7 @@ static struct buffer_head * block_getblk(struct inode * inode, ...@@ -296,7 +296,7 @@ static struct buffer_head * block_getblk(struct inode * inode,
goto repeat; goto repeat;
} }
*p = tmp; *p = tmp;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
return result; return result;
} }
...@@ -407,7 +407,7 @@ static struct buffer_head * ext_update_inode(struct inode * inode) ...@@ -407,7 +407,7 @@ static struct buffer_head * ext_update_inode(struct inode * inode)
raw_inode->i_zone[0] = inode->i_rdev; raw_inode->i_zone[0] = inode->i_rdev;
else for (block = 0; block < 12; block++) else for (block = 0; block < 12; block++)
raw_inode->i_zone[block] = inode->u.ext_i.i_data[block]; raw_inode->i_zone[block] = inode->u.ext_i.i_data[block];
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
inode->i_dirt=0; inode->i_dirt=0;
return bh; return bh;
} }
......
...@@ -249,7 +249,7 @@ printk ("ext_add_entry: skipping to next block\n"); ...@@ -249,7 +249,7 @@ printk ("ext_add_entry: skipping to next block\n");
#if 0 #if 0
dir->i_ctime = CURRENT_TIME; dir->i_ctime = CURRENT_TIME;
#endif #endif
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
} }
brelse (bh); brelse (bh);
bh = NULL; bh = NULL;
...@@ -296,7 +296,7 @@ printk ("ext_add_entry : creating next block\n"); ...@@ -296,7 +296,7 @@ printk ("ext_add_entry : creating next block\n");
de->name_len = namelen; de->name_len = namelen;
for (i=0; i < namelen ; i++) for (i=0; i < namelen ; i++)
de->name[i] = name[i]; de->name[i] = name[i];
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
*res_dir = de; *res_dir = de;
return bh; return bh;
} }
...@@ -334,7 +334,7 @@ int ext_create(struct inode * dir,const char * name, int len, int mode, ...@@ -334,7 +334,7 @@ int ext_create(struct inode * dir,const char * name, int len, int mode,
return -ENOSPC; return -ENOSPC;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
*result = inode; *result = inode;
...@@ -393,7 +393,7 @@ int ext_mknod(struct inode * dir, const char * name, int len, int mode, int rdev ...@@ -393,7 +393,7 @@ int ext_mknod(struct inode * dir, const char * name, int len, int mode, int rdev
return -ENOSPC; return -ENOSPC;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
iput(inode); iput(inode);
...@@ -445,7 +445,7 @@ int ext_mkdir(struct inode * dir, const char * name, int len, int mode) ...@@ -445,7 +445,7 @@ int ext_mkdir(struct inode * dir, const char * name, int len, int mode)
de->name_len=2; de->name_len=2;
strcpy(de->name,".."); strcpy(de->name,"..");
inode->i_nlink = 2; inode->i_nlink = 2;
dirtify_buffer(dir_block, 1); mark_buffer_dirty(dir_block, 1);
brelse(dir_block); brelse(dir_block);
inode->i_mode = S_IFDIR | (mode & 0777 & ~current->umask); inode->i_mode = S_IFDIR | (mode & 0777 & ~current->umask);
if (dir->i_mode & S_ISGID) if (dir->i_mode & S_ISGID)
...@@ -459,7 +459,7 @@ int ext_mkdir(struct inode * dir, const char * name, int len, int mode) ...@@ -459,7 +459,7 @@ int ext_mkdir(struct inode * dir, const char * name, int len, int mode)
return -ENOSPC; return -ENOSPC;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
dir->i_nlink++; dir->i_nlink++;
dir->i_dirt = 1; dir->i_dirt = 1;
iput(dir); iput(dir);
...@@ -567,7 +567,7 @@ int ext_rmdir(struct inode * dir, const char * name, int len) ...@@ -567,7 +567,7 @@ int ext_rmdir(struct inode * dir, const char * name, int len)
de->inode = 0; de->inode = 0;
de->name_len = 0; de->name_len = 0;
ext_merge_entries (de, pde, nde); ext_merge_entries (de, pde, nde);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
inode->i_nlink=0; inode->i_nlink=0;
inode->i_dirt=1; inode->i_dirt=1;
dir->i_nlink--; dir->i_nlink--;
...@@ -610,7 +610,7 @@ int ext_unlink(struct inode * dir, const char * name, int len) ...@@ -610,7 +610,7 @@ int ext_unlink(struct inode * dir, const char * name, int len)
de->inode = 0; de->inode = 0;
de->name_len = 0; de->name_len = 0;
ext_merge_entries (de, pde, nde); ext_merge_entries (de, pde, nde);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
inode->i_nlink--; inode->i_nlink--;
inode->i_dirt = 1; inode->i_dirt = 1;
inode->i_ctime = CURRENT_TIME; inode->i_ctime = CURRENT_TIME;
...@@ -650,7 +650,7 @@ int ext_symlink(struct inode * dir, const char * name, int len, const char * sym ...@@ -650,7 +650,7 @@ int ext_symlink(struct inode * dir, const char * name, int len, const char * sym
while (i < 1023 && (c = *(symname++))) while (i < 1023 && (c = *(symname++)))
name_block->b_data[i++] = c; name_block->b_data[i++] = c;
name_block->b_data[i] = 0; name_block->b_data[i] = 0;
dirtify_buffer(name_block, 1); mark_buffer_dirty(name_block, 1);
brelse(name_block); brelse(name_block);
inode->i_size = i; inode->i_size = i;
inode->i_dirt = 1; inode->i_dirt = 1;
...@@ -672,7 +672,7 @@ int ext_symlink(struct inode * dir, const char * name, int len, const char * sym ...@@ -672,7 +672,7 @@ int ext_symlink(struct inode * dir, const char * name, int len, const char * sym
return -ENOSPC; return -ENOSPC;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
iput(inode); iput(inode);
...@@ -708,7 +708,7 @@ int ext_link(struct inode * oldinode, struct inode * dir, const char * name, int ...@@ -708,7 +708,7 @@ int ext_link(struct inode * oldinode, struct inode * dir, const char * name, int
return -ENOSPC; return -ENOSPC;
} }
de->inode = oldinode->i_ino; de->inode = oldinode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
oldinode->i_nlink++; oldinode->i_nlink++;
...@@ -851,11 +851,11 @@ static int do_ext_rename(struct inode * old_dir, const char * old_name, int old_ ...@@ -851,11 +851,11 @@ static int do_ext_rename(struct inode * old_dir, const char * old_name, int old_
new_inode->i_nlink--; new_inode->i_nlink--;
new_inode->i_dirt = 1; new_inode->i_dirt = 1;
} }
dirtify_buffer(old_bh, 1); mark_buffer_dirty(old_bh, 1);
dirtify_buffer(new_bh, 1); mark_buffer_dirty(new_bh, 1);
if (dir_bh) { if (dir_bh) {
PARENT_INO(dir_bh->b_data) = new_dir->i_ino; PARENT_INO(dir_bh->b_data) = new_dir->i_ino;
dirtify_buffer(dir_bh, 1); mark_buffer_dirty(dir_bh, 1);
old_dir->i_nlink--; old_dir->i_nlink--;
new_dir->i_nlink++; new_dir->i_nlink++;
old_dir->i_dirt = 1; old_dir->i_dirt = 1;
......
...@@ -102,7 +102,7 @@ static int trunc_indirect(struct inode * inode, int offset, unsigned long * p) ...@@ -102,7 +102,7 @@ static int trunc_indirect(struct inode * inode, int offset, unsigned long * p)
continue; continue;
} }
*ind = 0; *ind = 0;
dirtify_buffer(ind_bh, 1); mark_buffer_dirty(ind_bh, 1);
brelse(bh); brelse(bh);
ext_free_block(inode->i_sb,tmp); ext_free_block(inode->i_sb,tmp);
} }
...@@ -154,7 +154,7 @@ static int trunc_dindirect(struct inode * inode, int offset, unsigned long * p) ...@@ -154,7 +154,7 @@ static int trunc_dindirect(struct inode * inode, int offset, unsigned long * p)
if (!tmp) if (!tmp)
continue; continue;
retry |= trunc_indirect(inode,offset+(i<<8),dind); retry |= trunc_indirect(inode,offset+(i<<8),dind);
dirtify_buffer(dind_bh, 1); mark_buffer_dirty(dind_bh, 1);
} }
dind = (unsigned long *) dind_bh->b_data; dind = (unsigned long *) dind_bh->b_data;
for (i = 0; i < 256; i++) for (i = 0; i < 256; i++)
...@@ -201,7 +201,7 @@ static int trunc_tindirect(struct inode * inode) ...@@ -201,7 +201,7 @@ static int trunc_tindirect(struct inode * inode)
goto repeat; goto repeat;
tind = i+(unsigned long *) tind_bh->b_data; tind = i+(unsigned long *) tind_bh->b_data;
retry |= trunc_dindirect(inode,9+256+256*256+(i<<16),tind); retry |= trunc_dindirect(inode,9+256+256*256+(i<<16),tind);
dirtify_buffer(tind_bh, 1); mark_buffer_dirty(tind_bh, 1);
} }
tind = (unsigned long *) tind_bh->b_data; tind = (unsigned long *) tind_bh->b_data;
for (i = 0; i < 256; i++) for (i = 0; i < 256; i++)
......
...@@ -310,10 +310,10 @@ void ext2_free_blocks (struct super_block * sb, unsigned long block, ...@@ -310,10 +310,10 @@ void ext2_free_blocks (struct super_block * sb, unsigned long block,
} }
} }
dirtify_buffer(bh2, 1); mark_buffer_dirty(bh2, 1);
dirtify_buffer(sb->u.ext2_sb.s_sbh, 1); mark_buffer_dirty(sb->u.ext2_sb.s_sbh, 1);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (sb->s_flags & MS_SYNC) { if (sb->s_flags & MS_SYNC) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -524,7 +524,7 @@ int ext2_new_block (struct super_block * sb, unsigned long goal, ...@@ -524,7 +524,7 @@ int ext2_new_block (struct super_block * sb, unsigned long goal,
j = tmp; j = tmp;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (sb->s_flags & MS_SYNC) { if (sb->s_flags & MS_SYNC) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -544,16 +544,16 @@ int ext2_new_block (struct super_block * sb, unsigned long goal, ...@@ -544,16 +544,16 @@ int ext2_new_block (struct super_block * sb, unsigned long goal,
} }
clear_block (bh->b_data, sb->s_blocksize); clear_block (bh->b_data, sb->s_blocksize);
bh->b_uptodate = 1; bh->b_uptodate = 1;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse (bh); brelse (bh);
ext2_debug ("allocating block %d. " ext2_debug ("allocating block %d. "
"Goal hits %d of %d.\n", j, goal_hits, goal_attempts); "Goal hits %d of %d.\n", j, goal_hits, goal_attempts);
gdp->bg_free_blocks_count--; gdp->bg_free_blocks_count--;
dirtify_buffer(bh2, 1); mark_buffer_dirty(bh2, 1);
es->s_free_blocks_count--; es->s_free_blocks_count--;
dirtify_buffer(sb->u.ext2_sb.s_sbh, 1); mark_buffer_dirty(sb->u.ext2_sb.s_sbh, 1);
sb->s_dirt = 1; sb->s_dirt = 1;
unlock_super (sb); unlock_super (sb);
return j; return j;
......
...@@ -78,6 +78,7 @@ static int ext2_file_read (struct inode * inode, struct file * filp, ...@@ -78,6 +78,7 @@ static int ext2_file_read (struct inode * inode, struct file * filp,
int read, left, chars; int read, left, chars;
int block, blocks, offset; int block, blocks, offset;
int bhrequest, uptodate; int bhrequest, uptodate;
int clusterblocks;
struct buffer_head ** bhb, ** bhe; struct buffer_head ** bhb, ** bhe;
struct buffer_head * bhreq[NBUF]; struct buffer_head * bhreq[NBUF];
struct buffer_head * buflist[NBUF]; struct buffer_head * buflist[NBUF];
...@@ -130,11 +131,18 @@ static int ext2_file_read (struct inode * inode, struct file * filp, ...@@ -130,11 +131,18 @@ static int ext2_file_read (struct inode * inode, struct file * filp,
* buffers and caches. * buffers and caches.
*/ */
clusterblocks = 0;
do { do {
bhrequest = 0; bhrequest = 0;
uptodate = 1; uptodate = 1;
while (blocks) { while (blocks) {
--blocks; --blocks;
#if 1
if(!clusterblocks) clusterblocks = ext2_getcluster(inode, block);
if(clusterblocks) clusterblocks--;
#endif
*bhb = ext2_getblk (inode, block++, 0, &err); *bhb = ext2_getblk (inode, block++, 0, &err);
if (*bhb && !(*bhb)->b_uptodate) { if (*bhb && !(*bhb)->b_uptodate) {
uptodate = 0; uptodate = 0;
...@@ -277,7 +285,7 @@ static int ext2_file_write (struct inode * inode, struct file * filp, ...@@ -277,7 +285,7 @@ static int ext2_file_write (struct inode * inode, struct file * filp,
memcpy_fromfs (p, buf, c); memcpy_fromfs (p, buf, c);
buf += c; buf += c;
bh->b_uptodate = 1; bh->b_uptodate = 1;
dirtify_buffer(bh, 0); mark_buffer_dirty(bh, 0);
brelse (bh); brelse (bh);
} }
up(&inode->i_sem); up(&inode->i_sem);
......
...@@ -202,7 +202,7 @@ static void set_inode_dtime (struct inode * inode, ...@@ -202,7 +202,7 @@ static void set_inode_dtime (struct inode * inode,
EXT2_INODES_PER_BLOCK(inode->i_sb)); EXT2_INODES_PER_BLOCK(inode->i_sb));
raw_inode->i_links_count = 0; raw_inode->i_links_count = 0;
raw_inode->i_dtime = CURRENT_TIME; raw_inode->i_dtime = CURRENT_TIME;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (IS_SYNC(inode)) { if (IS_SYNC(inode)) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -266,12 +266,12 @@ void ext2_free_inode (struct inode * inode) ...@@ -266,12 +266,12 @@ void ext2_free_inode (struct inode * inode)
gdp->bg_free_inodes_count++; gdp->bg_free_inodes_count++;
if (S_ISDIR(inode->i_mode)) if (S_ISDIR(inode->i_mode))
gdp->bg_used_dirs_count--; gdp->bg_used_dirs_count--;
dirtify_buffer(bh2, 1); mark_buffer_dirty(bh2, 1);
es->s_free_inodes_count++; es->s_free_inodes_count++;
dirtify_buffer(sb->u.ext2_sb.s_sbh, 1); mark_buffer_dirty(sb->u.ext2_sb.s_sbh, 1);
set_inode_dtime (inode, gdp); set_inode_dtime (inode, gdp);
} }
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (sb->s_flags & MS_SYNC) { if (sb->s_flags & MS_SYNC) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -313,7 +313,7 @@ static void inc_inode_version (struct inode * inode, ...@@ -313,7 +313,7 @@ static void inc_inode_version (struct inode * inode,
EXT2_INODES_PER_BLOCK(inode->i_sb)); EXT2_INODES_PER_BLOCK(inode->i_sb));
raw_inode->i_version++; raw_inode->i_version++;
inode->u.ext2_i.i_version = raw_inode->i_version; inode->u.ext2_i.i_version = raw_inode->i_version;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse (bh); brelse (bh);
} }
...@@ -438,7 +438,7 @@ struct inode * ext2_new_inode (const struct inode * dir, int mode) ...@@ -438,7 +438,7 @@ struct inode * ext2_new_inode (const struct inode * dir, int mode)
"bit already set for inode %d", j); "bit already set for inode %d", j);
goto repeat; goto repeat;
} }
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (sb->s_flags & MS_SYNC) { if (sb->s_flags & MS_SYNC) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -466,9 +466,9 @@ struct inode * ext2_new_inode (const struct inode * dir, int mode) ...@@ -466,9 +466,9 @@ struct inode * ext2_new_inode (const struct inode * dir, int mode)
gdp->bg_free_inodes_count--; gdp->bg_free_inodes_count--;
if (S_ISDIR(mode)) if (S_ISDIR(mode))
gdp->bg_used_dirs_count++; gdp->bg_used_dirs_count++;
dirtify_buffer(bh2, 1); mark_buffer_dirty(bh2, 1);
es->s_free_inodes_count--; es->s_free_inodes_count--;
dirtify_buffer(sb->u.ext2_sb.s_sbh, 1); mark_buffer_dirty(sb->u.ext2_sb.s_sbh, 1);
sb->s_dirt = 1; sb->s_dirt = 1;
inode->i_mode = mode; inode->i_mode = mode;
inode->i_sb = sb; inode->i_sb = sb;
......
...@@ -109,7 +109,7 @@ static int ext2_alloc_block (struct inode * inode, unsigned long goal) ...@@ -109,7 +109,7 @@ static int ext2_alloc_block (struct inode * inode, unsigned long goal)
} }
clear_block (bh->b_data, inode->i_sb->s_blocksize); clear_block (bh->b_data, inode->i_sb->s_blocksize);
bh->b_uptodate = 1; bh->b_uptodate = 1;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse (bh); brelse (bh);
} else { } else {
ext2_discard_prealloc (inode); ext2_discard_prealloc (inode);
...@@ -314,7 +314,7 @@ static struct buffer_head * block_getblk (struct inode * inode, ...@@ -314,7 +314,7 @@ static struct buffer_head * block_getblk (struct inode * inode,
goto repeat; goto repeat;
} }
*p = tmp; *p = tmp;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (IS_SYNC(inode)) { if (IS_SYNC(inode)) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -328,6 +328,41 @@ static struct buffer_head * block_getblk (struct inode * inode, ...@@ -328,6 +328,41 @@ static struct buffer_head * block_getblk (struct inode * inode,
return result; return result;
} }
static int block_getcluster (struct inode * inode, struct buffer_head * bh,
int nr,
int blocksize)
{
unsigned long * p;
int firstblock = 0;
int result = 0;
int i;
/* Check to see if clustering possible here. */
if(!bh) return 0;
if(nr % (PAGE_SIZE / inode->i_sb->s_blocksize) != 0) goto out;
if(nr + 3 > EXT2_ADDR_PER_BLOCK(inode->i_sb)) goto out;
for(i=0; i< (PAGE_SIZE / inode->i_sb->s_blocksize); i++) {
p = (unsigned long *) bh->b_data + nr + i;
/* All blocks in cluster must already be allocated */
if(*p == 0) goto out;
/* See if aligned correctly */
if(i==0) firstblock = *p;
else if(*p != firstblock + i) goto out;
};
p = (unsigned long *) bh->b_data + nr;
result = generate_cluster(bh->b_dev, (int *) p, blocksize);
out:
brelse(bh);
return result;
}
struct buffer_head * ext2_getblk (struct inode * inode, long block, struct buffer_head * ext2_getblk (struct inode * inode, long block,
int create, int * err) int create, int * err)
{ {
...@@ -389,6 +424,55 @@ struct buffer_head * ext2_getblk (struct inode * inode, long block, ...@@ -389,6 +424,55 @@ struct buffer_head * ext2_getblk (struct inode * inode, long block,
inode->i_sb->s_blocksize, b, err); inode->i_sb->s_blocksize, b, err);
} }
int ext2_getcluster (struct inode * inode, long block)
{
struct buffer_head * bh;
int err, create;
unsigned long b;
unsigned long addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb);
create = 0;
err = -EIO;
if (block < 0) {
ext2_warning (inode->i_sb, "ext2_getblk", "block < 0");
return 0;
}
if (block > EXT2_NDIR_BLOCKS + addr_per_block +
addr_per_block * addr_per_block +
addr_per_block * addr_per_block * addr_per_block) {
ext2_warning (inode->i_sb, "ext2_getblk", "block > big");
return 0;
}
err = -ENOSPC;
b = block;
if (block < EXT2_NDIR_BLOCKS) return 0;
block -= EXT2_NDIR_BLOCKS;
if (block < addr_per_block) {
bh = inode_getblk (inode, EXT2_IND_BLOCK, create, b, &err);
return block_getcluster (inode, bh, block,
inode->i_sb->s_blocksize);
}
block -= addr_per_block;
if (block < addr_per_block * addr_per_block) {
bh = inode_getblk (inode, EXT2_DIND_BLOCK, create, b, &err);
bh = block_getblk (inode, bh, block / addr_per_block, create,
inode->i_sb->s_blocksize, b, &err);
return block_getcluster (inode, bh, block & (addr_per_block - 1),
inode->i_sb->s_blocksize);
}
block -= addr_per_block * addr_per_block;
bh = inode_getblk (inode, EXT2_TIND_BLOCK, create, b, &err);
bh = block_getblk (inode, bh, block/(addr_per_block * addr_per_block),
create, inode->i_sb->s_blocksize, b, &err);
bh = block_getblk (inode, bh, (block/addr_per_block) & (addr_per_block - 1),
create, inode->i_sb->s_blocksize, b, &err);
return block_getcluster (inode, bh, block & (addr_per_block - 1),
inode->i_sb->s_blocksize);
}
struct buffer_head * ext2_bread (struct inode * inode, int block, struct buffer_head * ext2_bread (struct inode * inode, int block,
int create, int *err) int create, int *err)
{ {
...@@ -549,7 +633,7 @@ static struct buffer_head * ext2_update_inode (struct inode * inode) ...@@ -549,7 +633,7 @@ static struct buffer_head * ext2_update_inode (struct inode * inode)
raw_inode->i_block[0] = inode->i_rdev; raw_inode->i_block[0] = inode->i_rdev;
else for (block = 0; block < EXT2_N_BLOCKS; block++) else for (block = 0; block < EXT2_N_BLOCKS; block++)
raw_inode->i_block[block] = inode->u.ext2_i.i_data[block]; raw_inode->i_block[block] = inode->u.ext2_i.i_data[block];
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
inode->i_dirt = 0; inode->i_dirt = 0;
return bh; return bh;
} }
......
...@@ -320,7 +320,7 @@ static struct buffer_head * ext2_add_entry (struct inode * dir, ...@@ -320,7 +320,7 @@ static struct buffer_head * ext2_add_entry (struct inode * dir,
*/ */
dir->i_mtime = dir->i_ctime = CURRENT_TIME; dir->i_mtime = dir->i_ctime = CURRENT_TIME;
dir->i_dirt = 1; dir->i_dirt = 1;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
*res_dir = de; *res_dir = de;
*err = 0; *err = 0;
return bh; return bh;
...@@ -394,7 +394,7 @@ int ext2_create (struct inode * dir,const char * name, int len, int mode, ...@@ -394,7 +394,7 @@ int ext2_create (struct inode * dir,const char * name, int len, int mode,
ext2_dcache_add (dir->i_dev, dir->i_ino, de->name, de->name_len, ext2_dcache_add (dir->i_dev, dir->i_ino, de->name, de->name_len,
de->inode); de->inode);
#endif #endif
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (IS_SYNC(dir)) { if (IS_SYNC(dir)) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -460,7 +460,7 @@ int ext2_mknod (struct inode * dir, const char * name, int len, int mode, ...@@ -460,7 +460,7 @@ int ext2_mknod (struct inode * dir, const char * name, int len, int mode,
ext2_dcache_add (dir->i_dev, dir->i_ino, de->name, de->name_len, ext2_dcache_add (dir->i_dev, dir->i_ino, de->name, de->name_len,
de->inode); de->inode);
#endif #endif
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (IS_SYNC(dir)) { if (IS_SYNC(dir)) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -517,7 +517,7 @@ int ext2_mkdir (struct inode * dir, const char * name, int len, int mode) ...@@ -517,7 +517,7 @@ int ext2_mkdir (struct inode * dir, const char * name, int len, int mode)
de->name_len = 2; de->name_len = 2;
strcpy (de->name, ".."); strcpy (de->name, "..");
inode->i_nlink = 2; inode->i_nlink = 2;
dirtify_buffer(dir_block, 1); mark_buffer_dirty(dir_block, 1);
brelse (dir_block); brelse (dir_block);
inode->i_mode = S_IFDIR | (mode & S_IRWXUGO & ~current->umask); inode->i_mode = S_IFDIR | (mode & S_IRWXUGO & ~current->umask);
if (dir->i_mode & S_ISGID) if (dir->i_mode & S_ISGID)
...@@ -536,7 +536,7 @@ int ext2_mkdir (struct inode * dir, const char * name, int len, int mode) ...@@ -536,7 +536,7 @@ int ext2_mkdir (struct inode * dir, const char * name, int len, int mode)
ext2_dcache_add (dir->i_dev, dir->i_ino, de->name, de->name_len, ext2_dcache_add (dir->i_dev, dir->i_ino, de->name, de->name_len,
de->inode); de->inode);
#endif #endif
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (IS_SYNC(dir)) { if (IS_SYNC(dir)) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -660,7 +660,7 @@ int ext2_rmdir (struct inode * dir, const char * name, int len) ...@@ -660,7 +660,7 @@ int ext2_rmdir (struct inode * dir, const char * name, int len)
up(&inode->i_sem); up(&inode->i_sem);
if (retval) if (retval)
goto end_rmdir; goto end_rmdir;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (IS_SYNC(dir)) { if (IS_SYNC(dir)) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -728,7 +728,7 @@ int ext2_unlink (struct inode * dir, const char * name, int len) ...@@ -728,7 +728,7 @@ int ext2_unlink (struct inode * dir, const char * name, int len)
retval = ext2_delete_entry (de, bh); retval = ext2_delete_entry (de, bh);
if (retval) if (retval)
goto end_unlink; goto end_unlink;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (IS_SYNC(dir)) { if (IS_SYNC(dir)) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -793,7 +793,7 @@ int ext2_symlink (struct inode * dir, const char * name, int len, ...@@ -793,7 +793,7 @@ int ext2_symlink (struct inode * dir, const char * name, int len,
link[i++] = c; link[i++] = c;
link[i] = 0; link[i] = 0;
if (name_block) { if (name_block) {
dirtify_buffer(name_block, 1); mark_buffer_dirty(name_block, 1);
brelse (name_block); brelse (name_block);
} }
inode->i_size = i; inode->i_size = i;
...@@ -820,7 +820,7 @@ int ext2_symlink (struct inode * dir, const char * name, int len, ...@@ -820,7 +820,7 @@ int ext2_symlink (struct inode * dir, const char * name, int len,
ext2_dcache_add (dir->i_dev, dir->i_ino, de->name, de->name_len, ext2_dcache_add (dir->i_dev, dir->i_ino, de->name, de->name_len,
de->inode); de->inode);
#endif #endif
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (IS_SYNC(dir)) { if (IS_SYNC(dir)) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -866,7 +866,7 @@ int ext2_link (struct inode * oldinode, struct inode * dir, ...@@ -866,7 +866,7 @@ int ext2_link (struct inode * oldinode, struct inode * dir,
ext2_dcache_add (dir->i_dev, dir->i_ino, de->name, de->name_len, ext2_dcache_add (dir->i_dev, dir->i_ino, de->name, de->name_len,
de->inode); de->inode);
#endif #endif
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if (IS_SYNC(dir)) { if (IS_SYNC(dir)) {
ll_rw_block (WRITE, 1, &bh); ll_rw_block (WRITE, 1, &bh);
wait_on_buffer (bh); wait_on_buffer (bh);
...@@ -1042,19 +1042,19 @@ static int do_ext2_rename (struct inode * old_dir, const char * old_name, ...@@ -1042,19 +1042,19 @@ static int do_ext2_rename (struct inode * old_dir, const char * old_name,
} }
old_dir->i_ctime = old_dir->i_mtime = CURRENT_TIME; old_dir->i_ctime = old_dir->i_mtime = CURRENT_TIME;
old_dir->i_dirt = 1; old_dir->i_dirt = 1;
dirtify_buffer(old_bh, 1); mark_buffer_dirty(old_bh, 1);
if (IS_SYNC(old_dir)) { if (IS_SYNC(old_dir)) {
ll_rw_block (WRITE, 1, &old_bh); ll_rw_block (WRITE, 1, &old_bh);
wait_on_buffer (old_bh); wait_on_buffer (old_bh);
} }
dirtify_buffer(new_bh, 1); mark_buffer_dirty(new_bh, 1);
if (IS_SYNC(new_dir)) { if (IS_SYNC(new_dir)) {
ll_rw_block (WRITE, 1, &new_bh); ll_rw_block (WRITE, 1, &new_bh);
wait_on_buffer (new_bh); wait_on_buffer (new_bh);
} }
if (dir_bh) { if (dir_bh) {
PARENT_INO(dir_bh->b_data) = new_dir->i_ino; PARENT_INO(dir_bh->b_data) = new_dir->i_ino;
dirtify_buffer(dir_bh, 1); mark_buffer_dirty(dir_bh, 1);
old_dir->i_nlink--; old_dir->i_nlink--;
old_dir->i_dirt = 1; old_dir->i_dirt = 1;
if (new_inode) { if (new_inode) {
......
...@@ -36,7 +36,7 @@ void ext2_error (struct super_block * sb, const char * function, ...@@ -36,7 +36,7 @@ void ext2_error (struct super_block * sb, const char * function,
if (!(sb->s_flags & MS_RDONLY)) { if (!(sb->s_flags & MS_RDONLY)) {
sb->u.ext2_sb.s_mount_state |= EXT2_ERROR_FS; sb->u.ext2_sb.s_mount_state |= EXT2_ERROR_FS;
sb->u.ext2_sb.s_es->s_state |= EXT2_ERROR_FS; sb->u.ext2_sb.s_es->s_state |= EXT2_ERROR_FS;
dirtify_buffer(sb->u.ext2_sb.s_sbh, 1); mark_buffer_dirty(sb->u.ext2_sb.s_sbh, 1);
sb->s_dirt = 1; sb->s_dirt = 1;
} }
va_start (args, fmt); va_start (args, fmt);
...@@ -66,7 +66,7 @@ NORET_TYPE void ext2_panic (struct super_block * sb, const char * function, ...@@ -66,7 +66,7 @@ NORET_TYPE void ext2_panic (struct super_block * sb, const char * function,
if (!(sb->s_flags & MS_RDONLY)) { if (!(sb->s_flags & MS_RDONLY)) {
sb->u.ext2_sb.s_mount_state |= EXT2_ERROR_FS; sb->u.ext2_sb.s_mount_state |= EXT2_ERROR_FS;
sb->u.ext2_sb.s_es->s_state |= EXT2_ERROR_FS; sb->u.ext2_sb.s_es->s_state |= EXT2_ERROR_FS;
dirtify_buffer(sb->u.ext2_sb.s_sbh, 1); mark_buffer_dirty(sb->u.ext2_sb.s_sbh, 1);
sb->s_dirt = 1; sb->s_dirt = 1;
} }
va_start (args, fmt); va_start (args, fmt);
...@@ -96,7 +96,7 @@ void ext2_put_super (struct super_block * sb) ...@@ -96,7 +96,7 @@ void ext2_put_super (struct super_block * sb)
lock_super (sb); lock_super (sb);
if (!(sb->s_flags & MS_RDONLY)) { if (!(sb->s_flags & MS_RDONLY)) {
sb->u.ext2_sb.s_es->s_state = sb->u.ext2_sb.s_mount_state; sb->u.ext2_sb.s_es->s_state = sb->u.ext2_sb.s_mount_state;
dirtify_buffer(sb->u.ext2_sb.s_sbh, 1); mark_buffer_dirty(sb->u.ext2_sb.s_sbh, 1);
} }
#ifndef DONT_USE_DCACHE #ifndef DONT_USE_DCACHE
ext2_dcache_invalidate (sb->s_dev); ext2_dcache_invalidate (sb->s_dev);
...@@ -159,10 +159,10 @@ static int convert_pre_02b_fs (struct super_block * sb, ...@@ -159,10 +159,10 @@ static int convert_pre_02b_fs (struct super_block * sb,
gdp[i].bg_free_blocks_count = old_group_desc[i].bg_free_blocks_count; gdp[i].bg_free_blocks_count = old_group_desc[i].bg_free_blocks_count;
gdp[i].bg_free_inodes_count = old_group_desc[i].bg_free_inodes_count; gdp[i].bg_free_inodes_count = old_group_desc[i].bg_free_inodes_count;
} }
dirtify_buffer(bh2, 1); mark_buffer_dirty(bh2, 1);
brelse (bh2); brelse (bh2);
es->s_magic = EXT2_SUPER_MAGIC; es->s_magic = EXT2_SUPER_MAGIC;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
sb->s_magic = EXT2_SUPER_MAGIC; sb->s_magic = EXT2_SUPER_MAGIC;
return 1; return 1;
} }
...@@ -287,7 +287,7 @@ static void ext2_setup_super (struct super_block * sb, ...@@ -287,7 +287,7 @@ static void ext2_setup_super (struct super_block * sb,
es->s_max_mnt_count = EXT2_DFL_MAX_MNT_COUNT; es->s_max_mnt_count = EXT2_DFL_MAX_MNT_COUNT;
es->s_mnt_count++; es->s_mnt_count++;
es->s_mtime = CURRENT_TIME; es->s_mtime = CURRENT_TIME;
dirtify_buffer(sb->u.ext2_sb.s_sbh, 1); mark_buffer_dirty(sb->u.ext2_sb.s_sbh, 1);
sb->s_dirt = 1; sb->s_dirt = 1;
if (test_opt (sb, DEBUG)) if (test_opt (sb, DEBUG))
printk ("[EXT II FS %s, %s, bs=%lu, fs=%lu, gc=%lu, " printk ("[EXT II FS %s, %s, bs=%lu, fs=%lu, gc=%lu, "
...@@ -570,7 +570,7 @@ struct super_block * ext2_read_super (struct super_block * sb, void * data, ...@@ -570,7 +570,7 @@ struct super_block * ext2_read_super (struct super_block * sb, void * data,
#ifdef EXT2FS_PRE_02B_COMPAT #ifdef EXT2FS_PRE_02B_COMPAT
if (fs_converted) { if (fs_converted) {
for (i = 0; i < bh_count; i++) for (i = 0; i < bh_count; i++)
dirtify_buffer(sb->u.ext2_sb.s_group_desc[i], 1); mark_buffer_dirty(sb->u.ext2_sb.s_group_desc[i], 1);
sb->s_dirt = 1; sb->s_dirt = 1;
} }
#endif #endif
...@@ -582,7 +582,7 @@ static void ext2_commit_super (struct super_block * sb, ...@@ -582,7 +582,7 @@ static void ext2_commit_super (struct super_block * sb,
struct ext2_super_block * es) struct ext2_super_block * es)
{ {
es->s_wtime = CURRENT_TIME; es->s_wtime = CURRENT_TIME;
dirtify_buffer(sb->u.ext2_sb.s_sbh, 1); mark_buffer_dirty(sb->u.ext2_sb.s_sbh, 1);
sb->s_dirt = 0; sb->s_dirt = 0;
} }
...@@ -639,7 +639,7 @@ int ext2_remount (struct super_block * sb, int * flags, char * data) ...@@ -639,7 +639,7 @@ int ext2_remount (struct super_block * sb, int * flags, char * data)
*/ */
es->s_state = sb->u.ext2_sb.s_mount_state; es->s_state = sb->u.ext2_sb.s_mount_state;
es->s_mtime = CURRENT_TIME; es->s_mtime = CURRENT_TIME;
dirtify_buffer(sb->u.ext2_sb.s_sbh, 1); mark_buffer_dirty(sb->u.ext2_sb.s_sbh, 1);
sb->s_dirt = 1; sb->s_dirt = 1;
ext2_commit_super (sb, es); ext2_commit_super (sb, es);
} }
......
...@@ -90,7 +90,7 @@ static int trunc_direct (struct inode * inode) ...@@ -90,7 +90,7 @@ static int trunc_direct (struct inode * inode)
if (inode->u.ext2_i.i_flags & EXT2_SECRM_FL) { if (inode->u.ext2_i.i_flags & EXT2_SECRM_FL) {
clear_block (bh->b_data, inode->i_sb->s_blocksize, clear_block (bh->b_data, inode->i_sb->s_blocksize,
RANDOM_INT); RANDOM_INT);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
} }
brelse (bh); brelse (bh);
if (free_count == 0) { if (free_count == 0) {
...@@ -162,11 +162,11 @@ static int trunc_indirect (struct inode * inode, int offset, unsigned long * p) ...@@ -162,11 +162,11 @@ static int trunc_indirect (struct inode * inode, int offset, unsigned long * p)
continue; continue;
} }
*ind = 0; *ind = 0;
dirtify_buffer(ind_bh, 1); mark_buffer_dirty(ind_bh, 1);
if (inode->u.ext2_i.i_flags & EXT2_SECRM_FL) { if (inode->u.ext2_i.i_flags & EXT2_SECRM_FL) {
clear_block (bh->b_data, inode->i_sb->s_blocksize, clear_block (bh->b_data, inode->i_sb->s_blocksize,
RANDOM_INT); RANDOM_INT);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
} }
brelse (bh); brelse (bh);
if (free_count == 0) { if (free_count == 0) {
...@@ -243,7 +243,7 @@ static int trunc_dindirect (struct inode * inode, int offset, ...@@ -243,7 +243,7 @@ static int trunc_dindirect (struct inode * inode, int offset,
continue; continue;
retry |= trunc_indirect (inode, offset + (i * addr_per_block), retry |= trunc_indirect (inode, offset + (i * addr_per_block),
dind); dind);
dirtify_buffer(dind_bh, 1); mark_buffer_dirty(dind_bh, 1);
} }
dind = (unsigned long *) dind_bh->b_data; dind = (unsigned long *) dind_bh->b_data;
for (i = 0; i < addr_per_block; i++) for (i = 0; i < addr_per_block; i++)
...@@ -302,7 +302,7 @@ static int trunc_tindirect (struct inode * inode) ...@@ -302,7 +302,7 @@ static int trunc_tindirect (struct inode * inode)
retry |= trunc_dindirect(inode, EXT2_NDIR_BLOCKS + retry |= trunc_dindirect(inode, EXT2_NDIR_BLOCKS +
addr_per_block + (i + 1) * addr_per_block * addr_per_block, addr_per_block + (i + 1) * addr_per_block * addr_per_block,
tind); tind);
dirtify_buffer(tind_bh, 1); mark_buffer_dirty(tind_bh, 1);
} }
tind = (unsigned long *) tind_bh->b_data; tind = (unsigned long *) tind_bh->b_data;
for (i = 0; i < addr_per_block; i++) for (i = 0; i < addr_per_block; i++)
......
...@@ -93,7 +93,7 @@ void minix_free_block(struct super_block * sb, int block) ...@@ -93,7 +93,7 @@ void minix_free_block(struct super_block * sb, int block)
} }
if (!clear_bit(bit,bh->b_data)) if (!clear_bit(bit,bh->b_data))
printk("free_block (%04x:%d): bit already cleared\n",sb->s_dev,block); printk("free_block (%04x:%d): bit already cleared\n",sb->s_dev,block);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
return; return;
} }
...@@ -118,7 +118,7 @@ int minix_new_block(struct super_block * sb) ...@@ -118,7 +118,7 @@ int minix_new_block(struct super_block * sb)
printk("new_block: bit already set"); printk("new_block: bit already set");
goto repeat; goto repeat;
} }
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
j += i*8192 + sb->u.minix_sb.s_firstdatazone-1; j += i*8192 + sb->u.minix_sb.s_firstdatazone-1;
if (j < sb->u.minix_sb.s_firstdatazone || if (j < sb->u.minix_sb.s_firstdatazone ||
j >= sb->u.minix_sb.s_nzones) j >= sb->u.minix_sb.s_nzones)
...@@ -129,7 +129,7 @@ int minix_new_block(struct super_block * sb) ...@@ -129,7 +129,7 @@ int minix_new_block(struct super_block * sb)
} }
clear_block(bh->b_data); clear_block(bh->b_data);
bh->b_uptodate = 1; bh->b_uptodate = 1;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
return j; return j;
} }
...@@ -175,7 +175,7 @@ void minix_free_inode(struct inode * inode) ...@@ -175,7 +175,7 @@ void minix_free_inode(struct inode * inode)
clear_inode(inode); clear_inode(inode);
if (!clear_bit(ino & 8191, bh->b_data)) if (!clear_bit(ino & 8191, bh->b_data))
printk("free_inode: bit %lu already cleared.\n",ino); printk("free_inode: bit %lu already cleared.\n",ino);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
} }
struct inode * minix_new_inode(const struct inode * dir) struct inode * minix_new_inode(const struct inode * dir)
...@@ -204,7 +204,7 @@ struct inode * minix_new_inode(const struct inode * dir) ...@@ -204,7 +204,7 @@ struct inode * minix_new_inode(const struct inode * dir)
iput(inode); iput(inode);
return NULL; return NULL;
} }
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
j += i*8192; j += i*8192;
if (!j || j >= inode->i_sb->u.minix_sb.s_ninodes) { if (!j || j >= inode->i_sb->u.minix_sb.s_ninodes) {
iput(inode); iput(inode);
......
...@@ -240,7 +240,7 @@ static int minix_file_write(struct inode * inode, struct file * filp, char * buf ...@@ -240,7 +240,7 @@ static int minix_file_write(struct inode * inode, struct file * filp, char * buf
memcpy_fromfs(p,buf,c); memcpy_fromfs(p,buf,c);
buf += c; buf += c;
bh->b_uptodate = 1; bh->b_uptodate = 1;
dirtify_buffer(bh, 0); mark_buffer_dirty(bh, 0);
brelse(bh); brelse(bh);
} }
inode->i_mtime = inode->i_ctime = CURRENT_TIME; inode->i_mtime = inode->i_ctime = CURRENT_TIME;
......
...@@ -28,7 +28,7 @@ void minix_put_inode(struct inode *inode) ...@@ -28,7 +28,7 @@ void minix_put_inode(struct inode *inode)
static void minix_commit_super (struct super_block * sb, static void minix_commit_super (struct super_block * sb,
struct minix_super_block * ms) struct minix_super_block * ms)
{ {
dirtify_buffer(sb->u.minix_sb.s_sbh, 1); mark_buffer_dirty(sb->u.minix_sb.s_sbh, 1);
sb->s_dirt = 0; sb->s_dirt = 0;
} }
...@@ -54,7 +54,7 @@ void minix_put_super(struct super_block *sb) ...@@ -54,7 +54,7 @@ void minix_put_super(struct super_block *sb)
lock_super(sb); lock_super(sb);
if (!(sb->s_flags & MS_RDONLY)) { if (!(sb->s_flags & MS_RDONLY)) {
sb->u.minix_sb.s_ms->s_state = sb->u.minix_sb.s_mount_state; sb->u.minix_sb.s_ms->s_state = sb->u.minix_sb.s_mount_state;
dirtify_buffer(sb->u.minix_sb.s_sbh, 1); mark_buffer_dirty(sb->u.minix_sb.s_sbh, 1);
} }
sb->s_dev = 0; sb->s_dev = 0;
for(i = 0 ; i < MINIX_I_MAP_SLOTS ; i++) for(i = 0 ; i < MINIX_I_MAP_SLOTS ; i++)
...@@ -90,7 +90,7 @@ int minix_remount (struct super_block * sb, int * flags, char * data) ...@@ -90,7 +90,7 @@ int minix_remount (struct super_block * sb, int * flags, char * data)
return 0; return 0;
/* Mounting a rw partition read-only. */ /* Mounting a rw partition read-only. */
ms->s_state = sb->u.minix_sb.s_mount_state; ms->s_state = sb->u.minix_sb.s_mount_state;
dirtify_buffer(sb->u.minix_sb.s_sbh, 1); mark_buffer_dirty(sb->u.minix_sb.s_sbh, 1);
sb->s_dirt = 1; sb->s_dirt = 1;
minix_commit_super (sb, ms); minix_commit_super (sb, ms);
} }
...@@ -98,7 +98,7 @@ int minix_remount (struct super_block * sb, int * flags, char * data) ...@@ -98,7 +98,7 @@ int minix_remount (struct super_block * sb, int * flags, char * data)
/* Mount a partition which is read-only, read-write. */ /* Mount a partition which is read-only, read-write. */
sb->u.minix_sb.s_mount_state = ms->s_state; sb->u.minix_sb.s_mount_state = ms->s_state;
ms->s_state &= ~MINIX_VALID_FS; ms->s_state &= ~MINIX_VALID_FS;
dirtify_buffer(sb->u.minix_sb.s_sbh, 1); mark_buffer_dirty(sb->u.minix_sb.s_sbh, 1);
sb->s_dirt = 1; sb->s_dirt = 1;
if (!(sb->u.minix_sb.s_mount_state & MINIX_VALID_FS)) if (!(sb->u.minix_sb.s_mount_state & MINIX_VALID_FS))
...@@ -197,7 +197,7 @@ struct super_block *minix_read_super(struct super_block *s,void *data, ...@@ -197,7 +197,7 @@ struct super_block *minix_read_super(struct super_block *s,void *data,
} }
if (!(s->s_flags & MS_RDONLY)) { if (!(s->s_flags & MS_RDONLY)) {
ms->s_state &= ~MINIX_VALID_FS; ms->s_state &= ~MINIX_VALID_FS;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
s->s_dirt = 1; s->s_dirt = 1;
} }
if (!(s->u.minix_sb.s_mount_state & MINIX_VALID_FS)) if (!(s->u.minix_sb.s_mount_state & MINIX_VALID_FS))
...@@ -349,7 +349,7 @@ static struct buffer_head * block_getblk(struct inode * inode, ...@@ -349,7 +349,7 @@ static struct buffer_head * block_getblk(struct inode * inode,
goto repeat; goto repeat;
} }
*p = tmp; *p = tmp;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
return result; return result;
} }
...@@ -477,7 +477,7 @@ static struct buffer_head * minix_update_inode(struct inode * inode) ...@@ -477,7 +477,7 @@ static struct buffer_head * minix_update_inode(struct inode * inode)
else for (block = 0; block < 9; block++) else for (block = 0; block < 9; block++)
raw_inode->i_zone[block] = inode->u.minix_i.i_data[block]; raw_inode->i_zone[block] = inode->u.minix_i.i_data[block];
inode->i_dirt=0; inode->i_dirt=0;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
return bh; return bh;
} }
......
...@@ -195,7 +195,7 @@ static int minix_add_entry(struct inode * dir, ...@@ -195,7 +195,7 @@ static int minix_add_entry(struct inode * dir,
dir->i_mtime = dir->i_ctime = CURRENT_TIME; dir->i_mtime = dir->i_ctime = CURRENT_TIME;
for (i = 0; i < info->s_namelen ; i++) for (i = 0; i < info->s_namelen ; i++)
de->name[i] = (i < namelen) ? name[i] : 0; de->name[i] = (i < namelen) ? name[i] : 0;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
*res_dir = de; *res_dir = de;
break; break;
} }
...@@ -238,7 +238,7 @@ int minix_create(struct inode * dir,const char * name, int len, int mode, ...@@ -238,7 +238,7 @@ int minix_create(struct inode * dir,const char * name, int len, int mode,
return error; return error;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
*result = inode; *result = inode;
...@@ -295,7 +295,7 @@ int minix_mknod(struct inode * dir, const char * name, int len, int mode, int rd ...@@ -295,7 +295,7 @@ int minix_mknod(struct inode * dir, const char * name, int len, int mode, int rd
return error; return error;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
iput(inode); iput(inode);
...@@ -347,7 +347,7 @@ int minix_mkdir(struct inode * dir, const char * name, int len, int mode) ...@@ -347,7 +347,7 @@ int minix_mkdir(struct inode * dir, const char * name, int len, int mode)
de->inode = dir->i_ino; de->inode = dir->i_ino;
strcpy(de->name,".."); strcpy(de->name,"..");
inode->i_nlink = 2; inode->i_nlink = 2;
dirtify_buffer(dir_block, 1); mark_buffer_dirty(dir_block, 1);
brelse(dir_block); brelse(dir_block);
inode->i_mode = S_IFDIR | (mode & 0777 & ~current->umask); inode->i_mode = S_IFDIR | (mode & 0777 & ~current->umask);
if (dir->i_mode & S_ISGID) if (dir->i_mode & S_ISGID)
...@@ -361,7 +361,7 @@ int minix_mkdir(struct inode * dir, const char * name, int len, int mode) ...@@ -361,7 +361,7 @@ int minix_mkdir(struct inode * dir, const char * name, int len, int mode)
return error; return error;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
dir->i_nlink++; dir->i_nlink++;
dir->i_dirt = 1; dir->i_dirt = 1;
iput(dir); iput(dir);
...@@ -469,7 +469,7 @@ int minix_rmdir(struct inode * dir, const char * name, int len) ...@@ -469,7 +469,7 @@ int minix_rmdir(struct inode * dir, const char * name, int len)
if (inode->i_nlink != 2) if (inode->i_nlink != 2)
printk("empty directory has nlink!=2 (%d)\n",inode->i_nlink); printk("empty directory has nlink!=2 (%d)\n",inode->i_nlink);
de->inode = 0; de->inode = 0;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
inode->i_nlink=0; inode->i_nlink=0;
inode->i_dirt=1; inode->i_dirt=1;
dir->i_nlink--; dir->i_nlink--;
...@@ -522,7 +522,7 @@ int minix_unlink(struct inode * dir, const char * name, int len) ...@@ -522,7 +522,7 @@ int minix_unlink(struct inode * dir, const char * name, int len)
inode->i_nlink=1; inode->i_nlink=1;
} }
de->inode = 0; de->inode = 0;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
dir->i_ctime = dir->i_mtime = CURRENT_TIME; dir->i_ctime = dir->i_mtime = CURRENT_TIME;
dir->i_dirt = 1; dir->i_dirt = 1;
inode->i_nlink--; inode->i_nlink--;
...@@ -562,7 +562,7 @@ int minix_symlink(struct inode * dir, const char * name, int len, const char * s ...@@ -562,7 +562,7 @@ int minix_symlink(struct inode * dir, const char * name, int len, const char * s
while (i < 1023 && (c=*(symname++))) while (i < 1023 && (c=*(symname++)))
name_block->b_data[i++] = c; name_block->b_data[i++] = c;
name_block->b_data[i] = 0; name_block->b_data[i] = 0;
dirtify_buffer(name_block, 1); mark_buffer_dirty(name_block, 1);
brelse(name_block); brelse(name_block);
inode->i_size = i; inode->i_size = i;
inode->i_dirt = 1; inode->i_dirt = 1;
...@@ -584,7 +584,7 @@ int minix_symlink(struct inode * dir, const char * name, int len, const char * s ...@@ -584,7 +584,7 @@ int minix_symlink(struct inode * dir, const char * name, int len, const char * s
return i; return i;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
iput(inode); iput(inode);
...@@ -621,7 +621,7 @@ int minix_link(struct inode * oldinode, struct inode * dir, const char * name, i ...@@ -621,7 +621,7 @@ int minix_link(struct inode * oldinode, struct inode * dir, const char * name, i
return error; return error;
} }
de->inode = oldinode->i_ino; de->inode = oldinode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
oldinode->i_nlink++; oldinode->i_nlink++;
...@@ -774,11 +774,11 @@ static int do_minix_rename(struct inode * old_dir, const char * old_name, int ol ...@@ -774,11 +774,11 @@ static int do_minix_rename(struct inode * old_dir, const char * old_name, int ol
new_inode->i_ctime = CURRENT_TIME; new_inode->i_ctime = CURRENT_TIME;
new_inode->i_dirt = 1; new_inode->i_dirt = 1;
} }
dirtify_buffer(old_bh, 1); mark_buffer_dirty(old_bh, 1);
dirtify_buffer(new_bh, 1); mark_buffer_dirty(new_bh, 1);
if (dir_bh) { if (dir_bh) {
PARENT_INO(dir_bh->b_data) = new_dir->i_ino; PARENT_INO(dir_bh->b_data) = new_dir->i_ino;
dirtify_buffer(dir_bh, 1); mark_buffer_dirty(dir_bh, 1);
old_dir->i_nlink--; old_dir->i_nlink--;
old_dir->i_dirt = 1; old_dir->i_dirt = 1;
if (new_inode) { if (new_inode) {
......
...@@ -96,7 +96,7 @@ static int trunc_indirect(struct inode * inode, int offset, unsigned short * p) ...@@ -96,7 +96,7 @@ static int trunc_indirect(struct inode * inode, int offset, unsigned short * p)
continue; continue;
} }
*ind = 0; *ind = 0;
dirtify_buffer(ind_bh, 1); mark_buffer_dirty(ind_bh, 1);
brelse(bh); brelse(bh);
minix_free_block(inode->i_sb,tmp); minix_free_block(inode->i_sb,tmp);
} }
...@@ -144,7 +144,7 @@ static int trunc_dindirect(struct inode * inode) ...@@ -144,7 +144,7 @@ static int trunc_dindirect(struct inode * inode)
goto repeat; goto repeat;
dind = i+(unsigned short *) dind_bh->b_data; dind = i+(unsigned short *) dind_bh->b_data;
retry |= trunc_indirect(inode,7+512+(i<<9),dind); retry |= trunc_indirect(inode,7+512+(i<<9),dind);
dirtify_buffer(dind_bh, 1); mark_buffer_dirty(dind_bh, 1);
} }
dind = (unsigned short *) dind_bh->b_data; dind = (unsigned short *) dind_bh->b_data;
for (i = 0; i < 512; i++) for (i = 0; i < 512; i++)
......
...@@ -72,15 +72,15 @@ int fat_access(struct super_block *sb,int nr,int new_value) ...@@ -72,15 +72,15 @@ int fat_access(struct super_block *sb,int nr,int new_value)
*p_first = new_value & 0xff; *p_first = new_value & 0xff;
*p_last = (*p_last & 0xf0) | (new_value >> 8); *p_last = (*p_last & 0xf0) | (new_value >> 8);
} }
dirtify_buffer(bh2, 1); mark_buffer_dirty(bh2, 1);
} }
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
for (copy = 1; copy < MSDOS_SB(sb)->fats; copy++) { for (copy = 1; copy < MSDOS_SB(sb)->fats; copy++) {
if (!(c_bh = msdos_sread(sb->s_dev,MSDOS_SB(sb)-> if (!(c_bh = msdos_sread(sb->s_dev,MSDOS_SB(sb)->
fat_start+(first >> SECTOR_BITS)+MSDOS_SB(sb)-> fat_start+(first >> SECTOR_BITS)+MSDOS_SB(sb)->
fat_length*copy,&c_data))) break; fat_length*copy,&c_data))) break;
memcpy(c_data,data,SECTOR_SIZE); memcpy(c_data,data,SECTOR_SIZE);
dirtify_buffer(c_bh, 1); mark_buffer_dirty(c_bh, 1);
if (data != data2 || bh != bh2) { if (data != data2 || bh != bh2) {
if (!(c_bh2 = msdos_sread(sb->s_dev, if (!(c_bh2 = msdos_sread(sb->s_dev,
MSDOS_SB(sb)->fat_start+(first >> MSDOS_SB(sb)->fat_start+(first >>
......
...@@ -200,7 +200,7 @@ static int msdos_file_write(struct inode *inode,struct file *filp,char *buf, ...@@ -200,7 +200,7 @@ static int msdos_file_write(struct inode *inode,struct file *filp,char *buf,
inode->i_size = filp->f_pos; inode->i_size = filp->f_pos;
inode->i_dirt = 1; inode->i_dirt = 1;
} }
dirtify_buffer(bh, 0); mark_buffer_dirty(bh, 0);
brelse(bh); brelse(bh);
} }
if (start == buf) if (start == buf)
......
...@@ -415,7 +415,7 @@ void msdos_write_inode(struct inode *inode) ...@@ -415,7 +415,7 @@ void msdos_write_inode(struct inode *inode)
date_unix2dos(inode->i_mtime,&raw_entry->time,&raw_entry->date); date_unix2dos(inode->i_mtime,&raw_entry->time,&raw_entry->date);
raw_entry->time = CT_LE_W(raw_entry->time); raw_entry->time = CT_LE_W(raw_entry->time);
raw_entry->date = CT_LE_W(raw_entry->date); raw_entry->date = CT_LE_W(raw_entry->date);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
} }
......
...@@ -185,7 +185,7 @@ printk("zeroing sector %d\n",sector); ...@@ -185,7 +185,7 @@ printk("zeroing sector %d\n",sector);
else memset(data,0,SECTOR_SIZE); else memset(data,0,SECTOR_SIZE);
} }
if (bh) { if (bh) {
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
} }
} }
......
...@@ -181,7 +181,7 @@ static int msdos_create_entry(struct inode *dir,char *name,int is_dir, ...@@ -181,7 +181,7 @@ static int msdos_create_entry(struct inode *dir,char *name,int is_dir,
de->start = 0; de->start = 0;
date_unix2dos(dir->i_mtime,&de->time,&de->date); date_unix2dos(dir->i_mtime,&de->time,&de->date);
de->size = 0; de->size = 0;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
if ((*result = iget(dir->i_sb,ino)) != NULL) if ((*result = iget(dir->i_sb,ino)) != NULL)
msdos_read_inode(*result); msdos_read_inode(*result);
brelse(bh); brelse(bh);
...@@ -350,7 +350,7 @@ int msdos_rmdir(struct inode *dir,const char *name,int len) ...@@ -350,7 +350,7 @@ int msdos_rmdir(struct inode *dir,const char *name,int len)
dir->i_nlink--; dir->i_nlink--;
inode->i_dirt = dir->i_dirt = 1; inode->i_dirt = dir->i_dirt = 1;
de->name[0] = DELETED_FLAG; de->name[0] = DELETED_FLAG;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
res = 0; res = 0;
rmdir_done: rmdir_done:
brelse(bh); brelse(bh);
...@@ -384,7 +384,7 @@ int msdos_unlink(struct inode *dir,const char *name,int len) ...@@ -384,7 +384,7 @@ int msdos_unlink(struct inode *dir,const char *name,int len)
MSDOS_I(inode)->i_busy = 1; MSDOS_I(inode)->i_busy = 1;
inode->i_dirt = dir->i_dirt = 1; inode->i_dirt = dir->i_dirt = 1;
de->name[0] = DELETED_FLAG; de->name[0] = DELETED_FLAG;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
unlink_done: unlink_done:
brelse(bh); brelse(bh);
iput(inode); iput(inode);
...@@ -429,12 +429,12 @@ static int rename_same_dir(struct inode *old_dir,char *old_name, ...@@ -429,12 +429,12 @@ static int rename_same_dir(struct inode *old_dir,char *old_name,
MSDOS_I(new_inode)->i_busy = 1; MSDOS_I(new_inode)->i_busy = 1;
new_inode->i_dirt = 1; new_inode->i_dirt = 1;
new_de->name[0] = DELETED_FLAG; new_de->name[0] = DELETED_FLAG;
dirtify_buffer(new_bh, 1); mark_buffer_dirty(new_bh, 1);
iput(new_inode); iput(new_inode);
brelse(new_bh); brelse(new_bh);
} }
memcpy(old_de->name,new_name,MSDOS_NAME); memcpy(old_de->name,new_name,MSDOS_NAME);
dirtify_buffer(old_bh, 1); mark_buffer_dirty(old_bh, 1);
if (MSDOS_SB(old_dir->i_sb)->conversion == 'a') /* update binary info */ if (MSDOS_SB(old_dir->i_sb)->conversion == 'a') /* update binary info */
if ((old_inode = iget(old_dir->i_sb,old_ino)) != NULL) { if ((old_inode = iget(old_dir->i_sb,old_ino)) != NULL) {
msdos_read_inode(old_inode); msdos_read_inode(old_inode);
...@@ -503,7 +503,7 @@ static int rename_diff_dir(struct inode *old_dir,char *old_name, ...@@ -503,7 +503,7 @@ static int rename_diff_dir(struct inode *old_dir,char *old_name,
MSDOS_I(new_inode)->i_busy = 1; MSDOS_I(new_inode)->i_busy = 1;
new_inode->i_dirt = 1; new_inode->i_dirt = 1;
new_de->name[0] = DELETED_FLAG; new_de->name[0] = DELETED_FLAG;
dirtify_buffer(new_bh, 1); mark_buffer_dirty(new_bh, 1);
} }
memcpy(free_de,old_de,sizeof(struct msdos_dir_entry)); memcpy(free_de,old_de,sizeof(struct msdos_dir_entry));
memcpy(free_de->name,new_name,MSDOS_NAME); memcpy(free_de->name,new_name,MSDOS_NAME);
...@@ -526,8 +526,8 @@ static int rename_diff_dir(struct inode *old_dir,char *old_name, ...@@ -526,8 +526,8 @@ static int rename_diff_dir(struct inode *old_dir,char *old_name,
cache_inval_inode(old_inode); cache_inval_inode(old_inode);
old_inode->i_dirt = 1; old_inode->i_dirt = 1;
old_de->name[0] = DELETED_FLAG; old_de->name[0] = DELETED_FLAG;
dirtify_buffer(old_bh, 1); mark_buffer_dirty(old_bh, 1);
dirtify_buffer(free_bh, 1); mark_buffer_dirty(free_bh, 1);
if (!exists) iput(free_inode); if (!exists) iput(free_inode);
else { else {
MSDOS_I(new_inode)->i_depend = free_inode; MSDOS_I(new_inode)->i_depend = free_inode;
...@@ -547,7 +547,7 @@ static int rename_diff_dir(struct inode *old_dir,char *old_name, ...@@ -547,7 +547,7 @@ static int rename_diff_dir(struct inode *old_dir,char *old_name,
dotdot_de->start = MSDOS_I(dotdot_inode)->i_start = dotdot_de->start = MSDOS_I(dotdot_inode)->i_start =
MSDOS_I(new_dir)->i_start; MSDOS_I(new_dir)->i_start;
dotdot_inode->i_dirt = 1; dotdot_inode->i_dirt = 1;
dirtify_buffer(dotdot_bh, 1); mark_buffer_dirty(dotdot_bh, 1);
old_dir->i_nlink--; old_dir->i_nlink--;
new_dir->i_nlink++; new_dir->i_nlink++;
/* no need to mark them dirty */ /* no need to mark them dirty */
......
...@@ -465,6 +465,7 @@ static int get_maps(int pid, char *buf) ...@@ -465,6 +465,7 @@ static int get_maps(int pid, char *buf)
} }
extern int get_module_list(char *); extern int get_module_list(char *);
extern int get_device_list(char *);
static int array_read(struct inode * inode, struct file * file,char * buf, int count) static int array_read(struct inode * inode, struct file * file,char * buf, int count)
{ {
...@@ -522,6 +523,9 @@ static int array_read(struct inode * inode, struct file * file,char * buf, int c ...@@ -522,6 +523,9 @@ static int array_read(struct inode * inode, struct file * file,char * buf, int c
case 17: case 17:
length = get_kstat(page); length = get_kstat(page);
break; break;
case 18:
length = get_device_list(page);
break;
default: default:
free_page((unsigned long) page); free_page((unsigned long) page);
return -EBADF; return -EBADF;
......
...@@ -67,6 +67,7 @@ static struct proc_dir_entry root_dir[] = { ...@@ -67,6 +67,7 @@ static struct proc_dir_entry root_dir[] = {
{14,5,"kcore" }, {14,5,"kcore" },
{16,7,"modules" }, {16,7,"modules" },
{17,4,"stat" }, {17,4,"stat" },
{18,7,"devices" },
}; };
#define NR_ROOT_DIRENTRY ((sizeof (root_dir))/(sizeof (root_dir[0]))) #define NR_ROOT_DIRENTRY ((sizeof (root_dir))/(sizeof (root_dir[0])))
......
...@@ -96,7 +96,7 @@ void sysv_free_block(struct super_block * sb, unsigned int block) ...@@ -96,7 +96,7 @@ void sysv_free_block(struct super_block * sb, unsigned int block)
} }
*flc_count = *sb->sv_sb_flc_count; /* = sb->sv_flc_size */ *flc_count = *sb->sv_sb_flc_count; /* = sb->sv_flc_size */
memcpy(flc_blocks, sb->sv_sb_flc_blocks, *flc_count * sizeof(sysv_zone_t)); memcpy(flc_blocks, sb->sv_sb_flc_blocks, *flc_count * sizeof(sysv_zone_t));
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
bh->b_uptodate = 1; bh->b_uptodate = 1;
brelse(bh); brelse(bh);
*sb->sv_sb_flc_count = 0; *sb->sv_sb_flc_count = 0;
...@@ -117,7 +117,7 @@ void sysv_free_block(struct super_block * sb, unsigned int block) ...@@ -117,7 +117,7 @@ void sysv_free_block(struct super_block * sb, unsigned int block)
bh_data = bh->b_data + ((block & sb->sv_block_size_ratio_1) << sb->sv_block_size_bits); bh_data = bh->b_data + ((block & sb->sv_block_size_ratio_1) << sb->sv_block_size_bits);
memzero(bh_data, sb->sv_block_size); memzero(bh_data, sb->sv_block_size);
/* this implies ((struct ..._freelist_chunk *) bh_data)->flc_count = 0; */ /* this implies ((struct ..._freelist_chunk *) bh_data)->flc_count = 0; */
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
bh->b_uptodate = 1; bh->b_uptodate = 1;
brelse(bh); brelse(bh);
/* still *sb->sv_sb_flc_count = 0 */ /* still *sb->sv_sb_flc_count = 0 */
...@@ -138,7 +138,7 @@ void sysv_free_block(struct super_block * sb, unsigned int block) ...@@ -138,7 +138,7 @@ void sysv_free_block(struct super_block * sb, unsigned int block)
to_coh_ulong(from_coh_ulong(*sb->sv_sb_total_free_blocks) + 1); to_coh_ulong(from_coh_ulong(*sb->sv_sb_total_free_blocks) + 1);
else else
*sb->sv_sb_total_free_blocks = *sb->sv_sb_total_free_blocks + 1; *sb->sv_sb_total_free_blocks = *sb->sv_sb_total_free_blocks + 1;
dirtify_buffer(sb->sv_bh, 1); /* super-block has been modified */ mark_buffer_dirty(sb->sv_bh, 1); /* super-block has been modified */
sb->s_dirt = 1; /* and needs time stamp */ sb->s_dirt = 1; /* and needs time stamp */
unlock_super(sb); unlock_super(sb);
} }
...@@ -229,7 +229,7 @@ int sysv_new_block(struct super_block * sb) ...@@ -229,7 +229,7 @@ int sysv_new_block(struct super_block * sb)
return 0; return 0;
} }
memzero(bh_data,sb->sv_block_size); memzero(bh_data,sb->sv_block_size);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
bh->b_uptodate = 1; bh->b_uptodate = 1;
brelse(bh); brelse(bh);
if (sb->sv_convert) if (sb->sv_convert)
...@@ -237,7 +237,7 @@ int sysv_new_block(struct super_block * sb) ...@@ -237,7 +237,7 @@ int sysv_new_block(struct super_block * sb)
to_coh_ulong(from_coh_ulong(*sb->sv_sb_total_free_blocks) - 1); to_coh_ulong(from_coh_ulong(*sb->sv_sb_total_free_blocks) - 1);
else else
*sb->sv_sb_total_free_blocks = *sb->sv_sb_total_free_blocks - 1; *sb->sv_sb_total_free_blocks = *sb->sv_sb_total_free_blocks - 1;
dirtify_buffer(sb->sv_bh, 1); /* super-block has been modified */ mark_buffer_dirty(sb->sv_bh, 1); /* super-block has been modified */
sb->s_dirt = 1; /* and needs time stamp */ sb->s_dirt = 1; /* and needs time stamp */
unlock_super(sb); unlock_super(sb);
return block; return block;
...@@ -331,7 +331,7 @@ unsigned long sysv_count_free_blocks(struct super_block * sb) ...@@ -331,7 +331,7 @@ unsigned long sysv_count_free_blocks(struct super_block * sb)
printk("sysv_count_free_blocks: free block count was %d, correcting to %d\n",old_count,count); printk("sysv_count_free_blocks: free block count was %d, correcting to %d\n",old_count,count);
if (!(sb->s_flags & MS_RDONLY)) { if (!(sb->s_flags & MS_RDONLY)) {
*sb->sv_sb_total_free_blocks = (sb->sv_convert ? to_coh_ulong(count) : count); *sb->sv_sb_total_free_blocks = (sb->sv_convert ? to_coh_ulong(count) : count);
dirtify_buffer(sb->sv_bh, 1); /* super-block has been modified */ mark_buffer_dirty(sb->sv_bh, 1); /* super-block has been modified */
sb->s_dirt = 1; /* and needs time stamp */ sb->s_dirt = 1; /* and needs time stamp */
} }
} }
......
...@@ -301,7 +301,7 @@ static int sysv_file_write(struct inode * inode, struct file * filp, char * buf, ...@@ -301,7 +301,7 @@ static int sysv_file_write(struct inode * inode, struct file * filp, char * buf,
memcpy_fromfs(p,buf,c); memcpy_fromfs(p,buf,c);
buf += c; buf += c;
bh->b_uptodate = 1; bh->b_uptodate = 1;
dirtify_buffer(bh, 0); mark_buffer_dirty(bh, 0);
brelse(bh); brelse(bh);
} }
inode->i_mtime = inode->i_ctime = CURRENT_TIME; inode->i_mtime = inode->i_ctime = CURRENT_TIME;
......
...@@ -74,10 +74,10 @@ void sysv_free_inode(struct inode * inode) ...@@ -74,10 +74,10 @@ void sysv_free_inode(struct inode * inode)
if (*sb->sv_sb_fic_count < sb->sv_fic_size) if (*sb->sv_sb_fic_count < sb->sv_fic_size)
sb->sv_sb_fic_inodes[(*sb->sv_sb_fic_count)++] = ino; sb->sv_sb_fic_inodes[(*sb->sv_sb_fic_count)++] = ino;
(*sb->sv_sb_total_free_inodes)++; (*sb->sv_sb_total_free_inodes)++;
dirtify_buffer(sb->sv_bh, 1); /* super-block has been modified */ mark_buffer_dirty(sb->sv_bh, 1); /* super-block has been modified */
sb->s_dirt = 1; /* and needs time stamp */ sb->s_dirt = 1; /* and needs time stamp */
memset(raw_inode, 0, sizeof(struct sysv_inode)); memset(raw_inode, 0, sizeof(struct sysv_inode));
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
unlock_super(sb); unlock_super(sb);
brelse(bh); brelse(bh);
clear_inode(inode); clear_inode(inode);
...@@ -130,7 +130,7 @@ struct inode * sysv_new_inode(const struct inode * dir) ...@@ -130,7 +130,7 @@ struct inode * sysv_new_inode(const struct inode * dir)
} }
/* Now *sb->sv_sb_fic_count > 0. */ /* Now *sb->sv_sb_fic_count > 0. */
ino = sb->sv_sb_fic_inodes[--(*sb->sv_sb_fic_count)]; ino = sb->sv_sb_fic_inodes[--(*sb->sv_sb_fic_count)];
dirtify_buffer(sb->sv_bh, 1); /* super-block has been modified */ mark_buffer_dirty(sb->sv_bh, 1); /* super-block has been modified */
sb->s_dirt = 1; /* and needs time stamp */ sb->s_dirt = 1; /* and needs time stamp */
inode->i_count = 1; inode->i_count = 1;
inode->i_nlink = 1; inode->i_nlink = 1;
...@@ -152,7 +152,7 @@ struct inode * sysv_new_inode(const struct inode * dir) ...@@ -152,7 +152,7 @@ struct inode * sysv_new_inode(const struct inode * dir)
inode->i_dirt = 1; /* cleared by sysv_write_inode() */ inode->i_dirt = 1; /* cleared by sysv_write_inode() */
/* That's it. */ /* That's it. */
(*sb->sv_sb_total_free_inodes)--; (*sb->sv_sb_total_free_inodes)--;
dirtify_buffer(sb->sv_bh, 1); /* super-block has been modified again */ mark_buffer_dirty(sb->sv_bh, 1); /* super-block has been modified again */
sb->s_dirt = 1; /* and needs time stamp again */ sb->s_dirt = 1; /* and needs time stamp again */
unlock_super(sb); unlock_super(sb);
return inode; return inode;
...@@ -191,7 +191,7 @@ unsigned long sysv_count_free_inodes(struct super_block * sb) ...@@ -191,7 +191,7 @@ unsigned long sysv_count_free_inodes(struct super_block * sb)
printk("sysv_count_free_inodes: free inode count was %d, correcting to %d\n",(short)(*sb->sv_sb_total_free_inodes),count); printk("sysv_count_free_inodes: free inode count was %d, correcting to %d\n",(short)(*sb->sv_sb_total_free_inodes),count);
if (!(sb->s_flags & MS_RDONLY)) { if (!(sb->s_flags & MS_RDONLY)) {
*sb->sv_sb_total_free_inodes = count; *sb->sv_sb_total_free_inodes = count;
dirtify_buffer(sb->sv_bh, 1); /* super-block has been modified */ mark_buffer_dirty(sb->sv_bh, 1); /* super-block has been modified */
sb->s_dirt = 1; /* and needs time stamp */ sb->s_dirt = 1; /* and needs time stamp */
} }
} }
......
...@@ -557,7 +557,7 @@ static struct buffer_head * block_getblk(struct inode * inode, ...@@ -557,7 +557,7 @@ static struct buffer_head * block_getblk(struct inode * inode,
goto repeat; goto repeat;
} }
*p = (sb->sv_convert ? to_coh_ulong(block) : block); *p = (sb->sv_convert ? to_coh_ulong(block) : block);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
*start = result->b_data + ((block & sb->sv_block_size_ratio_1) << sb->sv_block_size_bits); *start = result->b_data + ((block & sb->sv_block_size_ratio_1) << sb->sv_block_size_bits);
return result; return result;
...@@ -773,7 +773,7 @@ static struct buffer_head * sysv_update_inode(struct inode * inode) ...@@ -773,7 +773,7 @@ static struct buffer_head * sysv_update_inode(struct inode * inode)
for (block = 0; block < 10+1+1+1; block++) for (block = 0; block < 10+1+1+1; block++)
write3byte(&raw_inode->i_a.i_addb[3*block],inode->u.sysv_i.i_data[block]); write3byte(&raw_inode->i_a.i_addb[3*block],inode->u.sysv_i.i_data[block]);
inode->i_dirt=0; inode->i_dirt=0;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
return bh; return bh;
} }
......
...@@ -193,7 +193,7 @@ static int sysv_add_entry(struct inode * dir, ...@@ -193,7 +193,7 @@ static int sysv_add_entry(struct inode * dir,
dir->i_mtime = dir->i_ctime = CURRENT_TIME; dir->i_mtime = dir->i_ctime = CURRENT_TIME;
for (i = 0; i < SYSV_NAMELEN ; i++) for (i = 0; i < SYSV_NAMELEN ; i++)
de->name[i] = (i < namelen) ? name[i] : 0; de->name[i] = (i < namelen) ? name[i] : 0;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
*res_dir = de; *res_dir = de;
break; break;
} }
...@@ -238,7 +238,7 @@ int sysv_create(struct inode * dir,const char * name, int len, int mode, ...@@ -238,7 +238,7 @@ int sysv_create(struct inode * dir,const char * name, int len, int mode,
return error; return error;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
*result = inode; *result = inode;
...@@ -298,7 +298,7 @@ int sysv_mknod(struct inode * dir, const char * name, int len, int mode, int rde ...@@ -298,7 +298,7 @@ int sysv_mknod(struct inode * dir, const char * name, int len, int mode, int rde
return error; return error;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
iput(inode); iput(inode);
...@@ -349,7 +349,7 @@ int sysv_mkdir(struct inode * dir, const char * name, int len, int mode) ...@@ -349,7 +349,7 @@ int sysv_mkdir(struct inode * dir, const char * name, int len, int mode)
de->inode = dir->i_ino; de->inode = dir->i_ino;
strcpy(de->name,".."); /* rest of de->name is zero, see sysv_new_block */ strcpy(de->name,".."); /* rest of de->name is zero, see sysv_new_block */
inode->i_nlink = 2; inode->i_nlink = 2;
dirtify_buffer(dir_block, 1); mark_buffer_dirty(dir_block, 1);
brelse(dir_block); brelse(dir_block);
inode->i_mode = S_IFDIR | (mode & 0777 & ~current->umask); inode->i_mode = S_IFDIR | (mode & 0777 & ~current->umask);
if (dir->i_mode & S_ISGID) if (dir->i_mode & S_ISGID)
...@@ -363,7 +363,7 @@ int sysv_mkdir(struct inode * dir, const char * name, int len, int mode) ...@@ -363,7 +363,7 @@ int sysv_mkdir(struct inode * dir, const char * name, int len, int mode)
return error; return error;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
dir->i_nlink++; dir->i_nlink++;
dir->i_dirt = 1; dir->i_dirt = 1;
iput(dir); iput(dir);
...@@ -473,7 +473,7 @@ int sysv_rmdir(struct inode * dir, const char * name, int len) ...@@ -473,7 +473,7 @@ int sysv_rmdir(struct inode * dir, const char * name, int len)
if (inode->i_nlink != 2) if (inode->i_nlink != 2)
printk("empty directory has nlink!=2 (%d)\n",inode->i_nlink); printk("empty directory has nlink!=2 (%d)\n",inode->i_nlink);
de->inode = 0; de->inode = 0;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
inode->i_nlink=0; inode->i_nlink=0;
inode->i_dirt=1; inode->i_dirt=1;
dir->i_nlink--; dir->i_nlink--;
...@@ -526,7 +526,7 @@ int sysv_unlink(struct inode * dir, const char * name, int len) ...@@ -526,7 +526,7 @@ int sysv_unlink(struct inode * dir, const char * name, int len)
inode->i_nlink=1; inode->i_nlink=1;
} }
de->inode = 0; de->inode = 0;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
dir->i_ctime = dir->i_mtime = CURRENT_TIME; dir->i_ctime = dir->i_mtime = CURRENT_TIME;
dir->i_dirt = 1; dir->i_dirt = 1;
inode->i_nlink--; inode->i_nlink--;
...@@ -570,7 +570,7 @@ int sysv_symlink(struct inode * dir, const char * name, int len, const char * sy ...@@ -570,7 +570,7 @@ int sysv_symlink(struct inode * dir, const char * name, int len, const char * sy
while (i < sb->sv_block_size_1 && (c = *(symname++))) while (i < sb->sv_block_size_1 && (c = *(symname++)))
name_block_data[i++] = c; name_block_data[i++] = c;
name_block_data[i] = 0; name_block_data[i] = 0;
dirtify_buffer(name_block, 1); mark_buffer_dirty(name_block, 1);
brelse(name_block); brelse(name_block);
inode->i_size = i; inode->i_size = i;
inode->i_dirt = 1; inode->i_dirt = 1;
...@@ -592,7 +592,7 @@ int sysv_symlink(struct inode * dir, const char * name, int len, const char * sy ...@@ -592,7 +592,7 @@ int sysv_symlink(struct inode * dir, const char * name, int len, const char * sy
return i; return i;
} }
de->inode = inode->i_ino; de->inode = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
iput(inode); iput(inode);
...@@ -629,7 +629,7 @@ int sysv_link(struct inode * oldinode, struct inode * dir, const char * name, in ...@@ -629,7 +629,7 @@ int sysv_link(struct inode * oldinode, struct inode * dir, const char * name, in
return error; return error;
} }
de->inode = oldinode->i_ino; de->inode = oldinode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
oldinode->i_nlink++; oldinode->i_nlink++;
...@@ -782,11 +782,11 @@ static int do_sysv_rename(struct inode * old_dir, const char * old_name, int old ...@@ -782,11 +782,11 @@ static int do_sysv_rename(struct inode * old_dir, const char * old_name, int old
new_inode->i_ctime = CURRENT_TIME; new_inode->i_ctime = CURRENT_TIME;
new_inode->i_dirt = 1; new_inode->i_dirt = 1;
} }
dirtify_buffer(old_bh, 1); mark_buffer_dirty(old_bh, 1);
dirtify_buffer(new_bh, 1); mark_buffer_dirty(new_bh, 1);
if (dir_bh) { if (dir_bh) {
PARENT_INO(dir_bh_data) = new_dir->i_ino; PARENT_INO(dir_bh_data) = new_dir->i_ino;
dirtify_buffer(dir_bh, 1); mark_buffer_dirty(dir_bh, 1);
old_dir->i_nlink--; old_dir->i_nlink--;
old_dir->i_dirt = 1; old_dir->i_dirt = 1;
if (new_inode) { if (new_inode) {
......
...@@ -84,7 +84,7 @@ static int coh_trunc_indirect (struct inode * inode, unsigned long blocks, unsig ...@@ -84,7 +84,7 @@ static int coh_trunc_indirect (struct inode * inode, unsigned long blocks, unsig
if (!indblock) if (!indblock)
continue; continue;
*ind = 0; *ind = 0;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
sysv_free_block(sb,indblock); sysv_free_block(sb,indblock);
} }
for (i = 0; i < sb->sv_ind_per_block; i++) for (i = 0; i < sb->sv_ind_per_block; i++)
...@@ -338,7 +338,7 @@ static int trunc_indirect(struct inode * inode, unsigned long offset, unsigned l ...@@ -338,7 +338,7 @@ static int trunc_indirect(struct inode * inode, unsigned long offset, unsigned l
continue; continue;
} }
*ind = 0; *ind = 0;
dirtify_buffer(indbh, 1); mark_buffer_dirty(indbh, 1);
brelse(bh); brelse(bh);
sysv_free_block(sb,block); sysv_free_block(sb,block);
} }
......
...@@ -65,7 +65,7 @@ static int find_first_zero(struct buffer_head *bh, int start_bit, int end_bit) ...@@ -65,7 +65,7 @@ static int find_first_zero(struct buffer_head *bh, int start_bit, int end_bit)
start_bit=j + (i << 5) + 1; start_bit=j + (i << 5) + 1;
goto repeat; goto repeat;
} }
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
return j + (i << 5); return j + (i << 5);
} }
...@@ -245,7 +245,7 @@ void xiafs_free_zone(struct super_block * sb, int d_addr) ...@@ -245,7 +245,7 @@ void xiafs_free_zone(struct super_block * sb, int d_addr)
printk("XIA-FS: dev %04x" printk("XIA-FS: dev %04x"
" block bit %u (0x%x) already cleared (%s %d)\n", " block bit %u (0x%x) already cleared (%s %d)\n",
sb->s_dev, bit, bit, WHERE_ERR); sb->s_dev, bit, bit, WHERE_ERR);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
xiafs_unlock_super(sb, sb->u.xiafs_sb.s_zmap_cached); xiafs_unlock_super(sb, sb->u.xiafs_sb.s_zmap_cached);
} }
...@@ -277,7 +277,7 @@ int xiafs_new_zone(struct super_block * sb, u_long prev_addr) ...@@ -277,7 +277,7 @@ int xiafs_new_zone(struct super_block * sb, u_long prev_addr)
} }
clear_buf(bh); clear_buf(bh);
bh->b_uptodate = 1; bh->b_uptodate = 1;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
return tmp; return tmp;
} }
...@@ -305,7 +305,7 @@ void xiafs_free_inode(struct inode * inode) ...@@ -305,7 +305,7 @@ void xiafs_free_inode(struct inode * inode)
printk("XIA-FS: dev %04x" printk("XIA-FS: dev %04x"
"inode bit %ld (0x%lx) already cleared (%s %d)\n", "inode bit %ld (0x%lx) already cleared (%s %d)\n",
inode->i_dev, ino, ino, WHERE_ERR); inode->i_dev, ino, ino, WHERE_ERR);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
xiafs_unlock_super(sb, sb->u.xiafs_sb.s_imap_cached); xiafs_unlock_super(sb, sb->u.xiafs_sb.s_imap_cached);
} }
......
...@@ -241,7 +241,7 @@ xiafs_file_write(struct inode * inode, struct file * filp, char * buf, int count ...@@ -241,7 +241,7 @@ xiafs_file_write(struct inode * inode, struct file * filp, char * buf, int count
memcpy_fromfs(cp,buf,c); memcpy_fromfs(cp,buf,c);
buf += c; buf += c;
bh->b_uptodate = 1; bh->b_uptodate = 1;
dirtify_buffer(bh, 0); mark_buffer_dirty(bh, 0);
brelse(bh); brelse(bh);
} }
inode->i_mtime = inode->i_ctime = CURRENT_TIME; inode->i_mtime = inode->i_ctime = CURRENT_TIME;
......
...@@ -306,7 +306,7 @@ indt_getblk(struct inode * inode, struct buffer_head * bh, ...@@ -306,7 +306,7 @@ indt_getblk(struct inode * inode, struct buffer_head * bh,
} }
*lp = tmp; *lp = tmp;
inode->i_blocks+=2 << XIAFS_ZSHIFT(inode->i_sb); inode->i_blocks+=2 << XIAFS_ZSHIFT(inode->i_sb);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
return result; return result;
} }
...@@ -466,7 +466,7 @@ static struct buffer_head * xiafs_update_inode(struct inode * inode) ...@@ -466,7 +466,7 @@ static struct buffer_head * xiafs_update_inode(struct inode * inode)
| (inode->u.xiafs_i.i_dind_zone & 0xffffff); | (inode->u.xiafs_i.i_dind_zone & 0xffffff);
} }
inode->i_dirt=0; inode->i_dirt=0;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
return bh; return bh;
} }
......
...@@ -221,7 +221,7 @@ static struct buffer_head * xiafs_add_entry(struct inode * dir, ...@@ -221,7 +221,7 @@ static struct buffer_head * xiafs_add_entry(struct inode * dir,
memcpy(de->d_name, name, namelen); memcpy(de->d_name, name, namelen);
de->d_name[namelen]=0; de->d_name[namelen]=0;
de->d_name_len=namelen; de->d_name_len=namelen;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
*res_dir = de; *res_dir = de;
if (res_pre) if (res_pre)
*res_pre = de_pre; *res_pre = de_pre;
...@@ -268,7 +268,7 @@ int xiafs_create(struct inode * dir, const char * name, int len, int mode, ...@@ -268,7 +268,7 @@ int xiafs_create(struct inode * dir, const char * name, int len, int mode,
return -ENOSPC; return -ENOSPC;
} }
de->d_ino = inode->i_ino; de->d_ino = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
*result = inode; *result = inode;
...@@ -325,7 +325,7 @@ int xiafs_mknod(struct inode *dir, const char *name, int len, int mode, int rdev ...@@ -325,7 +325,7 @@ int xiafs_mknod(struct inode *dir, const char *name, int len, int mode, int rdev
return -ENOSPC; return -ENOSPC;
} }
de->d_ino = inode->i_ino; de->d_ino = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
iput(inode); iput(inode);
...@@ -375,7 +375,7 @@ int xiafs_mkdir(struct inode * dir, const char * name, int len, int mode) ...@@ -375,7 +375,7 @@ int xiafs_mkdir(struct inode * dir, const char * name, int len, int mode)
de->d_name_len=2; de->d_name_len=2;
de->d_rec_len=XIAFS_ZSIZE(dir->i_sb)-12; de->d_rec_len=XIAFS_ZSIZE(dir->i_sb)-12;
inode->i_nlink = 2; inode->i_nlink = 2;
dirtify_buffer(dir_block, 1); mark_buffer_dirty(dir_block, 1);
brelse(dir_block); brelse(dir_block);
inode->i_mode = S_IFDIR | (mode & S_IRWXUGO & ~current->umask); inode->i_mode = S_IFDIR | (mode & S_IRWXUGO & ~current->umask);
if (dir->i_mode & S_ISGID) if (dir->i_mode & S_ISGID)
...@@ -389,7 +389,7 @@ int xiafs_mkdir(struct inode * dir, const char * name, int len, int mode) ...@@ -389,7 +389,7 @@ int xiafs_mkdir(struct inode * dir, const char * name, int len, int mode)
return -ENOSPC; return -ENOSPC;
} }
de->d_ino = inode->i_ino; de->d_ino = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
dir->i_nlink++; dir->i_nlink++;
dir->i_dirt = 1; dir->i_dirt = 1;
iput(dir); iput(dir);
...@@ -518,7 +518,7 @@ int xiafs_rmdir(struct inode * dir, const char * name, int len) ...@@ -518,7 +518,7 @@ int xiafs_rmdir(struct inode * dir, const char * name, int len)
if (inode->i_nlink != 2) if (inode->i_nlink != 2)
printk("XIA-FS: empty directory has nlink!=2 (%s %d)\n", WHERE_ERR); printk("XIA-FS: empty directory has nlink!=2 (%s %d)\n", WHERE_ERR);
xiafs_rm_entry(de, de_pre); xiafs_rm_entry(de, de_pre);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
inode->i_nlink=0; inode->i_nlink=0;
inode->i_dirt=1; inode->i_dirt=1;
dir->i_nlink--; dir->i_nlink--;
...@@ -566,7 +566,7 @@ int xiafs_unlink(struct inode * dir, const char * name, int len) ...@@ -566,7 +566,7 @@ int xiafs_unlink(struct inode * dir, const char * name, int len)
inode->i_nlink=1; inode->i_nlink=1;
} }
xiafs_rm_entry(de, de_pre); xiafs_rm_entry(de, de_pre);
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME;
dir->i_dirt = 1; dir->i_dirt = 1;
inode->i_nlink--; inode->i_nlink--;
...@@ -611,7 +611,7 @@ int xiafs_symlink(struct inode * dir, const char * name, ...@@ -611,7 +611,7 @@ int xiafs_symlink(struct inode * dir, const char * name,
for (i = 0; i < BLOCK_SIZE-1 && (c=*symname++); i++) for (i = 0; i < BLOCK_SIZE-1 && (c=*symname++); i++)
name_block->b_data[i] = c; name_block->b_data[i] = c;
name_block->b_data[i] = 0; name_block->b_data[i] = 0;
dirtify_buffer(name_block, 1); mark_buffer_dirty(name_block, 1);
brelse(name_block); brelse(name_block);
inode->i_size = i; inode->i_size = i;
inode->i_dirt = 1; inode->i_dirt = 1;
...@@ -624,7 +624,7 @@ int xiafs_symlink(struct inode * dir, const char * name, ...@@ -624,7 +624,7 @@ int xiafs_symlink(struct inode * dir, const char * name,
return -ENOSPC; return -ENOSPC;
} }
de->d_ino = inode->i_ino; de->d_ino = inode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
iput(inode); iput(inode);
...@@ -661,7 +661,7 @@ int xiafs_link(struct inode * oldinode, struct inode * dir, ...@@ -661,7 +661,7 @@ int xiafs_link(struct inode * oldinode, struct inode * dir,
return -ENOSPC; return -ENOSPC;
} }
de->d_ino = oldinode->i_ino; de->d_ino = oldinode->i_ino;
dirtify_buffer(bh, 1); mark_buffer_dirty(bh, 1);
brelse(bh); brelse(bh);
iput(dir); iput(dir);
oldinode->i_nlink++; oldinode->i_nlink++;
...@@ -798,11 +798,11 @@ static int do_xiafs_rename(struct inode * old_dir, const char * old_name, ...@@ -798,11 +798,11 @@ static int do_xiafs_rename(struct inode * old_dir, const char * old_name,
new_inode->i_nlink--; new_inode->i_nlink--;
new_inode->i_dirt = 1; new_inode->i_dirt = 1;
} }
dirtify_buffer(old_bh, 1); mark_buffer_dirty(old_bh, 1);
dirtify_buffer(new_bh, 1); mark_buffer_dirty(new_bh, 1);
if (dir_bh) { if (dir_bh) {
PARENT_INO(dir_bh->b_data) = new_dir->i_ino; PARENT_INO(dir_bh->b_data) = new_dir->i_ino;
dirtify_buffer(dir_bh, 1); mark_buffer_dirty(dir_bh, 1);
old_dir->i_nlink--; old_dir->i_nlink--;
new_dir->i_nlink++; new_dir->i_nlink++;
old_dir->i_dirt = 1; old_dir->i_dirt = 1;
......
...@@ -104,7 +104,7 @@ static int trunc_indirect(struct inode * inode, int addr_off, u_long * lp) ...@@ -104,7 +104,7 @@ static int trunc_indirect(struct inode * inode, int addr_off, u_long * lp)
retry = 1; retry = 1;
else { else {
*indp = 0; *indp = 0;
dirtify_buffer(ind_bh, 1); mark_buffer_dirty(ind_bh, 1);
inode->i_blocks-= 2 << XIAFS_ZSHIFT(inode->i_sb); inode->i_blocks-= 2 << XIAFS_ZSHIFT(inode->i_sb);
xiafs_free_zone(inode->i_sb, tmp); xiafs_free_zone(inode->i_sb, tmp);
} }
...@@ -157,7 +157,7 @@ static int trunc_dindirect(struct inode * inode) ...@@ -157,7 +157,7 @@ static int trunc_dindirect(struct inode * inode)
retry |= trunc_indirect(inode, retry |= trunc_indirect(inode,
8+((1+i)<<XIAFS_ADDRS_PER_Z_BITS(inode->i_sb)), 8+((1+i)<<XIAFS_ADDRS_PER_Z_BITS(inode->i_sb)),
dindp); dindp);
dirtify_buffer(dind_bh, 1); mark_buffer_dirty(dind_bh, 1);
} }
dindp = (u_long *) dind_bh->b_data; dindp = (u_long *) dind_bh->b_data;
for (i = 0; i < XIAFS_ADDRS_PER_Z(inode->i_sb) && !(*dindp++); i++); for (i = 0; i < XIAFS_ADDRS_PER_Z(inode->i_sb) && !(*dindp++); i++);
......
...@@ -390,6 +390,7 @@ extern int ext2_bmap (struct inode *, int); ...@@ -390,6 +390,7 @@ extern int ext2_bmap (struct inode *, int);
extern struct buffer_head * ext2_getblk (struct inode *, long, int, int *); extern struct buffer_head * ext2_getblk (struct inode *, long, int, int *);
extern struct buffer_head * ext2_bread (struct inode *, int, int, int *); extern struct buffer_head * ext2_bread (struct inode *, int, int, int *);
extern int ext2_getcluster (struct inode * inode, long block);
extern void ext2_read_inode (struct inode *); extern void ext2_read_inode (struct inode *);
extern void ext2_write_inode (struct inode *); extern void ext2_write_inode (struct inode *);
extern void ext2_put_inode (struct inode *); extern void ext2_put_inode (struct inode *);
......
...@@ -28,7 +28,6 @@ ...@@ -28,7 +28,6 @@
#define NR_INODE 2048 /* this should be bigger than NR_FILE */ #define NR_INODE 2048 /* this should be bigger than NR_FILE */
#define NR_FILE 1024 /* this can well be larger on a larger system */ #define NR_FILE 1024 /* this can well be larger on a larger system */
#define NR_SUPER 32 #define NR_SUPER 32
#define NR_HASH 997
#define NR_IHASH 131 #define NR_IHASH 131
#define NR_FILE_LOCKS 64 #define NR_FILE_LOCKS 64
#define BLOCK_SIZE 1024 #define BLOCK_SIZE 1024
...@@ -138,6 +137,11 @@ struct buffer_head { ...@@ -138,6 +137,11 @@ struct buffer_head {
unsigned char b_dirt; /* 0-clean,1-dirty */ unsigned char b_dirt; /* 0-clean,1-dirty */
unsigned char b_lock; /* 0 - ok, 1 -locked */ unsigned char b_lock; /* 0 - ok, 1 -locked */
unsigned char b_req; /* 0 if the buffer has been invalidated */ unsigned char b_req; /* 0 if the buffer has been invalidated */
unsigned char b_list; /* List that this buffer appears */
unsigned char b_retain; /* Expected number of times this will
be used. Put on freelist when 0 */
unsigned long b_flushtime; /* Time when this (dirty) buffer should be written */
unsigned long b_lru_time; /* Time when this buffer was last used. */
struct wait_queue * b_wait; struct wait_queue * b_wait;
struct buffer_head * b_prev; /* doubly linked list of hash-queue */ struct buffer_head * b_prev; /* doubly linked list of hash-queue */
struct buffer_head * b_next; struct buffer_head * b_next;
...@@ -356,16 +360,41 @@ extern struct super_block super_blocks[NR_SUPER]; ...@@ -356,16 +360,41 @@ extern struct super_block super_blocks[NR_SUPER];
extern int shrink_buffers(unsigned int priority); extern int shrink_buffers(unsigned int priority);
extern void refile_buffer(struct buffer_head * buf);
void set_writetime(struct buffer_head * buf, int flag);
struct buffer_head ** buffer_pages;
extern int nr_buffers; extern int nr_buffers;
extern int buffermem; extern int buffermem;
extern int nr_buffer_heads; extern int nr_buffer_heads;
/* Once the full cluster diffs are in place, this will be filled out a bit. */ #define BUF_CLEAN 0
extern inline void dirtify_buffer(struct buffer_head * bh, int flag) #define BUF_UNSHARED 1 /* Buffers that were shared but are not any more */
#define BUF_LOCKED 2 /* Buffers scheduled for write */
#define BUF_LOCKED1 3 /* Supers, inodes */
#define BUF_DIRTY 4 /* Dirty buffers, not yet scheduled for write */
#define BUF_SHARED 5 /* Buffers shared */
#define NR_LIST 6
extern inline void mark_buffer_clean(struct buffer_head * bh)
{ {
bh->b_dirt = 1; if(bh->b_dirt) {
bh->b_dirt = 0;
if(bh->b_list == BUF_DIRTY) refile_buffer(bh);
}
} }
extern inline void mark_buffer_dirty(struct buffer_head * bh, int flag)
{
if(!bh->b_dirt) {
bh->b_dirt = 1;
set_writetime(bh, flag);
if(bh->b_list != BUF_DIRTY) refile_buffer(bh);
}
}
extern void check_disk_change(dev_t dev); extern void check_disk_change(dev_t dev);
extern void invalidate_inodes(dev_t dev); extern void invalidate_inodes(dev_t dev);
extern void invalidate_buffers(dev_t dev); extern void invalidate_buffers(dev_t dev);
...@@ -402,6 +431,7 @@ extern unsigned long bread_page(unsigned long addr,dev_t dev,int b[],int size,in ...@@ -402,6 +431,7 @@ extern unsigned long bread_page(unsigned long addr,dev_t dev,int b[],int size,in
extern struct buffer_head * breada(dev_t dev,int block, int size, extern struct buffer_head * breada(dev_t dev,int block, int size,
unsigned int pos, unsigned int filesize); unsigned int pos, unsigned int filesize);
extern void put_super(dev_t dev); extern void put_super(dev_t dev);
unsigned long generate_cluster(dev_t dev, int b[], int size);
extern dev_t ROOT_DEV; extern dev_t ROOT_DEV;
extern void show_buffers(void); extern void show_buffers(void);
......
...@@ -217,6 +217,7 @@ extern unsigned short * mem_map; ...@@ -217,6 +217,7 @@ extern unsigned short * mem_map;
#define GFP_ATOMIC 0x01 #define GFP_ATOMIC 0x01
#define GFP_USER 0x02 #define GFP_USER 0x02
#define GFP_KERNEL 0x03 #define GFP_KERNEL 0x03
#define GFP_NOBUFFER 0x04
/* vm_ops not present page codes */ /* vm_ops not present page codes */
......
...@@ -14,6 +14,7 @@ ...@@ -14,6 +14,7 @@
/* /*
* These are system calls that will be removed at some time * These are system calls that will be removed at some time
* due to newer versions existing.. * due to newer versions existing..
* (please be careful - ibcs2 may need some of these).
*/ */
#ifdef notdef #ifdef notdef
#define _sys_waitpid _sys_old_syscall /* _sys_wait4 */ #define _sys_waitpid _sys_old_syscall /* _sys_wait4 */
...@@ -32,6 +33,5 @@ ...@@ -32,6 +33,5 @@
* but have an entry in the table for future expansion.. * but have an entry in the table for future expansion..
*/ */
#define _sys_quotactl _sys_ni_syscall #define _sys_quotactl _sys_ni_syscall
#define _sys_bdflush _sys_ni_syscall
#endif #endif
...@@ -470,12 +470,12 @@ static int swap_out(unsigned int priority) ...@@ -470,12 +470,12 @@ static int swap_out(unsigned int priority)
#endif #endif
static int try_to_free_page(void) static int try_to_free_page(int priority)
{ {
int i=6; int i=6;
while (i--) { while (i--) {
if (shrink_buffers(i)) if (priority != GFP_NOBUFFER && shrink_buffers(i))
return 1; return 1;
if (shm_swap(i)) if (shm_swap(i))
return 1; return 1;
...@@ -545,6 +545,17 @@ void free_pages(unsigned long addr, unsigned long order) ...@@ -545,6 +545,17 @@ void free_pages(unsigned long addr, unsigned long order)
if (!--*map) if (!--*map)
free_pages_ok(addr, order); free_pages_ok(addr, order);
restore_flags(flag); restore_flags(flag);
if(*map == 1) {
int j;
struct buffer_head * bh, *tmp;
bh = buffer_pages[MAP_NR(addr)];
if(bh)
for(j = 0, tmp = bh; tmp && (!j || tmp != bh);
tmp = tmp->b_this_page, j++)
if(tmp->b_list == BUF_SHARED && tmp->b_dev != 0xffff)
refile_buffer(tmp);
}
} }
return; return;
} }
...@@ -610,7 +621,7 @@ unsigned long __get_free_pages(int priority, unsigned long order) ...@@ -610,7 +621,7 @@ unsigned long __get_free_pages(int priority, unsigned long order)
return 0; return 0;
} }
restore_flags(flags); restore_flags(flags);
if (priority != GFP_BUFFER && try_to_free_page()) if (priority != GFP_BUFFER && try_to_free_page(priority))
goto repeat; goto repeat;
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment