Commit 0b098c16 authored by Linus Torvalds's avatar Linus Torvalds

[PATCH] Linux-0.96b (June 21, 1992)

First cut at core-dumping.  Also, do more dynamic boottime memory
allocation, rather than allocating data structures statically.

Allocate task structures at run-time rather than having a big array of
them.

First "obsolete" system call.  The old "stat()" system call was too
limited, due to "struct stat" having various 16-bit fields etc (notably
inode numbers).  We make a new stat() function, and keep the old one
around as "old_stat()" for binary compatibility.

We also need a bigger "utsname" to hold real node names.

Whoo! NR_OPEN is now 32 rather than 20.

itimer() support driven by X11 adoption (Darren Senn).

gcc starts using fsqrt, so that gets added to the FP emulation.  We're
still basing that on my trivial code.

[Original changelog below]

0.96b is not a new major release: it's pretty close to 0.96a with all my
patches (1-4).  However, as there has been 4 patches already, I decided
it would be time for a full kernel release along with a bootimage, so
that people who don't feel confident with patching can use the new
features.

If you already have 0.96a patchlevel 4, 0.96b will offer you these new
features:

 - the math-emulation now handles fsqrt, as gcc-2.2.2 generates that
   inline.  I haven't tested the kernel code at all: I tested the
   algorithm in user space, but I'm lazy, so I never turned off my 387
   to do real testing.  I hope it works.
 - better vt100 terminal emulation thanks to Mika Liljeberg.
 - I removed a possible race-condition in the buffer-cache code.
 - minor fixes

The vt100 emulation should now be complete enough for almost everything
(including vt100 test suites): as a result the setterm utility had to be
changed (as the old setterm codes aren't compatible with the full vt100
codes).  setterm-0.96b.tar.Z contains the new setterm.

The soon-to-be-released gcc-2.2.2 will need the 0.96b kernel: (a) due to
the fsqrt emulation and (b) it uses the new stat() system call.  So
upgrading is a good idea.  (If you have a co-processor, (a) isn't used,
but (b) still stands)

If you have an unpatched 0.96a, the differences to 0.96b are roughly
(not counting the above-mentioned new things):

 - corrected the disk-buffer-list bug with read/write-errors
 - fixed read-ahead warning messages at end of disk
 - better support for text-mode restoration after running MGR and X
 - full core-dumping, attach/detach etc debugging features
 - 16550A support
 - less low 1MB memory used for kernel structures
 - various minor fixes

Note that the fact that new versions (pl4 and above) use more memory in
the 1M+ area means that linux will report less free memory (it's used
for buffer-cache instead).  This could concievably be a problem on 2MB
machines.  The standard kernel comes with only 4 pty's though, and if
you use the standard 80x25 text modes instead of svga modes, the VC
buffers will be smaller.  Please contact me if there are problems even
with this minimal setup.

0.96b does /not/ contain: the new scsi drivers, new filesystems or some
other patches I have gotten (ibm character set mode, loop-devices etc).
If you have sent me any other patch, you might want to remind me about
it.

                Linus
parent a5dcf393
...@@ -195,6 +195,6 @@ init/main.o : init/main.c include/stddef.h include/stdarg.h include/fcntl.h incl ...@@ -195,6 +195,6 @@ init/main.o : init/main.c include/stddef.h include/stdarg.h include/fcntl.h incl
include/time.h include/asm/system.h include/asm/io.h include/linux/config.h \ include/time.h include/asm/system.h include/asm/io.h include/linux/config.h \
include/linux/config_rel.h include/linux/config_ver.h include/linux/config.dist.h \ include/linux/config_rel.h include/linux/config_ver.h include/linux/config.dist.h \
include/linux/sched.h include/linux/head.h include/linux/fs.h include/sys/dirent.h \ include/linux/sched.h include/linux/head.h include/linux/fs.h include/sys/dirent.h \
include/limits.h include/linux/mm.h include/linux/kernel.h include/signal.h \ include/limits.h include/sys/vfs.h include/linux/mm.h include/linux/kernel.h \
include/sys/param.h include/sys/time.h include/sys/resource.h include/linux/tty.h \ include/signal.h include/sys/param.h include/sys/time.h include/sys/resource.h \
include/termios.h include/linux/unistd.h include/linux/tty.h include/termios.h include/linux/unistd.h
...@@ -43,44 +43,46 @@ dep: ...@@ -43,44 +43,46 @@ dep:
### Dependencies: ### Dependencies:
block_dev.o : block_dev.c ../include/errno.h ../include/linux/sched.h ../include/linux/head.h \ block_dev.o : block_dev.c ../include/errno.h ../include/linux/sched.h ../include/linux/head.h \
../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \ ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \ ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \
../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/asm/segment.h \ ../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \
../include/asm/system.h ../include/asm/segment.h ../include/asm/system.h
buffer.o : buffer.c ../include/stdarg.h ../include/linux/config.h ../include/linux/config_rel.h \ buffer.o : buffer.c ../include/stdarg.h ../include/linux/config.h ../include/linux/config_rel.h \
../include/linux/config_ver.h ../include/linux/config.dist.h ../include/linux/sched.h \ ../include/linux/config_ver.h ../include/linux/config.dist.h ../include/linux/sched.h \
../include/linux/head.h ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h \ ../include/linux/head.h ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h \
../include/limits.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \ ../include/limits.h ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h \
../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \ ../include/signal.h ../include/sys/param.h ../include/sys/time.h ../include/time.h \
../include/asm/system.h ../include/asm/io.h ../include/sys/resource.h ../include/asm/system.h ../include/asm/io.h
exec.o : exec.c ../include/signal.h ../include/sys/types.h ../include/errno.h \ exec.o : exec.c ../include/signal.h ../include/sys/types.h ../include/errno.h \
../include/linux/string.h ../include/sys/stat.h ../include/a.out.h ../include/linux/fs.h \ ../include/linux/string.h ../include/linux/stat.h ../include/sys/ptrace.h ../include/a.out.h \
../include/sys/dirent.h ../include/limits.h ../include/linux/sched.h ../include/linux/head.h \ ../include/fcntl.h ../include/linux/fs.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/mm.h ../include/linux/kernel.h ../include/sys/param.h ../include/sys/time.h \ ../include/sys/vfs.h ../include/linux/sched.h ../include/linux/head.h ../include/linux/mm.h \
../include/time.h ../include/sys/resource.h ../include/asm/segment.h ../include/linux/kernel.h ../include/sys/param.h ../include/sys/time.h ../include/time.h \
../include/sys/resource.h ../include/asm/segment.h ../include/sys/user.h
fcntl.o : fcntl.c ../include/errno.h ../include/fcntl.h ../include/sys/types.h \ fcntl.o : fcntl.c ../include/errno.h ../include/fcntl.h ../include/sys/types.h \
../include/sys/stat.h ../include/asm/segment.h ../include/linux/string.h ../include/linux/sched.h \ ../include/linux/stat.h ../include/asm/segment.h ../include/linux/string.h ../include/linux/sched.h \
../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h ../include/limits.h \ ../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \ ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \
../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h
file_table.o : file_table.c ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h \ file_table.o : file_table.c ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h \
../include/limits.h ../include/limits.h ../include/sys/vfs.h
inode.o : inode.c ../include/linux/string.h ../include/sys/stat.h ../include/sys/types.h \ inode.o : inode.c ../include/linux/string.h ../include/linux/stat.h ../include/linux/sched.h \
../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h \ ../include/linux/head.h ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h \
../include/limits.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \ ../include/limits.h ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h \
../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \
../include/asm/system.h
ioctl.o : ioctl.c ../include/linux/string.h ../include/errno.h ../include/sys/stat.h \
../include/sys/types.h ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \
../include/sys/dirent.h ../include/limits.h ../include/linux/mm.h ../include/linux/kernel.h \
../include/signal.h ../include/sys/param.h ../include/sys/time.h ../include/time.h \ ../include/signal.h ../include/sys/param.h ../include/sys/time.h ../include/time.h \
../include/sys/resource.h ../include/sys/resource.h ../include/asm/system.h
namei.o : namei.c ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \ ioctl.o : ioctl.c ../include/linux/string.h ../include/errno.h ../include/linux/stat.h \
../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/linux/mm.h \ ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h ../include/sys/types.h \
../include/sys/dirent.h ../include/limits.h ../include/sys/vfs.h ../include/linux/mm.h \
../include/linux/kernel.h ../include/signal.h ../include/sys/param.h ../include/sys/time.h \ ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h ../include/sys/time.h \
../include/time.h ../include/sys/resource.h ../include/asm/segment.h ../include/linux/string.h \ ../include/time.h ../include/sys/resource.h
../include/fcntl.h ../include/errno.h ../include/const.h ../include/sys/stat.h namei.o : namei.c ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \
../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/sys/vfs.h \
../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \
../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/asm/segment.h \
../include/linux/string.h ../include/fcntl.h ../include/errno.h ../include/const.h \
../include/linux/stat.h
open.o : open.c ../include/errno.h ../include/fcntl.h ../include/sys/types.h \ open.o : open.c ../include/errno.h ../include/fcntl.h ../include/sys/types.h \
../include/utime.h ../include/sys/stat.h ../include/sys/vfs.h ../include/linux/string.h \ ../include/utime.h ../include/sys/vfs.h ../include/linux/stat.h ../include/linux/string.h \
../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h \ ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h \
../include/limits.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \ ../include/limits.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \
../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \ ../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \
...@@ -88,27 +90,28 @@ open.o : open.c ../include/errno.h ../include/fcntl.h ../include/sys/types.h \ ...@@ -88,27 +90,28 @@ open.o : open.c ../include/errno.h ../include/fcntl.h ../include/sys/types.h \
pipe.o : pipe.c ../include/signal.h ../include/sys/types.h ../include/errno.h \ pipe.o : pipe.c ../include/signal.h ../include/sys/types.h ../include/errno.h \
../include/termios.h ../include/fcntl.h ../include/asm/segment.h ../include/linux/sched.h \ ../include/termios.h ../include/fcntl.h ../include/asm/segment.h ../include/linux/sched.h \
../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h ../include/limits.h \ ../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/mm.h ../include/linux/kernel.h ../include/sys/param.h ../include/sys/time.h \ ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h ../include/sys/param.h \
../include/time.h ../include/sys/resource.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h
read_write.o : read_write.c ../include/errno.h ../include/sys/types.h ../include/sys/stat.h \ read_write.o : read_write.c ../include/errno.h ../include/sys/types.h ../include/sys/dirent.h \
../include/sys/dirent.h ../include/limits.h ../include/linux/kernel.h ../include/linux/sched.h \ ../include/limits.h ../include/linux/stat.h ../include/linux/kernel.h ../include/linux/sched.h \
../include/linux/head.h ../include/linux/fs.h ../include/linux/mm.h ../include/signal.h \ ../include/linux/head.h ../include/linux/fs.h ../include/sys/vfs.h ../include/linux/mm.h \
../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \ ../include/signal.h ../include/sys/param.h ../include/sys/time.h ../include/time.h \
../include/linux/minix_fs.h ../include/asm/segment.h ../include/sys/resource.h ../include/linux/minix_fs.h ../include/asm/segment.h
select.o : select.c ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h \ select.o : select.c ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h \
../include/limits.h ../include/linux/kernel.h ../include/linux/tty.h ../include/asm/system.h \ ../include/limits.h ../include/sys/vfs.h ../include/linux/kernel.h ../include/linux/tty.h \
../include/termios.h ../include/linux/sched.h ../include/linux/head.h ../include/linux/mm.h \ ../include/asm/system.h ../include/termios.h ../include/linux/sched.h ../include/linux/head.h \
../include/linux/mm.h ../include/signal.h ../include/sys/param.h ../include/sys/time.h \
../include/time.h ../include/sys/resource.h ../include/linux/string.h ../include/linux/stat.h \
../include/asm/segment.h ../include/const.h ../include/errno.h
stat.o : stat.c ../include/errno.h ../include/linux/stat.h ../include/linux/fs.h \
../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/sys/vfs.h \
../include/linux/sched.h ../include/linux/head.h ../include/linux/mm.h ../include/linux/kernel.h \
../include/signal.h ../include/sys/param.h ../include/sys/time.h ../include/time.h \ ../include/signal.h ../include/sys/param.h ../include/sys/time.h ../include/time.h \
../include/sys/resource.h ../include/linux/string.h ../include/asm/segment.h \ ../include/sys/resource.h ../include/asm/segment.h
../include/sys/stat.h ../include/const.h ../include/errno.h
stat.o : stat.c ../include/errno.h ../include/sys/stat.h ../include/sys/types.h \
../include/linux/fs.h ../include/sys/dirent.h ../include/limits.h ../include/linux/sched.h \
../include/linux/head.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \
../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \
../include/asm/segment.h
super.o : super.c ../include/linux/config.h ../include/linux/config_rel.h ../include/linux/config_ver.h \ super.o : super.c ../include/linux/config.h ../include/linux/config_rel.h ../include/linux/config_ver.h \
../include/linux/config.dist.h ../include/linux/sched.h ../include/linux/head.h \ ../include/linux/config.dist.h ../include/linux/sched.h ../include/linux/head.h \
../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \ ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \ ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \
../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/linux/minix_fs.h \ ../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \
../include/asm/system.h ../include/asm/segment.h ../include/errno.h ../include/sys/stat.h ../include/linux/minix_fs.h ../include/linux/stat.h ../include/asm/system.h \
../include/asm/segment.h ../include/errno.h
...@@ -273,11 +273,9 @@ struct buffer_head * getblk(int dev,int block) ...@@ -273,11 +273,9 @@ struct buffer_head * getblk(int dev,int block)
wait_on_buffer(bh); wait_on_buffer(bh);
if (bh->b_count) if (bh->b_count)
goto repeat; goto repeat;
while (bh->b_dirt) { if (bh->b_dirt) {
sync_buffers(bh->b_dev); sync_buffers(bh->b_dev);
wait_on_buffer(bh); goto repeat;
if (bh->b_count)
goto repeat;
} }
/* NOTE!! While we slept waiting for this block, somebody else might */ /* NOTE!! While we slept waiting for this block, somebody else might */
/* already have added "this" block to the cache. check it */ /* already have added "this" block to the cache. check it */
......
...@@ -40,50 +40,55 @@ dep: ...@@ -40,50 +40,55 @@ dep:
### Dependencies: ### Dependencies:
bitmap.o : bitmap.c ../../include/linux/string.h ../../include/linux/sched.h \ bitmap.o : bitmap.c ../../include/linux/string.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/sys/dirent.h ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/linux/kernel.h ../../include/signal.h ../../include/sys/param.h \
../../include/sys/resource.h ../../include/linux/minix_fs.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h ../../include/linux/minix_fs.h
blkdev.o : blkdev.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \ blkdev.o : blkdev.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \
../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \ ../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \
../../include/linux/mm.h ../../include/linux/kernel.h ../../include/signal.h \ ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/linux/minix_fs.h ../../include/linux/tty.h ../../include/asm/system.h \ ../../include/sys/resource.h ../../include/linux/minix_fs.h ../../include/linux/tty.h \
../../include/termios.h ../../include/errno.h ../../include/fcntl.h ../../include/sys/stat.h ../../include/asm/system.h ../../include/termios.h ../../include/linux/stat.h \
../../include/errno.h ../../include/fcntl.h
chrdev.o : chrdev.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \ chrdev.o : chrdev.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \
../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \ ../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \
../../include/linux/mm.h ../../include/linux/kernel.h ../../include/signal.h \ ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/linux/minix_fs.h ../../include/linux/tty.h ../../include/asm/system.h \ ../../include/sys/resource.h ../../include/linux/minix_fs.h ../../include/linux/tty.h \
../../include/termios.h ../../include/errno.h ../../include/fcntl.h ../../include/sys/stat.h ../../include/asm/system.h ../../include/termios.h ../../include/linux/stat.h \
dir.o : dir.c ../../include/errno.h ../../include/sys/stat.h ../../include/sys/types.h \ ../../include/errno.h ../../include/fcntl.h
../../include/asm/segment.h ../../include/linux/fs.h ../../include/sys/dirent.h \ dir.o : dir.c ../../include/errno.h ../../include/asm/segment.h ../../include/linux/fs.h \
../../include/limits.h ../../include/linux/minix_fs.h ../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \
../../include/sys/vfs.h ../../include/linux/minix_fs.h ../../include/linux/stat.h
file.o : file.c ../../include/errno.h ../../include/fcntl.h ../../include/sys/types.h \ file.o : file.c ../../include/errno.h ../../include/fcntl.h ../../include/sys/types.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/sys/stat.h ../../include/asm/segment.h \ ../../include/sys/dirent.h ../../include/limits.h ../../include/asm/segment.h \
../../include/asm/system.h ../../include/linux/sched.h ../../include/linux/head.h \ ../../include/asm/system.h ../../include/linux/sched.h ../../include/linux/head.h \
../../include/linux/fs.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/linux/fs.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/sys/resource.h ../../include/linux/minix_fs.h
inode.o : inode.c ../../include/linux/string.h ../../include/sys/stat.h ../../include/sys/types.h \
../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/sys/resource.h ../../include/linux/minix_fs.h ../../include/asm/system.h ../../include/sys/resource.h ../../include/linux/minix_fs.h ../../include/linux/stat.h
inode.o : inode.c ../../include/linux/string.h ../../include/linux/stat.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h \
../../include/linux/kernel.h ../../include/signal.h ../../include/sys/param.h \
../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h ../../include/linux/minix_fs.h \
../../include/asm/system.h ../../include/asm/segment.h
namei.o : namei.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \ namei.o : namei.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \
../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \ ../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \
../../include/linux/mm.h ../../include/linux/kernel.h ../../include/signal.h \ ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/linux/minix_fs.h ../../include/asm/segment.h ../../include/linux/string.h \ ../../include/sys/resource.h ../../include/linux/minix_fs.h ../../include/linux/string.h \
../../include/fcntl.h ../../include/errno.h ../../include/const.h ../../include/sys/stat.h ../../include/linux/stat.h ../../include/asm/segment.h ../../include/fcntl.h \
symlink.o : symlink.c ../../include/errno.h ../../include/sys/stat.h ../../include/sys/types.h \ ../../include/errno.h ../../include/const.h
../../include/asm/segment.h ../../include/linux/sched.h ../../include/linux/head.h \ symlink.o : symlink.c ../../include/errno.h ../../include/asm/segment.h ../../include/linux/sched.h \
../../include/linux/fs.h ../../include/sys/dirent.h ../../include/limits.h ../../include/linux/mm.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h \
../../include/linux/kernel.h ../../include/signal.h ../../include/sys/param.h \ ../../include/linux/kernel.h ../../include/signal.h ../../include/sys/param.h \
../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h ../../include/linux/minix_fs.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h ../../include/linux/minix_fs.h \
../../include/linux/stat.h
truncate.o : truncate.c ../../include/linux/sched.h ../../include/linux/head.h \ truncate.o : truncate.c ../../include/linux/sched.h ../../include/linux/head.h \
../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \ ../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/sys/resource.h ../../include/linux/minix_fs.h ../../include/linux/tty.h \ ../../include/sys/resource.h ../../include/linux/minix_fs.h ../../include/linux/tty.h \
../../include/asm/system.h ../../include/termios.h ../../include/errno.h ../../include/fcntl.h \ ../../include/asm/system.h ../../include/termios.h ../../include/linux/stat.h \
../../include/sys/stat.h ../../include/errno.h ../../include/fcntl.h
#define UTS_RELEASE "0.96a-35" #define UTS_RELEASE "0.96a-37"
#define UTS_VERSION "06/17/92" #define UTS_VERSION "06/20/92"
...@@ -177,6 +177,10 @@ void fmul(const temp_real *, const temp_real *, temp_real *); ...@@ -177,6 +177,10 @@ void fmul(const temp_real *, const temp_real *, temp_real *);
void fdiv(const temp_real *, const temp_real *, temp_real *); void fdiv(const temp_real *, const temp_real *, temp_real *);
/* sqrt.c */
void fsqrt(const temp_real *, temp_real *);
/* compare.c */ /* compare.c */
void fcom(const temp_real *, const temp_real *); void fcom(const temp_real *, const temp_real *);
......
...@@ -183,7 +183,7 @@ extern long lp_init(long); ...@@ -183,7 +183,7 @@ extern long lp_init(long);
extern long con_init(long); extern long con_init(long);
extern long tty_init(long); extern long tty_init(long);
extern void flush(struct tty_queue * queue); extern void flush_input(struct tty_struct * tty);
extern int tty_ioctl(struct inode *, struct file *, unsigned int, unsigned int); extern int tty_ioctl(struct inode *, struct file *, unsigned int, unsigned int);
extern int is_orphaned_pgrp(int pgrp); extern int is_orphaned_pgrp(int pgrp);
......
#ifndef _SYS_STAT_H
#define _SYS_STAT_H
#include <sys/types.h>
struct stat {
dev_t st_dev;
ino_t st_ino;
umode_t st_mode;
nlink_t st_nlink;
uid_t st_uid;
gid_t st_gid;
dev_t st_rdev;
off_t st_size;
time_t st_atime;
time_t st_mtime;
time_t st_ctime;
};
#define S_IFMT 00170000
#define S_IFSOCK 0140000
#define S_IFLNK 0120000
#define S_IFREG 0100000
#define S_IFBLK 0060000
#define S_IFDIR 0040000
#define S_IFCHR 0020000
#define S_IFIFO 0010000
#define S_ISUID 0004000
#define S_ISGID 0002000
#define S_ISVTX 0001000
#define S_ISLNK(m) (((m) & S_IFMT) == S_IFLNK)
#define S_ISREG(m) (((m) & S_IFMT) == S_IFREG)
#define S_ISDIR(m) (((m) & S_IFMT) == S_IFDIR)
#define S_ISCHR(m) (((m) & S_IFMT) == S_IFCHR)
#define S_ISBLK(m) (((m) & S_IFMT) == S_IFBLK)
#define S_ISFIFO(m) (((m) & S_IFMT) == S_IFIFO)
#define S_ISSOCK(m) (((m) & S_IFMT) == S_IFSOCK)
#define S_IRWXU 00700
#define S_IRUSR 00400
#define S_IWUSR 00200
#define S_IXUSR 00100
#define S_IRWXG 00070
#define S_IRGRP 00040
#define S_IWGRP 00020
#define S_IXGRP 00010
#define S_IRWXO 00007
#define S_IROTH 00004
#define S_IWOTH 00002
#define S_IXOTH 00001
extern int chmod(const char *_path, mode_t mode);
extern int fstat(int fildes, struct stat *stat_buf);
extern int mkdir(const char *_path, mode_t mode);
extern int mkfifo(const char *_path, mode_t mode);
extern int stat(const char *filename, struct stat *stat_buf);
extern mode_t umask(mode_t mask);
#endif
#ifndef _SYS_UTSNAME_H
#define _SYS_UTSNAME_H
#include <sys/types.h>
#include <sys/param.h>
struct utsname {
char sysname[9];
char nodename[MAXHOSTNAMELEN+1];
char release[9];
char version[9];
char machine[9];
};
extern int uname(struct utsname * utsbuf);
#endif
...@@ -60,54 +60,60 @@ dep: ...@@ -60,54 +60,60 @@ dep:
### Dependencies: ### Dependencies:
exit.s exit.o : exit.c ../include/errno.h ../include/signal.h ../include/sys/types.h \ exit.s exit.o : exit.c ../include/errno.h ../include/signal.h ../include/sys/types.h \
../include/sys/wait.h ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \ ../include/sys/wait.h ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \
../include/sys/dirent.h ../include/limits.h ../include/linux/mm.h ../include/linux/kernel.h \ ../include/sys/dirent.h ../include/limits.h ../include/sys/vfs.h ../include/linux/mm.h \
../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \ ../include/linux/kernel.h ../include/sys/param.h ../include/sys/time.h ../include/time.h \
../include/linux/tty.h ../include/asm/system.h ../include/termios.h ../include/asm/segment.h ../include/sys/resource.h ../include/linux/tty.h ../include/asm/system.h ../include/termios.h \
../include/asm/segment.h
fork.s fork.o : fork.c ../include/errno.h ../include/stddef.h ../include/linux/sched.h \ fork.s fork.o : fork.c ../include/errno.h ../include/stddef.h ../include/linux/sched.h \
../include/linux/head.h ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h \ ../include/linux/head.h ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h \
../include/limits.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \ ../include/limits.h ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h \
../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \ ../include/signal.h ../include/sys/param.h ../include/sys/time.h ../include/time.h \
../include/asm/segment.h ../include/asm/system.h ../include/sys/resource.h ../include/asm/segment.h ../include/asm/system.h
ioport.s ioport.o : ioport.c ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \ ioport.s ioport.o : ioport.c ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \
../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/linux/mm.h \ ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/sys/vfs.h \
../include/linux/kernel.h ../include/signal.h ../include/sys/param.h ../include/sys/time.h \ ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \
../include/time.h ../include/sys/resource.h ../include/errno.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/errno.h
itimer.s itimer.o : itimer.c ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \
../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/sys/vfs.h \
../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \
../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/asm/segment.h \
../include/errno.h
mktime.s mktime.o : mktime.c ../include/time.h mktime.s mktime.o : mktime.c ../include/time.h
panic.s panic.o : panic.c ../include/linux/kernel.h ../include/linux/sched.h ../include/linux/head.h \ panic.s panic.o : panic.c ../include/linux/kernel.h ../include/linux/sched.h ../include/linux/head.h \
../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \ ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/mm.h ../include/signal.h ../include/sys/param.h ../include/sys/time.h \ ../include/sys/vfs.h ../include/linux/mm.h ../include/signal.h ../include/sys/param.h \
../include/time.h ../include/sys/resource.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h
printk.s printk.o : printk.c ../include/stdarg.h ../include/stddef.h ../include/errno.h \ printk.s printk.o : printk.c ../include/stdarg.h ../include/stddef.h ../include/errno.h \
../include/asm/segment.h ../include/asm/system.h ../include/linux/sched.h ../include/linux/head.h \ ../include/asm/segment.h ../include/asm/system.h ../include/linux/sched.h ../include/linux/head.h \
../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \ ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \ ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \
../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h
ptrace.s ptrace.o : ptrace.c ../include/linux/head.h ../include/linux/kernel.h ../include/linux/sched.h \ ptrace.s ptrace.o : ptrace.c ../include/linux/head.h ../include/linux/kernel.h ../include/linux/sched.h \
../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \ ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/mm.h ../include/signal.h ../include/sys/param.h ../include/sys/time.h \ ../include/sys/vfs.h ../include/linux/mm.h ../include/signal.h ../include/sys/param.h \
../include/time.h ../include/sys/resource.h ../include/errno.h ../include/asm/segment.h \ ../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/asm/segment.h \
../include/asm/system.h ../include/sys/ptrace.h ../include/asm/system.h ../include/errno.h ../include/sys/ptrace.h
sched.s sched.o : sched.c ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \ sched.s sched.o : sched.c ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \
../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/linux/mm.h \ ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/sys/vfs.h \
../include/linux/kernel.h ../include/signal.h ../include/sys/param.h ../include/sys/time.h \ ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \
../include/time.h ../include/sys/resource.h ../include/linux/timer.h ../include/linux/sys.h \ ../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/linux/timer.h \
../include/linux/fdreg.h ../include/asm/system.h ../include/asm/io.h ../include/asm/segment.h \ ../include/linux/sys.h ../include/linux/fdreg.h ../include/asm/system.h ../include/asm/io.h \
../include/errno.h ../include/asm/segment.h ../include/errno.h
signal.s signal.o : signal.c ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \ signal.s signal.o : signal.c ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \
../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/linux/mm.h \ ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/sys/vfs.h \
../include/linux/kernel.h ../include/signal.h ../include/sys/param.h ../include/sys/time.h \ ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \
../include/time.h ../include/sys/resource.h ../include/asm/segment.h ../include/sys/wait.h \ ../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/asm/segment.h \
../include/errno.h ../include/sys/wait.h ../include/sys/ptrace.h ../include/errno.h
sys.s sys.o : sys.c ../include/errno.h ../include/linux/sched.h ../include/linux/head.h \ sys.s sys.o : sys.c ../include/errno.h ../include/linux/sched.h ../include/linux/head.h \
../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \ ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \ ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \
../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/linux/tty.h \ ../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \
../include/asm/system.h ../include/termios.h ../include/linux/config.h ../include/linux/config_rel.h \ ../include/linux/tty.h ../include/asm/system.h ../include/termios.h ../include/linux/config.h \
../include/linux/config_ver.h ../include/linux/config.dist.h ../include/asm/segment.h \ ../include/linux/config_rel.h ../include/linux/config_ver.h ../include/linux/config.dist.h \
../include/sys/times.h ../include/sys/utsname.h ../include/linux/string.h ../include/asm/segment.h ../include/sys/times.h ../include/linux/utsname.h ../include/linux/string.h
traps.s traps.o : traps.c ../include/linux/string.h ../include/linux/head.h ../include/linux/sched.h \ traps.s traps.o : traps.c ../include/linux/string.h ../include/linux/head.h ../include/linux/sched.h \
../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \ ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \ ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \
../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/asm/system.h \ ../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \
../include/asm/segment.h ../include/asm/io.h ../include/errno.h ../include/asm/system.h ../include/asm/segment.h ../include/asm/io.h ../include/errno.h
vsprintf.s vsprintf.o : vsprintf.c ../include/stdarg.h ../include/linux/string.h vsprintf.s vsprintf.o : vsprintf.c ../include/stdarg.h ../include/linux/string.h
...@@ -48,29 +48,30 @@ dep: ...@@ -48,29 +48,30 @@ dep:
### Dependencies: ### Dependencies:
floppy.s floppy.o : floppy.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \ floppy.s floppy.o : floppy.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \
../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \ ../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \
../../include/linux/mm.h ../../include/linux/kernel.h ../../include/signal.h \ ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/linux/timer.h ../../include/linux/fdreg.h ../../include/linux/fd.h \ ../../include/sys/resource.h ../../include/linux/timer.h ../../include/linux/fdreg.h \
../../include/asm/system.h ../../include/asm/io.h ../../include/asm/segment.h \ ../../include/linux/fd.h ../../include/asm/system.h ../../include/asm/io.h ../../include/asm/segment.h \
../../include/errno.h blk.h ../../include/errno.h blk.h
hd.s hd.o : hd.c ../../include/errno.h ../../include/linux/config.h ../../include/linux/config_rel.h \ hd.s hd.o : hd.c ../../include/errno.h ../../include/linux/config.h ../../include/linux/config_rel.h \
../../include/linux/config_ver.h ../../include/linux/config.dist.h ../../include/linux/sched.h \ ../../include/linux/config_ver.h ../../include/linux/config.dist.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/sys/dirent.h ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/linux/kernel.h ../../include/signal.h ../../include/sys/param.h \
../../include/sys/resource.h ../../include/linux/timer.h ../../include/linux/hdreg.h \ ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h ../../include/linux/timer.h \
../../include/asm/system.h ../../include/asm/io.h ../../include/asm/segment.h \ ../../include/linux/hdreg.h ../../include/asm/system.h ../../include/asm/io.h \
blk.h ../../include/asm/segment.h blk.h
ll_rw_blk.s ll_rw_blk.o : ll_rw_blk.c ../../include/errno.h ../../include/linux/sched.h \ ll_rw_blk.s ll_rw_blk.o : ll_rw_blk.c ../../include/errno.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/sys/dirent.h ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/linux/kernel.h ../../include/signal.h ../../include/sys/param.h \
../../include/sys/resource.h ../../include/asm/system.h blk.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h ../../include/asm/system.h \
blk.h
ramdisk.s ramdisk.o : ramdisk.c ../../include/linux/string.h ../../include/linux/config.h \ ramdisk.s ramdisk.o : ramdisk.c ../../include/linux/string.h ../../include/linux/config.h \
../../include/linux/config_rel.h ../../include/linux/config_ver.h ../../include/linux/config.dist.h \ ../../include/linux/config_rel.h ../../include/linux/config_ver.h ../../include/linux/config.dist.h \
../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \ ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \
../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \ ../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \
../../include/linux/mm.h ../../include/linux/kernel.h ../../include/signal.h \ ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/linux/minix_fs.h ../../include/asm/system.h ../../include/asm/segment.h \ ../../include/sys/resource.h ../../include/linux/minix_fs.h ../../include/asm/system.h \
../../include/asm/memory.h blk.h ../../include/asm/segment.h ../../include/asm/memory.h blk.h
...@@ -112,7 +112,7 @@ void rd_load(void) ...@@ -112,7 +112,7 @@ void rd_load(void)
nblocks, rd_length >> BLOCK_SIZE_BITS); nblocks, rd_length >> BLOCK_SIZE_BITS);
return; return;
} }
printk("Loading %d bytes into ram disk... 0000k", printk("Loading %d bytes into ram disk\n",
nblocks << BLOCK_SIZE_BITS); nblocks << BLOCK_SIZE_BITS);
cp = rd_start; cp = rd_start;
while (nblocks) { while (nblocks) {
...@@ -127,12 +127,12 @@ void rd_load(void) ...@@ -127,12 +127,12 @@ void rd_load(void)
} }
(void) memcpy(cp, bh->b_data, BLOCK_SIZE); (void) memcpy(cp, bh->b_data, BLOCK_SIZE);
brelse(bh); brelse(bh);
printk("\010\010\010\010\010%4dk",i); if (!(nblocks-- & 15))
printk(".");
cp += BLOCK_SIZE; cp += BLOCK_SIZE;
block++; block++;
nblocks--;
i++; i++;
} }
printk("\010\010\010\010\010done \n"); printk("\ndone\n");
ROOT_DEV=0x0101; ROOT_DEV=0x0101;
} }
...@@ -48,7 +48,7 @@ dep: ...@@ -48,7 +48,7 @@ dep:
### Dependencies: ### Dependencies:
console.s console.o : console.c ../../include/linux/sched.h ../../include/linux/head.h \ console.s console.o : console.c ../../include/linux/sched.h ../../include/linux/head.h \
../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \ ../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/sys/resource.h ../../include/linux/timer.h ../../include/linux/tty.h \ ../../include/sys/resource.h ../../include/linux/timer.h ../../include/linux/tty.h \
../../include/asm/system.h ../../include/termios.h ../../include/linux/config.h \ ../../include/asm/system.h ../../include/termios.h ../../include/linux/config.h \
...@@ -57,51 +57,51 @@ console.s console.o : console.c ../../include/linux/sched.h ../../include/linux/ ...@@ -57,51 +57,51 @@ console.s console.o : console.c ../../include/linux/sched.h ../../include/linux/
../../include/errno.h ../../include/sys/kd.h vt_kern.h ../../include/errno.h ../../include/sys/kd.h vt_kern.h
keyboard.s keyboard.o : keyboard.c ../../include/linux/sched.h ../../include/linux/head.h \ keyboard.s keyboard.o : keyboard.c ../../include/linux/sched.h ../../include/linux/head.h \
../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \ ../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/sys/resource.h ../../include/linux/ctype.h ../../include/linux/tty.h \ ../../include/sys/resource.h ../../include/linux/ctype.h ../../include/linux/tty.h \
../../include/asm/system.h ../../include/termios.h ../../include/asm/io.h ../../include/asm/system.h ../../include/termios.h ../../include/asm/io.h
lp.s lp.o : lp.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \ lp.s lp.o : lp.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \
../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \ ../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \
../../include/linux/mm.h ../../include/linux/kernel.h ../../include/signal.h \ ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/linux/lp.h ../../include/errno.h ../../include/asm/io.h ../../include/asm/segment.h ../../include/sys/resource.h ../../include/linux/lp.h ../../include/errno.h \
../../include/asm/io.h ../../include/asm/segment.h
mem.s mem.o : mem.c ../../include/errno.h ../../include/sys/types.h ../../include/linux/sched.h \ mem.s mem.o : mem.c ../../include/errno.h ../../include/sys/types.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/dirent.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/sys/resource.h ../../include/linux/tty.h ../../include/asm/system.h \ ../../include/sys/resource.h ../../include/linux/tty.h ../../include/asm/system.h \
../../include/termios.h ../../include/asm/segment.h ../../include/asm/io.h ../../include/termios.h ../../include/asm/segment.h ../../include/asm/io.h
pty.s pty.o : pty.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \ pty.s pty.o : pty.c ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \
../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \ ../../include/sys/types.h ../../include/sys/dirent.h ../../include/limits.h \
../../include/linux/mm.h ../../include/linux/kernel.h ../../include/signal.h \ ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/linux/tty.h ../../include/asm/system.h ../../include/termios.h \ ../../include/sys/resource.h ../../include/linux/tty.h ../../include/asm/system.h \
../../include/asm/io.h ../../include/termios.h ../../include/asm/io.h
serial.s serial.o : serial.c ../../include/signal.h ../../include/sys/types.h ../../include/linux/sched.h \ serial.s serial.o : serial.c ../../include/signal.h ../../include/sys/types.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/dirent.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h \ ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h \
../../include/linux/timer.h ../../include/linux/tty.h ../../include/asm/system.h \ ../../include/linux/timer.h ../../include/linux/tty.h ../../include/asm/system.h \
../../include/termios.h ../../include/asm/io.h ../../include/termios.h ../../include/asm/io.h
tty_io.s tty_io.o : tty_io.c ../../include/linux/ctype.h ../../include/errno.h ../../include/signal.h \ tty_io.s tty_io.o : tty_io.c ../../include/errno.h ../../include/signal.h ../../include/sys/types.h \
../../include/sys/types.h ../../include/unistd.h ../../include/sys/stat.h ../../include/sys/time.h \ ../../include/fcntl.h ../../include/linux/sched.h ../../include/linux/head.h \
../../include/time.h ../../include/sys/times.h ../../include/sys/utsname.h ../../include/sys/param.h \ ../../include/linux/fs.h ../../include/sys/dirent.h ../../include/limits.h ../../include/sys/vfs.h \
../../include/sys/resource.h ../../include/utime.h ../../include/fcntl.h ../../include/linux/sched.h \ ../../include/linux/mm.h ../../include/linux/kernel.h ../../include/sys/param.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/dirent.h \ ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h ../../include/linux/tty.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/asm/system.h ../../include/termios.h ../../include/linux/ctype.h \
../../include/linux/tty.h ../../include/asm/system.h ../../include/termios.h \ ../../include/asm/io.h ../../include/asm/segment.h ../../include/sys/kd.h vt_kern.h
../../include/asm/io.h ../../include/asm/segment.h
tty_ioctl.s tty_ioctl.o : tty_ioctl.c ../../include/errno.h ../../include/termios.h ../../include/sys/types.h \ tty_ioctl.s tty_ioctl.o : tty_ioctl.c ../../include/errno.h ../../include/termios.h ../../include/sys/types.h \
../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \ ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/sys/dirent.h ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/linux/kernel.h ../../include/signal.h ../../include/sys/param.h \
../../include/sys/resource.h ../../include/linux/tty.h ../../include/asm/system.h \ ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h ../../include/linux/tty.h \
../../include/asm/io.h ../../include/asm/segment.h ../../include/asm/system.h ../../include/asm/io.h ../../include/asm/segment.h
vt.s vt.o : vt.c ../../include/errno.h ../../include/sys/types.h ../../include/sys/kd.h \ vt.s vt.o : vt.c ../../include/errno.h ../../include/sys/types.h ../../include/sys/kd.h \
../../include/sys/vt.h ../../include/asm/io.h ../../include/asm/segment.h ../../include/linux/sched.h \ ../../include/sys/vt.h ../../include/asm/io.h ../../include/asm/segment.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/dirent.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/sys/resource.h ../../include/linux/tty.h ../../include/asm/system.h \ ../../include/sys/resource.h ../../include/linux/tty.h ../../include/asm/system.h \
../../include/termios.h vt_kern.h ../../include/termios.h ../../include/linux/timer.h vt_kern.h
...@@ -46,16 +46,6 @@ ...@@ -46,16 +46,6 @@
#include <sys/kd.h> #include <sys/kd.h>
#include "vt_kern.h" #include "vt_kern.h"
#define DEF_TERMIOS \
(struct termios) { \
ICRNL, \
OPOST | ONLCR, \
0, \
IXON | ISIG | ICANON | ECHO | ECHOCTL | ECHOKE, \
0, \
INIT_C_CC \
}
/* /*
* These are set up by the setup-routine at boot-time: * These are set up by the setup-routine at boot-time:
*/ */
...@@ -81,10 +71,13 @@ extern void vt_init(void); ...@@ -81,10 +71,13 @@ extern void vt_init(void);
extern void keyboard_interrupt(void); extern void keyboard_interrupt(void);
extern void set_leds(void); extern void set_leds(void);
extern unsigned char kapplic; extern unsigned char kapplic;
extern unsigned char ckmode;
extern unsigned char krepeat;
extern unsigned char kleds; extern unsigned char kleds;
extern unsigned char kmode; extern unsigned char kmode;
extern unsigned char kraw; extern unsigned char kraw;
extern unsigned char ke0; extern unsigned char ke0;
extern unsigned char lfnlmode;
unsigned long video_num_columns; /* Number of text columns */ unsigned long video_num_columns; /* Number of text columns */
unsigned long video_num_lines; /* Number of test lines */ unsigned long video_num_lines; /* Number of test lines */
...@@ -96,31 +89,57 @@ static unsigned long video_size_row; /* Bytes per row */ ...@@ -96,31 +89,57 @@ static unsigned long video_size_row; /* Bytes per row */
static unsigned char video_page; /* Initial video page */ static unsigned char video_page; /* Initial video page */
static unsigned short video_port_reg; /* Video register select port */ static unsigned short video_port_reg; /* Video register select port */
static unsigned short video_port_val; /* Video register value port */ static unsigned short video_port_val; /* Video register value port */
static int can_do_colour = 0; static int can_do_color = 0;
static struct { static struct {
unsigned short vc_video_erase_char; unsigned short vc_video_erase_char; /* Current attributes & space */
unsigned char vc_attr; unsigned char vc_def_color; /* Default colors */
unsigned char vc_def_attr; unsigned char vc_color; /* Foreground & background */
int vc_bold_attr; unsigned char vc_s_color; /* Saved foreground & background */
unsigned long vc_ques; unsigned char vc_ulcolor; /* Colour for underline mode */
unsigned long vc_state; unsigned char vc_halfcolor; /* Colour for half intensity mode */
char * vc_restate;
unsigned long vc_checkin;
unsigned long vc_origin; /* Used for EGA/VGA fast scroll */ unsigned long vc_origin; /* Used for EGA/VGA fast scroll */
unsigned long vc_scr_end; /* Used for EGA/VGA fast scroll */ unsigned long vc_scr_end; /* Used for EGA/VGA fast scroll */
unsigned long vc_pos; unsigned long vc_pos;
unsigned long vc_x,vc_y; unsigned long vc_x,vc_y;
unsigned long vc_top,vc_bottom; unsigned long vc_top,vc_bottom;
unsigned long vc_state;
unsigned long vc_npar,vc_par[NPAR]; unsigned long vc_npar,vc_par[NPAR];
unsigned long vc_video_mem_start; /* Start of video RAM */ unsigned long vc_video_mem_start; /* Start of video RAM */
unsigned long vc_video_mem_end; /* End of video RAM (sort of) */ unsigned long vc_video_mem_end; /* End of video RAM (sort of) */
unsigned int vc_saved_x; unsigned long vc_saved_x;
unsigned int vc_saved_y; unsigned long vc_saved_y;
unsigned int vc_iscolor; /* mode flags */
unsigned char vc_kbdapplic; unsigned long vc_kbdapplic : 1; /* Application keyboard */
unsigned long vc_charset : 1; /* Character set G0 / G1 */
unsigned long vc_s_charset : 1; /* Saved character set */
unsigned long vc_decckm : 1; /* Cursor Keys Mode */
unsigned long vc_decscnm : 1; /* Screen Mode */
unsigned long vc_decom : 1; /* Origin Mode */
unsigned long vc_decawm : 1; /* Autowrap Mode */
unsigned long vc_decarm : 1; /* Autorepeat Mode */
unsigned long vc_deccm : 1; /* Cursor Visible */
unsigned long vc_decim : 1; /* Insert Mode */
unsigned long vc_lnm : 1; /* Line feed New line Mode */
/* attribute flags */
unsigned long vc_intensity : 2; /* 0=half-bright, 1=normal, 2=bold */
unsigned long vc_underline : 1;
unsigned long vc_blink : 1;
unsigned long vc_reverse : 1;
unsigned long vc_s_intensity : 2; /* saved rendition */
unsigned long vc_s_underline : 1;
unsigned long vc_s_blink : 1;
unsigned long vc_s_reverse : 1;
/* misc */
unsigned long vc_ques : 1;
unsigned long vc_need_wrap : 1;
unsigned long vc_tab_stop[5]; /* Tab stops. 160 columns. */
unsigned char vc_kbdmode; unsigned char vc_kbdmode;
char * vc_translate; char * vc_translate;
char * vc_G0_charset;
char * vc_G1_charset;
char * vc_saved_G0;
char * vc_saved_G1;
/* additional information is in vt_kern.h */ /* additional information is in vt_kern.h */
} vc_cons [NR_CONSOLES]; } vc_cons [NR_CONSOLES];
...@@ -138,25 +157,58 @@ static int console_blanked = 0; ...@@ -138,25 +157,58 @@ static int console_blanked = 0;
#define x (vc_cons[currcons].vc_x) #define x (vc_cons[currcons].vc_x)
#define y (vc_cons[currcons].vc_y) #define y (vc_cons[currcons].vc_y)
#define state (vc_cons[currcons].vc_state) #define state (vc_cons[currcons].vc_state)
#define restate (vc_cons[currcons].vc_restate)
#define checkin (vc_cons[currcons].vc_checkin)
#define npar (vc_cons[currcons].vc_npar) #define npar (vc_cons[currcons].vc_npar)
#define par (vc_cons[currcons].vc_par) #define par (vc_cons[currcons].vc_par)
#define ques (vc_cons[currcons].vc_ques) #define ques (vc_cons[currcons].vc_ques)
#define attr (vc_cons[currcons].vc_attr) #define attr (vc_cons[currcons].vc_video_erase_char >> 8)
#define saved_x (vc_cons[currcons].vc_saved_x) #define saved_x (vc_cons[currcons].vc_saved_x)
#define saved_y (vc_cons[currcons].vc_saved_y) #define saved_y (vc_cons[currcons].vc_saved_y)
#define translate (vc_cons[currcons].vc_translate) #define translate (vc_cons[currcons].vc_translate)
#define G0_charset (vc_cons[currcons].vc_G0_charset)
#define G1_charset (vc_cons[currcons].vc_G1_charset)
#define saved_G0 (vc_cons[currcons].vc_saved_G0)
#define saved_G1 (vc_cons[currcons].vc_saved_G1)
#define video_mem_start (vc_cons[currcons].vc_video_mem_start) #define video_mem_start (vc_cons[currcons].vc_video_mem_start)
#define video_mem_end (vc_cons[currcons].vc_video_mem_end) #define video_mem_end (vc_cons[currcons].vc_video_mem_end)
#define def_attr (vc_cons[currcons].vc_def_attr) #define video_erase_char (vc_cons[currcons].vc_video_erase_char)
#define video_erase_char (vc_cons[currcons].vc_video_erase_char) #define decckm (vc_cons[currcons].vc_decckm)
#define iscolor (vc_cons[currcons].vc_iscolor) #define decscnm (vc_cons[currcons].vc_decscnm)
#define decom (vc_cons[currcons].vc_decom)
#define decawm (vc_cons[currcons].vc_decawm)
#define decarm (vc_cons[currcons].vc_decarm)
#define deccm (vc_cons[currcons].vc_deccm)
#define decim (vc_cons[currcons].vc_decim)
#define lnm (vc_cons[currcons].vc_lnm)
#define kbdapplic (vc_cons[currcons].vc_kbdapplic) #define kbdapplic (vc_cons[currcons].vc_kbdapplic)
#define need_wrap (vc_cons[currcons].vc_need_wrap)
#define color (vc_cons[currcons].vc_color)
#define s_color (vc_cons[currcons].vc_s_color)
#define def_color (vc_cons[currcons].vc_def_color)
#define foreground (color & 0x0f)
#define background (color & 0xf0)
#define charset (vc_cons[currcons].vc_charset)
#define s_charset (vc_cons[currcons].vc_s_charset)
#define intensity (vc_cons[currcons].vc_intensity)
#define underline (vc_cons[currcons].vc_underline)
#define blink (vc_cons[currcons].vc_blink)
#define reverse (vc_cons[currcons].vc_reverse)
#define s_intensity (vc_cons[currcons].vc_s_intensity)
#define s_underline (vc_cons[currcons].vc_s_underline)
#define s_blink (vc_cons[currcons].vc_s_blink)
#define s_reverse (vc_cons[currcons].vc_s_reverse)
#define ulcolor (vc_cons[currcons].vc_ulcolor)
#define halfcolor (vc_cons[currcons].vc_halfcolor)
#define kbdmode (vc_cons[currcons].vc_kbdmode) #define kbdmode (vc_cons[currcons].vc_kbdmode)
#define tab_stop (vc_cons[currcons].vc_tab_stop)
#define kbdraw (vt_cons[currcons].vc_kbdraw) #define kbdraw (vt_cons[currcons].vc_kbdraw)
#define kbde0 (vt_cons[currcons].vc_kbde0) #define kbde0 (vt_cons[currcons].vc_kbde0)
#define kbdleds (vt_cons[currcons].vc_kbdleds) #define kbdleds (vt_cons[currcons].vc_kbdleds)
#define vtmode (vt_cons[currcons].vt_mode)
#define SET(mode,fg,v) \
(mode) = (v); \
if (currcons == fg_console) \
(fg) = (v)
int blankinterval = 5*60*HZ; int blankinterval = 5*60*HZ;
static int screen_size = 0; static int screen_size = 0;
...@@ -164,10 +216,10 @@ static int screen_size = 0; ...@@ -164,10 +216,10 @@ static int screen_size = 0;
static void sysbeep(void); static void sysbeep(void);
/* /*
* this is what the terminal answers to a ESC-Z or csi0c * this is what the terminal answers to a ESC-Z or csi0c query.
* query (= vt100 response).
*/ */
#define RESPONSE "\033[?1;2c" #define VT100ID "\033[?1;2c"
#define VT102ID "\033[?6c"
static char * translations[] = { static char * translations[] = {
/* 8-bit Latin-1 mapped to the PC charater set: '\0' means non-printable */ /* 8-bit Latin-1 mapped to the PC charater set: '\0' means non-printable */
...@@ -204,21 +256,45 @@ static char * translations[] = { ...@@ -204,21 +256,45 @@ static char * translations[] = {
#define NORM_TRANS (translations[0]) #define NORM_TRANS (translations[0])
#define GRAF_TRANS (translations[1]) #define GRAF_TRANS (translations[1])
/* NOTE! gotoxy thinks x==video_num_columns is ok */ static unsigned char color_table[] = { 0, 4, 2, 6, 1, 5, 3, 7,
static inline void gotoxy(int currcons, unsigned int new_x,unsigned int new_y) 8,12,10,14, 9,13,11,15 };
/*
* gotoxy() must verify all boundaries, because the arguments
* might also be negative. If the given position is out of
* bounds, the cursor is placed at the nearest margin.
*/
static void gotoxy(int currcons, int new_x, int new_y)
{ {
if (new_x > video_num_columns || new_y >= video_num_lines) int max_y;
return;
x = new_x; if (new_x < 0)
y = new_y; x = 0;
else
if (new_x >= video_num_columns)
x = video_num_columns - 1;
else
x = new_x;
if (decom) {
new_y += top;
max_y = bottom;
} else
max_y = video_num_lines;
if (new_y < 0)
y = 0;
else
if (new_y >= max_y)
y = max_y - 1;
else
y = new_y;
pos = origin + y*video_size_row + (x<<1); pos = origin + y*video_size_row + (x<<1);
} }
static inline void set_origin(int currcons) static void set_origin(int currcons)
{ {
if (video_type != VIDEO_TYPE_EGAC && video_type != VIDEO_TYPE_EGAM) if (video_type != VIDEO_TYPE_EGAC && video_type != VIDEO_TYPE_EGAM)
return; return;
if (currcons != fg_console || vt_cons[currcons].vt_mode == KD_GRAPHICS) if (currcons != fg_console || vtmode == KD_GRAPHICS)
return; return;
cli(); cli();
outb_p(12, video_port_reg); outb_p(12, video_port_reg);
...@@ -321,7 +397,7 @@ static void ri(int currcons) ...@@ -321,7 +397,7 @@ static void ri(int currcons)
scrdown(currcons,top,bottom); scrdown(currcons,top,bottom);
} }
static void cr(int currcons) static inline void cr(int currcons)
{ {
pos -= x<<1; pos -= x<<1;
x=0; x=0;
...@@ -347,7 +423,7 @@ static void csi_J(int currcons, int vpar) ...@@ -347,7 +423,7 @@ static void csi_J(int currcons, int vpar)
start = pos; start = pos;
break; break;
case 1: /* erase from start to cursor */ case 1: /* erase from start to cursor */
count = (pos-origin)>>1; count = ((pos-origin)>>1)+1;
start = origin; start = origin;
break; break;
case 2: /* erase whole display */ case 2: /* erase whole display */
...@@ -372,14 +448,12 @@ static void csi_K(int currcons, int vpar) ...@@ -372,14 +448,12 @@ static void csi_K(int currcons, int vpar)
switch (vpar) { switch (vpar) {
case 0: /* erase from cursor to end of line */ case 0: /* erase from cursor to end of line */
if (x>=video_num_columns)
return;
count = video_num_columns-x; count = video_num_columns-x;
start = pos; start = pos;
break; break;
case 1: /* erase from start of line to cursor */ case 1: /* erase from start of line to cursor */
start = pos - (x<<1); start = pos - (x<<1);
count = (x<video_num_columns)?x:video_num_columns; count = x+1;
break; break;
case 2: /* erase whole line */ case 2: /* erase whole line */
start = pos - (x<<1); start = pos - (x<<1);
...@@ -396,64 +470,91 @@ static void csi_K(int currcons, int vpar) ...@@ -396,64 +470,91 @@ static void csi_K(int currcons, int vpar)
:"cx","di"); :"cx","di");
} }
static void csi_m(int currcons ) /*
* I hope this works. The monochrome part is untested.
*/
static void update_attr(int currcons)
{
unsigned char a = color;
if (can_do_color) {
if (underline)
a = (a & 0xf8) | ulcolor;
else if (intensity == 0)
a = (a & 0xf0) | halfcolor;
}
if (reverse ^ decscnm)
a = (a & 0x88) | (((a >> 4) | (a << 4)) & 0x77);
if (blink)
a |= 0x80;
if (intensity == 2)
a |= 0x08;
if (!can_do_color) {
if (underline)
a = (a & 0xf8) | 0x01;
else if (intensity == 0)
a = (a & 0xf0) | 0x08;
}
video_erase_char = (a << 8) | ' ';
}
static void csi_m(int currcons)
{ {
int i; int i;
static int conv_table[8] = { 0, 4, 2, 6, 1, 5, 3, 7 };
for (i=0;i<=npar;i++) for (i=0;i<=npar;i++)
switch (par[i]) { switch (par[i]) {
case 0: attr=def_attr;break; /* default */ case 0: /* all attributes off */
case 1: attr=(iscolor?attr|0x08:attr|0x0f);break; /* bold */ intensity = 1;
/*case 4: attr=attr|0x01;break;*/ /* underline */ underline = 0;
case 4: /* bold */ reverse = 0;
if (!iscolor) blink = 0;
attr |= 0x01; color = def_color;
else break;
{ /* check if forground == background */ case 1:
if (vc_cons[currcons].vc_bold_attr != -1) intensity = 2;
attr = (vc_cons[currcons].vc_bold_attr&0x0f)|(0xf0&(attr)); break;
else case 2:
{ short newattr = (attr&0xf0)|(0xf&(~attr)); intensity = 0;
attr = ((newattr&0xf)==((attr>>4)&0xf)? break;
(attr&0xf0)|(((attr&0xf)+1)%0xf): case 4:
newattr); underline = 1;
} break;
} case 5:
break; blink = 1;
case 5: attr=attr|0x80;break; /* blinking */ break;
case 7: attr=(attr&0x88)|((attr<<4)&0x70)| case 7:
((attr>>4)&0x07);break; /* negative */ reverse = 1;
case 22: attr=attr&0xf7;break; /* not bold */ break;
case 24: attr=attr&0xfe;break; /* not underline */ case 21:
case 25: attr=attr&0x7f;break; /* not blinking */ case 22:
case 27: attr=def_attr;break; /* positive image */ intensity = 1;
case 39: attr=(attr & 0xf8)|(def_attr & 0x07); break; break;
case 49: attr=(attr & 0x8f)|(def_attr & 0x70); break; case 24:
underline = 0;
break;
case 25:
blink = 0;
break;
case 27:
reverse = 0;
break;
case 39:
color = (def_color & 0x0f) | background;
break;
case 49:
color = (def_color & 0xf0) | foreground;
break;
default: default:
if (!can_do_colour) if (par[i] >= 30 && par[i] <= 37)
break; color = color_table[par[i]-30]
iscolor = 1; | background;
if ((par[i]>=30) && (par[i]<=37)) else if (par[i] >= 40 && par[i] <= 47)
attr = (attr & 0xf8) | conv_table[par[i]-30]; color = (color_table[par[i]-40]<<4)
else /* Background color */ | foreground;
if ((par[i]>=40) && (par[i]<=47))
attr = (attr & 0x8f) | (conv_table[par[i]-40]<<4);
else
break; break;
} }
} update_attr(currcons);
static inline void set_cursor(int currcons)
{
if (currcons != fg_console)
return;
cli();
outb_p(14, video_port_reg);
outb_p(0xff&((pos-video_mem_base)>>9), video_port_val);
outb_p(15, video_port_reg);
outb_p(0xff&((pos-video_mem_base)>>1), video_port_val);
sti();
} }
static inline void hide_cursor(int currcons) static inline void hide_cursor(int currcons)
...@@ -464,10 +565,23 @@ static inline void hide_cursor(int currcons) ...@@ -464,10 +565,23 @@ static inline void hide_cursor(int currcons)
outb_p(0xff&((scr_end-video_mem_base)>>1), video_port_val); outb_p(0xff&((scr_end-video_mem_base)>>1), video_port_val);
} }
static void respond(int currcons, struct tty_struct * tty) static inline void set_cursor(int currcons)
{ {
char * p = RESPONSE; if (currcons != fg_console)
return;
cli();
if (deccm) {
outb_p(14, video_port_reg);
outb_p(0xff&((pos-video_mem_base)>>9), video_port_val);
outb_p(15, video_port_reg);
outb_p(0xff&((pos-video_mem_base)>>1), video_port_val);
} else
hide_cursor(currcons);
sti();
}
static void respond_string(char * p, int currcons, struct tty_struct * tty)
{
while (*p) { while (*p) {
PUTCH(*p,tty->read_q); PUTCH(*p,tty->read_q);
p++; p++;
...@@ -475,6 +589,123 @@ static void respond(int currcons, struct tty_struct * tty) ...@@ -475,6 +589,123 @@ static void respond(int currcons, struct tty_struct * tty)
TTY_READ_FLUSH(tty); TTY_READ_FLUSH(tty);
} }
static void respond_num(unsigned int n, int currcons, struct tty_struct * tty)
{
char buff[3];
int i = 0;
do {
buff[i++] = (n%10)+'0';
n /= 10;
} while(n && i < 3); /* We'll take no chances */
while (i--) {
PUTCH(buff[i],tty->read_q);
}
/* caller must flush */
}
static void cursor_report(int currcons, struct tty_struct * tty)
{
PUTCH('\033', tty->read_q);
PUTCH('[', tty->read_q);
respond_num(y + (decom ? top+1 : 1), currcons, tty);
PUTCH(';', tty->read_q);
respond_num(x+1, currcons, tty);
PUTCH('R', tty->read_q);
TTY_READ_FLUSH(tty);
}
static inline void status_report(int currcons, struct tty_struct * tty)
{
respond_string("\033[0n", currcons, tty); /* Terminal ok */
}
static inline void respond_ID(int currcons, struct tty_struct * tty)
{
respond_string(VT102ID, currcons, tty);
}
static void invert_screen(int currcons) {
unsigned char *p;
if (can_do_color)
for (p = (unsigned char *)origin+1; p < (unsigned char *)scr_end; p+=2)
*p = (*p & 0x88) | ((*p & 0x70) >> 4) | ((*p & 0x07) << 4);
else
for (p = (unsigned char *)origin+1; p < (unsigned char *)scr_end; p+=2)
*p = *p ^ (*p & 0x07 == 1 ? 0x70 : 0x77);
}
static void set_mode(int currcons, int on_off)
{
int i;
for (i=0; i<=npar; i++)
if (ques) switch(par[i]) { /* DEC private modes set/reset */
case 1: /* Cursor keys send ^[Ox/^[[x */
SET(decckm,ckmode,on_off);
break;
case 3: /* 80/132 mode switch unimplemented */
csi_J(currcons,2);
gotoxy(currcons,0,0);
break;
case 5: /* Inverted screen on/off */
if (decscnm != on_off) {
decscnm = on_off;
invert_screen(currcons);
update_attr(currcons);
}
break;
case 6: /* Origin relative/absolute */
decom = on_off;
gotoxy(currcons,0,0);
break;
case 7: /* Autowrap on/off */
decawm = on_off;
break;
case 8: /* Autorepeat on/off */
SET(decarm,krepeat,on_off);
break;
case 25: /* Cursor on/off */
deccm = on_off;
set_cursor(currcons);
break;
} else switch(par[i]) { /* ANSI modes set/reset */
case 4: /* Insert Mode on/off */
decim = on_off;
break;
case 20: /* Lf, Enter == CrLf/Lf */
SET(lnm,lfnlmode,on_off);
break;
}
}
static void setterm_command(int currcons)
{
switch(par[0]) {
case 1: /* set color for underline mode */
if (can_do_color && par[1] < 16) {
ulcolor = color_table[par[1]];
if (underline)
update_attr(currcons);
}
break;
case 2: /* set color for half intensity mode */
if (can_do_color && par[1] < 16) {
halfcolor = color_table[par[1]];
if (intensity == 0)
update_attr(currcons);
}
break;
case 8: /* store colors as defaults */
def_color = color;
break;
case 9: /* set blanking interval */
blankinterval = ((par[1] < 60) ? par[1] : 60) * 60 * HZ;
break;
}
}
static void insert_char(int currcons) static void insert_char(int currcons)
{ {
unsigned int i = x; unsigned int i = x;
...@@ -499,8 +730,6 @@ static void delete_char(int currcons) ...@@ -499,8 +730,6 @@ static void delete_char(int currcons)
unsigned int i = x; unsigned int i = x;
unsigned short * p = (unsigned short *) pos; unsigned short * p = (unsigned short *) pos;
if (x >= video_num_columns)
return;
while (++i < video_num_columns) { while (++i < video_num_columns) {
*p = *(p+1); *p = *(p+1);
p++; p++;
...@@ -555,18 +784,91 @@ static void csi_M(int currcons, unsigned int nr) ...@@ -555,18 +784,91 @@ static void csi_M(int currcons, unsigned int nr)
static void save_cur(int currcons) static void save_cur(int currcons)
{ {
saved_x = x; saved_x = x;
saved_y = y; saved_y = y;
s_intensity = intensity;
s_blink = blink;
s_underline = underline;
s_blink = blink;
s_reverse = reverse;
s_charset = charset;
s_color = color;
saved_G0 = G0_charset;
saved_G1 = G1_charset;
} }
static void restore_cur(int currcons) static void restore_cur(int currcons)
{ {
gotoxy(currcons, saved_x, saved_y); x = saved_x;
y = saved_y;
pos = origin + y*video_size_row + (x<<1);
intensity = s_intensity;
blink = s_blink;
underline = s_underline;
blink = s_blink;
reverse = s_reverse;
charset = s_charset;
color = s_color;
G0_charset = saved_G0;
G1_charset = saved_G1;
translate = charset ? G1_charset : G0_charset;
update_attr(currcons);
} }
enum { ESnormal, ESesc, ESsquare, ESgetpars, ESgotpars, ESfunckey, enum { ESnormal, ESesc, ESsquare, ESgetpars, ESgotpars, ESfunckey,
ESsetterm, ESsetgraph, ESgraph, ESgresc, ESignore }; EShash, ESsetG0, ESsetG1, ESignore };
static void reset_terminal(int currcons, int do_clear)
{
vtmode = KD_TEXT;
top = 0;
bottom = video_num_lines;
/* Default colors. */
def_color = 0x07; /* light gray */
ulcolor = 0x0f; /* bold white */
halfcolor = 0x08; /* dark gray */
color = def_color;
state = ESnormal;
ques = 0;
translate = NORM_TRANS;
G0_charset = NORM_TRANS;
G1_charset = GRAF_TRANS;
charset = 0;
kbdleds = 2;
kbdmode = 0;
kbdraw = 0;
kbde0 = 0;
need_wrap = 0;
decscnm = 0;
decom = 0;
decawm = 1;
deccm = 1;
decim = 0;
SET(decarm,krepeat,1);
SET(decckm,ckmode,0);
SET(kbdapplic,kapplic,0);
SET(lnm,lfnlmode,0);
intensity = 1;
underline = 0;
blink = 0;
reverse = 0;
update_attr(currcons);
tab_stop[0] = 0x01010100;
tab_stop[1] =
tab_stop[2] =
tab_stop[3] =
tab_stop[4] = 0x01010101;
if (do_clear) {
gotoxy(currcons,0,0);
csi_J(currcons,2);
}
save_cur(currcons);
}
void con_write(struct tty_struct * tty) void con_write(struct tty_struct * tty)
{ {
...@@ -580,54 +882,75 @@ void con_write(struct tty_struct * tty) ...@@ -580,54 +882,75 @@ void con_write(struct tty_struct * tty)
return; return;
} }
while (!tty->stopped && (c = GETCH(tty->write_q)) >= 0) { while (!tty->stopped && (c = GETCH(tty->write_q)) >= 0) {
if (c == 24 || c == 26) if (state == ESnormal && translate[c]) {
state = ESnormal; if (need_wrap) {
switch(state) { cr(currcons);
case ESnormal: lf(currcons);
if (translate[c]) { need_wrap = 0;
c = translate[c]; }
while (x >= video_num_columns) { if (decim)
x -= video_num_columns; insert_char(currcons);
pos -= video_size_row; c = translate[c];
lf(currcons); *(char *) pos = c;
} *(char *) (pos+1) = attr;
*(char *) pos = c; if (x == video_num_columns - 1) {
*(char *) (pos+1) = attr; need_wrap = decawm;
pos += 2; continue;
}
x++;
pos+=2;
continue;
}
need_wrap = 0;
/*
* Control characters can be used in the _middle_
* of an escape sequence.
*/
if (c < 32 || c == 127) switch(c) {
case 7:
sysbeep();
break;
case 8:
if (x) {
x--;
pos -= 2;
}
break;
case 9:
pos -= (x << 1);
while (x < video_num_columns - 1) {
x++; x++;
} else if (c == 27) if (tab_stop[x >> 5] & (1 << (x & 31)))
state = ESesc; break;
else if (c == 10 || c == 11 || c == 12) }
lf(currcons); pos += (x << 1);
else if (c == 13) break;
cr(currcons); case 10: case 11: case 12:
else if (c == 127) lf(currcons);
del(currcons); if (!lfnlmode)
else if (c == 8) { break;
if (x) { case 13:
x--; cr(currcons);
pos -= 2;
}
} else if (c == 9) {
c = 8-(x&7);
x += c;
pos += c<<1;
if (x > video_num_columns) {
x -= video_num_columns;
pos -= video_size_row;
lf(currcons);
}
c = 9;
} else if (c == 7)
sysbeep();
else if (c == 14) {
checkin = 1;
translate = restate;
} else if (c == 15) {
translate = NORM_TRANS;
checkin = 0;
}
break; break;
case 14:
charset = 1;
translate = G1_charset;
break;
case 15:
charset = 0;
translate = G0_charset;
break;
case 24: case 26:
state = ESnormal;
break;
case 27:
state = ESesc;
break;
case 127:
del(currcons);
break;
} else switch(state) {
case ESesc: case ESesc:
state = ESnormal; state = ESnormal;
switch (c) { switch (c) {
...@@ -635,7 +958,8 @@ void con_write(struct tty_struct * tty) ...@@ -635,7 +958,8 @@ void con_write(struct tty_struct * tty)
state = ESsquare; state = ESsquare;
break; break;
case 'E': case 'E':
gotoxy(currcons,0,y+1); cr(currcons);
lf(currcons);
break; break;
case 'M': case 'M':
ri(currcons); ri(currcons);
...@@ -643,8 +967,11 @@ void con_write(struct tty_struct * tty) ...@@ -643,8 +967,11 @@ void con_write(struct tty_struct * tty)
case 'D': case 'D':
lf(currcons); lf(currcons);
break; break;
case 'H':
tab_stop[x >> 5] |= (1 << (x & 31));
break;
case 'Z': case 'Z':
respond(currcons,tty); respond_ID(currcons,tty);
break; break;
case '7': case '7':
save_cur(currcons); save_cur(currcons);
...@@ -653,32 +980,22 @@ void con_write(struct tty_struct * tty) ...@@ -653,32 +980,22 @@ void con_write(struct tty_struct * tty)
restore_cur(currcons); restore_cur(currcons);
break; break;
case '(': case '(':
state = ESsetG0;
break;
case ')': case ')':
state = ESsetgraph; state = ESsetG1;
break; break;
case 'P':
state = ESsetterm;
break;
case '#': case '#':
state = -1; state = EShash;
break; break;
case 'c': case 'c':
tty->termios = DEF_TERMIOS; reset_terminal(currcons,1);
state = ESnormal; break;
restate = NORM_TRANS;
checkin = 0;
top = 0;
bottom = video_num_lines;
translate = NORM_TRANS;
case '>': /* Numeric keypad */ case '>': /* Numeric keypad */
kbdapplic = 0; SET(kbdapplic,kapplic,0);
if (currcons == fg_console) break;
kapplic = 0;
break;
case '=': /* Appl. keypad */ case '=': /* Appl. keypad */
kbdapplic = 1; SET(kbdapplic,kapplic,1);
if (currcons == fg_console)
kapplic = 1;
break; break;
} }
break; break;
...@@ -690,7 +1007,7 @@ void con_write(struct tty_struct * tty) ...@@ -690,7 +1007,7 @@ void con_write(struct tty_struct * tty)
if (c == '[') { /* Function key */ if (c == '[') { /* Function key */
state=ESfunckey; state=ESfunckey;
break; break;
} }
if (ques=(c=='?')) if (ques=(c=='?'))
break; break;
case ESgetpars: case ESgetpars:
...@@ -704,10 +1021,25 @@ void con_write(struct tty_struct * tty) ...@@ -704,10 +1021,25 @@ void con_write(struct tty_struct * tty)
} else state=ESgotpars; } else state=ESgotpars;
case ESgotpars: case ESgotpars:
state = ESnormal; state = ESnormal;
switch(c) {
case 'h':
set_mode(currcons,1);
break;
case 'l':
set_mode(currcons,0);
break;
case 'n':
if (!ques)
if (par[0] == 5)
status_report(currcons,tty);
else if (par[0] == 6)
cursor_report(currcons,tty);
break;
}
if (ques) { if (ques) {
ques = 0; ques = 0;
break; break;
} }
switch(c) { switch(c) {
case 'G': case '`': case 'G': case '`':
if (par[0]) par[0]--; if (par[0]) par[0]--;
...@@ -761,20 +1093,33 @@ void con_write(struct tty_struct * tty) ...@@ -761,20 +1093,33 @@ void con_write(struct tty_struct * tty)
case 'P': case 'P':
csi_P(currcons,par[0]); csi_P(currcons,par[0]);
break; break;
case '@': case 'c':
csi_at(currcons,par[0]); if (!par[0])
respond_ID(currcons,tty);
break;
case 'g':
if (!par[0])
tab_stop[x >> 5] &= ~(1 << (x & 31));
else if (par[0] == 3) {
tab_stop[0] =
tab_stop[1] =
tab_stop[2] =
tab_stop[3] =
tab_stop[4] = 0;
}
break; break;
case 'm': case 'm':
csi_m(currcons); csi_m(currcons);
break; break;
case 'r': case 'r':
if (par[0]) if (!par[0])
par[0]--; par[0]++;
if (!par[1]) if (!par[1])
par[1] = video_num_lines; par[1] = video_num_lines;
/* Minimum allowed region is 2 lines */
if (par[0] < par[1] && if (par[0] < par[1] &&
par[1] <= video_num_lines) { par[1] <= video_num_lines) {
top=par[0]; top=par[0]-1;
bottom=par[1]; bottom=par[1];
gotoxy(currcons,0,0); gotoxy(currcons,0,0);
} }
...@@ -785,40 +1130,44 @@ void con_write(struct tty_struct * tty) ...@@ -785,40 +1130,44 @@ void con_write(struct tty_struct * tty)
case 'u': case 'u':
restore_cur(currcons); restore_cur(currcons);
break; break;
case 'l': /* blank interval */ case '@':
case 'b': /* bold attribute */ csi_at(currcons,par[0]);
if (!((npar >= 2) && break;
((par[1]-13) == par[0]) && case ']': /* setterm functions */
((par[2]-17) == par[0]))) setterm_command(currcons);
break; break;
if ((c=='l') && (par[0]<=60)) {
blankinterval = HZ*60*par[0];
}
if (c=='b')
vc_cons[currcons].vc_bold_attr
= par[0];
} }
break; break;
case ESfunckey: case ESfunckey:
state = ESnormal; state = ESnormal;
break; break;
case ESsetterm: /* Setterm functions. */ case EShash:
state = ESnormal;
if (c == '8') {
/* DEC screen alignment test. kludge :-) */
video_erase_char =
(video_erase_char & 0xff00) | 'E';
csi_J(currcons, 2);
video_erase_char =
(video_erase_char & 0xff00) | ' ';
}
break;
case ESsetG0:
if (c == '0')
G0_charset = GRAF_TRANS;
else if (c == 'B')
G0_charset = NORM_TRANS;
if (charset == 0)
translate = G0_charset;
state = ESnormal; state = ESnormal;
if (c == 'S') {
def_attr = attr;
video_erase_char = (video_erase_char&0x0ff) | (def_attr<<8);
} else if (c == 'L')
/*linewrap on*/;
else if (c == 'l')
/*linewrap off*/;
break; break;
case ESsetgraph: case ESsetG1:
if (c == '0') { if (c == '0')
if (checkin) G1_charset = GRAF_TRANS;
translate = GRAF_TRANS; else if (c == 'B')
restate = GRAF_TRANS; G1_charset = NORM_TRANS;
} else if (c == 'B') if (charset == 1)
translate = restate = NORM_TRANS; translate = G1_charset;
state = ESnormal; state = ESnormal;
break; break;
default: default:
...@@ -826,7 +1175,7 @@ void con_write(struct tty_struct * tty) ...@@ -826,7 +1175,7 @@ void con_write(struct tty_struct * tty)
} }
} }
timer_active &= ~(1<<BLANK_TIMER); timer_active &= ~(1<<BLANK_TIMER);
if (vt_cons[currcons].vt_mode == KD_GRAPHICS) if (vtmode == KD_GRAPHICS)
return; return;
set_cursor(currcons); set_cursor(currcons);
if (currcons == fg_console) if (currcons == fg_console)
...@@ -889,7 +1238,6 @@ long con_init(long kmem_start) ...@@ -889,7 +1238,6 @@ long con_init(long kmem_start)
video_size_row = video_num_columns * 2; video_size_row = video_num_columns * 2;
video_num_lines = ORIG_VIDEO_LINES; video_num_lines = ORIG_VIDEO_LINES;
video_page = ORIG_VIDEO_PAGE; video_page = ORIG_VIDEO_PAGE;
video_erase_char = 0x0720;
screen_size = (video_num_lines * video_size_row); screen_size = (video_num_lines * video_size_row);
kmem_start += NR_CONSOLES * screen_size; kmem_start += NR_CONSOLES * screen_size;
timer_table[BLANK_TIMER].fn = blank_screen; timer_table[BLANK_TIMER].fn = blank_screen;
...@@ -919,7 +1267,7 @@ long con_init(long kmem_start) ...@@ -919,7 +1267,7 @@ long con_init(long kmem_start)
} }
else /* If not, it is color. */ else /* If not, it is color. */
{ {
can_do_colour = 1; can_do_color = 1;
video_mem_base = 0xb8000; video_mem_base = 0xb8000;
video_port_reg = 0x3d4; video_port_reg = 0x3d4;
video_port_val = 0x3d5; video_port_val = 0x3d5;
...@@ -937,7 +1285,7 @@ long con_init(long kmem_start) ...@@ -937,7 +1285,7 @@ long con_init(long kmem_start)
} }
} }
/* Let the user known what kind of display driver we are using */ /* Let the user know what kind of display driver we are using */
display_ptr = ((char *)video_mem_base) + video_size_row - 8; display_ptr = ((char *)video_mem_base) + video_size_row - 8;
while (*display_desc) while (*display_desc)
...@@ -945,53 +1293,25 @@ long con_init(long kmem_start) ...@@ -945,53 +1293,25 @@ long con_init(long kmem_start)
*display_ptr++ = *display_desc++; *display_ptr++ = *display_desc++;
display_ptr++; display_ptr++;
} }
memsetw(vc_scrmembuf,video_erase_char,MEM_BUFFER_SIZE/2);
base = (long)vc_scrmembuf;
/* Initialize the variables used for scrolling (mostly EGA/VGA) */ /* Initialize the variables used for scrolling (mostly EGA/VGA) */
base = origin = video_mem_start = (long)vc_scrmembuf;
scr_end = video_mem_end = base + screen_size;
vc_scrbuf[0] = (unsigned short *) origin;
top = 0;
bottom = video_num_lines;
attr = 0x07;
def_attr = 0x07;
restate = NORM_TRANS;
state = ESnormal;
checkin = 0;
ques = 0;
iscolor = 0;
translate = NORM_TRANS;
kbdleds = 2;
kbdmode = 0;
kbdraw = 0;
kbde0 = 0;
kbdapplic = 0;
vt_cons[0].vt_mode = KD_TEXT;
vc_cons[0].vc_bold_attr = -1;
gotoxy(currcons,orig_x,orig_y); base = (long)vc_scrmembuf;
for (currcons = 1 ; currcons < NR_CONSOLES ; currcons++) { for (currcons = 0; currcons<NR_CONSOLES; currcons++) {
vc_cons[currcons] = vc_cons[0];
vt_cons[currcons] = vt_cons[0];
base += screen_size;
x = y = 0;
pos = origin = video_mem_start = base; pos = origin = video_mem_start = base;
scr_end = video_mem_end = base + screen_size; scr_end = video_mem_end = (base += screen_size);
vc_scrbuf[currcons] = (unsigned short *) origin; vc_scrbuf[currcons] = (unsigned short *) origin;
reset_terminal(currcons, currcons);
} }
currcons = 0; currcons = fg_console = 0;
video_mem_start = video_mem_base; video_mem_start = video_mem_base;
video_mem_end = video_mem_term; video_mem_end = video_mem_term;
origin = video_mem_start; origin = video_mem_start;
scr_end = video_mem_start + video_num_lines * video_size_row; scr_end = video_mem_start + video_num_lines * video_size_row;
top = 0; gotoxy(currcons,orig_x,orig_y);
bottom = video_num_lines;
pos=origin + y*video_size_row + (x<<1);
update_screen(fg_console); update_screen(fg_console);
set_trap_gate(0x21,&keyboard_interrupt); set_trap_gate(0x21,&keyboard_interrupt);
outb_p(inb_p(0x21)&0xfd,0x21); outb_p(inb_p(0x21)&0xfd,0x21);
a=inb_p(0x61); a=inb_p(0x61);
...@@ -1008,12 +1328,18 @@ void kbdsave(int new_console) ...@@ -1008,12 +1328,18 @@ void kbdsave(int new_console)
kbde0 = ke0; kbde0 = ke0;
kbdleds = kleds; kbdleds = kleds;
kbdapplic = kapplic; kbdapplic = kapplic;
decckm = ckmode;
decarm = krepeat;
lnm = lfnlmode;
currcons = new_console; currcons = new_console;
kmode = (kmode & 0x3F) | (kbdmode & 0xC0); kmode = (kmode & 0x3F) | (kbdmode & 0xC0);
kraw = kbdraw; kraw = kbdraw;
ke0 = kbde0; ke0 = kbde0;
kleds = kbdleds; kleds = kbdleds;
kapplic = kbdapplic; kapplic = kbdapplic;
ckmode = decckm;
krepeat = decarm;
lfnlmode = lnm;
set_leds(); set_leds();
} }
...@@ -1021,9 +1347,9 @@ static void get_scrmem(int currcons) ...@@ -1021,9 +1347,9 @@ static void get_scrmem(int currcons)
{ {
memcpy((void *)vc_scrbuf[fg_console],(void *)origin, screen_size); memcpy((void *)vc_scrbuf[fg_console],(void *)origin, screen_size);
video_mem_start = (unsigned long)vc_scrbuf[fg_console]; video_mem_start = (unsigned long)vc_scrbuf[fg_console];
origin = video_mem_start; origin = video_mem_start;
scr_end = video_mem_end = video_mem_start+screen_size; scr_end = video_mem_end = video_mem_start+screen_size;
pos = origin + y*video_size_row + (x<<1); pos = origin + y*video_size_row + (x<<1);
} }
static void set_scrmem(int currcons) static void set_scrmem(int currcons)
...@@ -1123,24 +1449,21 @@ void console_print(const char * b) ...@@ -1123,24 +1449,21 @@ void console_print(const char * b)
if (currcons<0 || currcons>=NR_CONSOLES) if (currcons<0 || currcons>=NR_CONSOLES)
currcons = 0; currcons = 0;
while (c = *(b++)) { while (c = *(b++)) {
if (c == 10) { if (c == 10 || c == 13 || need_wrap) {
cr(currcons); cr(currcons);
lf(currcons); if (c == 10 || need_wrap)
lf(currcons);
need_wrap = 0;
continue; continue;
} }
if (c == 13) {
cr(currcons);
continue;
}
while (x >= video_num_columns) {
x -= video_num_columns;
pos -= video_size_row;
lf(currcons);
}
*(char *) pos = c; *(char *) pos = c;
*(char *) (pos+1) = attr; *(char *) (pos+1) = attr;
pos += 2; if (x == video_num_columns - 1) {
need_wrap = 1;
continue;
}
x++; x++;
pos+=2;
} }
set_cursor(currcons); set_cursor(currcons);
} }
...@@ -29,11 +29,14 @@ ...@@ -29,11 +29,14 @@
#define NO_META_BIT 0x80 #define NO_META_BIT 0x80
unsigned char kapplic = 0; unsigned char kapplic = 0;
unsigned char ckmode = 0;
unsigned char krepeat = 1;
unsigned char kmode = 0; unsigned char kmode = 0;
unsigned char kleds = NUMLED; unsigned char kleds = NUMLED;
unsigned char ke0 = 0; unsigned char ke0 = 0;
unsigned char kraw = 0; unsigned char kraw = 0;
unsigned char kbd_flags = KBDFLAGS; unsigned char kbd_flags = KBDFLAGS;
unsigned char lfnlmode = 0;
extern void do_keyboard_interrupt(void); extern void do_keyboard_interrupt(void);
extern void ctrl_alt_del(void); extern void ctrl_alt_del(void);
...@@ -57,7 +60,9 @@ static unsigned int handle_diacr(unsigned int); ...@@ -57,7 +60,9 @@ static unsigned int handle_diacr(unsigned int);
void do_keyboard(void) void do_keyboard(void)
{ {
static unsigned char rep = 0xff, repke0 = 0;
unsigned char scancode, x; unsigned char scancode, x;
struct tty_struct * tty = TTY_TABLE(0);
scancode=inb_p(0x60); scancode=inb_p(0x60);
x=inb_p(0x61); x=inb_p(0x61);
...@@ -69,15 +74,48 @@ void do_keyboard(void) ...@@ -69,15 +74,48 @@ void do_keyboard(void)
if (kraw) { if (kraw) {
put_queue(scancode); put_queue(scancode);
do_keyboard_interrupt(); do_keyboard_interrupt();
} else if (scancode == 0xe0) return;
}
if (scancode == 0xe0) {
ke0 = 1; ke0 = 1;
else if (scancode == 0xe1) return;
}
if (scancode == 0xe1) {
ke0 = 2; ke0 = 2;
else { return;
key_table[scancode](scancode); }
do_keyboard_interrupt(); /*
* The keyboard maintains its own internal caps lock and num lock
* statuses. In caps lock mode E0 AA precedes make code and E0 2A
* follows break code. In num lock mode, E0 2A precedes make
* code and E0 AA follows break code. We do our own book-keeping,
* so we will just ignore these.
*/
if (ke0 == 1 && (scancode == 0x2a || scancode == 0xaa)) {
ke0 = 0; ke0 = 0;
return;
} }
/*
* Repeat a key only if the input buffers are empty or the
* characters get echoed locally. This makes key repeat usable
* with slow applications and unders heavy loads.
*/
if (rep == 0xff) {
if (scancode < 0x80) {
rep = scancode;
repke0 = ke0;
}
} else if (ke0 == repke0 && (scancode & 0x7f) == rep)
if (scancode & 0x80)
rep = 0xff;
else if (!(krepeat && (L_ECHO(tty) || (EMPTY(tty->secondary) &&
EMPTY(tty->read_q))))) {
ke0 = 0;
return;
}
key_table[scancode](scancode);
do_keyboard_interrupt();
ke0 = 0;
} }
static void put_queue(int ch) static void put_queue(int ch)
...@@ -167,10 +205,10 @@ static void unrshift(int sc) ...@@ -167,10 +205,10 @@ static void unrshift(int sc)
static void caps(int sc) static void caps(int sc)
{ {
if (!(kmode&CAPSDOWN)) { if (!(kmode & CAPSDOWN)) {
kleds^=CAPSLED; kleds ^= CAPSLED;
kmode^=CAPS; kmode ^= CAPS;
kmode|=CAPSDOWN; kmode |= CAPSDOWN;
set_leds(); set_leds();
} }
} }
...@@ -178,7 +216,7 @@ static void caps(int sc) ...@@ -178,7 +216,7 @@ static void caps(int sc)
void set_leds(void) void set_leds(void)
{ {
if (kleds != old_leds) { if (kleds != old_leds) {
old_leds=kleds; old_leds = kleds;
kb_wait(); kb_wait();
outb(0xed, 0x60); /* set leds command */ outb(0xed, 0x60); /* set leds command */
kb_ack(); kb_ack();
...@@ -190,16 +228,16 @@ void set_leds(void) ...@@ -190,16 +228,16 @@ void set_leds(void)
static void uncaps(int sc) static void uncaps(int sc)
{ {
kmode&=(~CAPSDOWN); kmode &= ~CAPSDOWN;
} }
static void scroll(int sc) static void scroll(int sc)
{ {
if (kmode&(LSHIFT|RSHIFT)) if (kmode & (LSHIFT | RSHIFT))
show_mem(); show_mem();
else else
show_state(); show_state();
kleds^=SCRLED; kleds ^= SCRLED;
set_leds(); set_leds();
} }
...@@ -208,7 +246,7 @@ static void num(int sc) ...@@ -208,7 +246,7 @@ static void num(int sc)
if (kapplic) if (kapplic)
applkey(0x50); applkey(0x50);
else { else {
kleds^=NUMLED; kleds ^= NUMLED;
set_leds(); set_leds();
} }
} }
...@@ -217,7 +255,7 @@ static void applkey(int key) ...@@ -217,7 +255,7 @@ static void applkey(int key)
{ {
char buf[] = { 0x1b, 0x4f, 0x00, 0x00 }; char buf[] = { 0x1b, 0x4f, 0x00, 0x00 };
buf[2]=key; buf[2] = key;
puts_queue(buf); puts_queue(buf);
} }
...@@ -747,27 +785,27 @@ static void do_self(int sc) ...@@ -747,27 +785,27 @@ static void do_self(int sc)
{ {
unsigned char ch; unsigned char ch;
if (kmode&ALTGR) if (kmode & ALTGR)
ch=alt_map[sc]; ch = alt_map[sc];
else if (kmode&(LSHIFT|RSHIFT|LCTRL|RCTRL)) else if (kmode & (LSHIFT | RSHIFT | LCTRL | RCTRL))
ch=shift_map[sc]; ch = shift_map[sc];
else else
ch=key_map[sc]; ch = key_map[sc];
if (ch == 0) if (ch == 0)
return; return;
if ((ch=handle_diacr(ch)) == 0) if ((ch = handle_diacr(ch)) == 0)
return; return;
if (kmode&(LCTRL|RCTRL|CAPS)) /* ctrl or caps */ if (kmode & (LCTRL | RCTRL | CAPS)) /* ctrl or caps */
if ((ch>='a' && ch <='z') || (ch>=224 && ch<=254)) if ((ch >= 'a' && ch <= 'z') || (ch >= 224 && ch <= 254))
ch -= 32; ch -= 32;
if (kmode&(LCTRL|RCTRL)) /* ctrl */ if (kmode & (LCTRL | RCTRL)) /* ctrl */
ch &= 0x1f; ch &= 0x1f;
if (kmode&ALT) if (kmode & ALT)
if (kbd_flags&NO_META_BIT) { if (kbd_flags & NO_META_BIT) {
put_queue('\033'); put_queue('\033');
put_queue(ch); put_queue(ch);
} else } else
...@@ -910,7 +948,7 @@ static void cur(int sc) ...@@ -910,7 +948,7 @@ static void cur(int sc)
buf[2]=cur_table[sc]; buf[2]=cur_table[sc];
if (buf[2] < '9') if (buf[2] < '9')
buf[3]='~'; buf[3]='~';
if (kapplic) if ((buf[2] >= 'A' && buf[2] <= 'D') ? ckmode : kapplic)
buf[1]='O'; buf[1]='O';
puts_queue(buf); puts_queue(buf);
} }
...@@ -952,12 +990,13 @@ static void star(int sc) ...@@ -952,12 +990,13 @@ static void star(int sc)
static void enter(int sc) static void enter(int sc)
{ {
if (ke0 != 1) if (ke0 == 1 && kapplic)
do_self(sc);
else if (kapplic)
applkey('M'); applkey('M');
else else {
do_self(sc); put_queue(13);
if (lfnlmode)
put_queue(10);
}
} }
static void minus(int sc) static void minus(int sc)
......
...@@ -70,16 +70,13 @@ static void send_intr(unsigned line, unsigned port, struct tty_struct * tty) ...@@ -70,16 +70,13 @@ static void send_intr(unsigned line, unsigned port, struct tty_struct * tty)
#define TIMER ((SER1_TIMEOUT-1)+line) #define TIMER ((SER1_TIMEOUT-1)+line)
timer_active &= ~(1 << TIMER); timer_active &= ~(1 << TIMER);
if (!tty->stopped) { do {
do { if ((c = GETCH(tty->write_q)) < 0)
if ((c = GETCH(tty->write_q)) < 0) return;
return; outb(c,port);
outb(c,port); i++;
i++; } while ( port_table[line] == PORT_16550A &&
} while ( port_table[line] == PORT_16550A && \ i < 14 && !EMPTY(tty->write_q));
i < 14 && !EMPTY(tty->write_q) && \
!tty->stopped);
}
timer_table[TIMER].expires = jiffies + 10; timer_table[TIMER].expires = jiffies + 10;
timer_active |= 1 << TIMER; timer_active |= 1 << TIMER;
if (LEFT(tty->write_q) > WAKEUP_CHARS) if (LEFT(tty->write_q) > WAKEUP_CHARS)
......
...@@ -175,11 +175,13 @@ void copy_to_cooked(struct tty_struct * tty) ...@@ -175,11 +175,13 @@ void copy_to_cooked(struct tty_struct * tty)
if ((INTR_CHAR(tty) != __DISABLED_CHAR) && if ((INTR_CHAR(tty) != __DISABLED_CHAR) &&
(c==INTR_CHAR(tty))) { (c==INTR_CHAR(tty))) {
kill_pg(tty->pgrp, SIGINT, 1); kill_pg(tty->pgrp, SIGINT, 1);
flush_input(tty);
continue; continue;
} }
if ((QUIT_CHAR(tty) != __DISABLED_CHAR) && if ((QUIT_CHAR(tty) != __DISABLED_CHAR) &&
(c==QUIT_CHAR(tty))) { (c==QUIT_CHAR(tty))) {
kill_pg(tty->pgrp, SIGQUIT, 1); kill_pg(tty->pgrp, SIGQUIT, 1);
flush_input(tty);
continue; continue;
} }
if ((SUSPEND_CHAR(tty) != __DISABLED_CHAR) && if ((SUSPEND_CHAR(tty) != __DISABLED_CHAR) &&
......
...@@ -42,7 +42,7 @@ static void change_speed(struct tty_struct * tty) ...@@ -42,7 +42,7 @@ static void change_speed(struct tty_struct * tty)
sti(); sti();
} }
void flush(struct tty_queue * queue) static void flush(struct tty_queue * queue)
{ {
if (queue) { if (queue) {
cli(); cli();
...@@ -52,6 +52,14 @@ void flush(struct tty_queue * queue) ...@@ -52,6 +52,14 @@ void flush(struct tty_queue * queue)
} }
} }
void flush_input(struct tty_struct * tty)
{
flush(tty->read_q);
flush(tty->secondary);
tty->secondary->data = 0;
wake_up(&tty->read_q->proc_list);
}
static void wait_until_sent(struct tty_struct * tty) static void wait_until_sent(struct tty_struct * tty)
{ {
while (!(current->signal & ~current->blocked) && !EMPTY(tty->write_q)) { while (!(current->signal & ~current->blocked) && !EMPTY(tty->write_q)) {
...@@ -250,8 +258,7 @@ int tty_ioctl(struct inode * inode, struct file * file, ...@@ -250,8 +258,7 @@ int tty_ioctl(struct inode * inode, struct file * file,
case TCGETS: case TCGETS:
return get_termios(tty,(struct termios *) arg); return get_termios(tty,(struct termios *) arg);
case TCSETSF: case TCSETSF:
flush(tty->read_q); flush_input(tty);
flush(tty->secondary);
if (other_tty) if (other_tty)
flush(other_tty->write_q); flush(other_tty->write_q);
/* fallthrough */ /* fallthrough */
...@@ -263,8 +270,7 @@ int tty_ioctl(struct inode * inode, struct file * file, ...@@ -263,8 +270,7 @@ int tty_ioctl(struct inode * inode, struct file * file,
case TCGETA: case TCGETA:
return get_termio(tty,(struct termio *) arg); return get_termio(tty,(struct termio *) arg);
case TCSETAF: case TCSETAF:
flush(tty->read_q); flush_input(tty);
flush(tty->secondary);
if (other_tty) if (other_tty)
flush(other_tty->write_q); flush(other_tty->write_q);
/* fallthrough */ /* fallthrough */
...@@ -299,15 +305,13 @@ int tty_ioctl(struct inode * inode, struct file * file, ...@@ -299,15 +305,13 @@ int tty_ioctl(struct inode * inode, struct file * file,
return -EINVAL; /* not implemented */ return -EINVAL; /* not implemented */
case TCFLSH: case TCFLSH:
if (arg==0) { if (arg==0) {
flush(tty->read_q); flush_input(tty);
flush(tty->secondary);
if (other_tty) if (other_tty)
flush(other_tty->write_q); flush(other_tty->write_q);
} else if (arg==1) } else if (arg==1)
flush(tty->write_q); flush(tty->write_q);
else if (arg==2) { else if (arg==2) {
flush(tty->read_q); flush_input(tty);
flush(tty->secondary);
flush(tty->write_q); flush(tty->write_q);
if (other_tty) if (other_tty)
flush(other_tty->write_q); flush(other_tty->write_q);
......
...@@ -164,8 +164,7 @@ vt_ioctl(struct tty_struct *tty, int dev, int cmd, int arg) ...@@ -164,8 +164,7 @@ vt_ioctl(struct tty_struct *tty, int dev, int cmd, int arg)
} }
else else
return -EINVAL; return -EINVAL;
flush(tty->read_q); flush_input(tty);
flush(tty->secondary);
return 0; return 0;
case KDGKBMODE: case KDGKBMODE:
verify_area((void *) arg, sizeof(unsigned long)); verify_area((void *) arg, sizeof(unsigned long));
......
...@@ -23,7 +23,7 @@ CPP =cpp -nostdinc -I../../include ...@@ -23,7 +23,7 @@ CPP =cpp -nostdinc -I../../include
-c -o $*.o $< -c -o $*.o $<
OBJS = emulate.o error.o convert.o ea.o get_put.o \ OBJS = emulate.o error.o convert.o ea.o get_put.o \
add.o mul.o div.o compare.o add.o mul.o div.o compare.o sqrt.o
math.a: $(OBJS) math.a: $(OBJS)
$(AR) rcs math.a $(OBJS) $(AR) rcs math.a $(OBJS)
...@@ -42,44 +42,49 @@ dep: ...@@ -42,44 +42,49 @@ dep:
### Dependencies: ### Dependencies:
add.s add.o : add.c ../../include/linux/math_emu.h ../../include/linux/sched.h ../../include/linux/head.h \ add.s add.o : add.c ../../include/linux/math_emu.h ../../include/linux/sched.h ../../include/linux/head.h \
../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \ ../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/sys/resource.h ../../include/sys/resource.h
compare.s compare.o : compare.c ../../include/linux/math_emu.h ../../include/linux/sched.h \ compare.s compare.o : compare.c ../../include/linux/math_emu.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/sys/dirent.h ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/linux/kernel.h ../../include/signal.h ../../include/sys/param.h \
../../include/sys/resource.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h
convert.s convert.o : convert.c ../../include/linux/math_emu.h ../../include/linux/sched.h \ convert.s convert.o : convert.c ../../include/linux/math_emu.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/sys/dirent.h ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/linux/kernel.h ../../include/signal.h ../../include/sys/param.h \
../../include/sys/resource.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h
div.s div.o : div.c ../../include/linux/math_emu.h ../../include/linux/sched.h ../../include/linux/head.h \ div.s div.o : div.c ../../include/linux/math_emu.h ../../include/linux/sched.h ../../include/linux/head.h \
../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \ ../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/sys/resource.h ../../include/sys/resource.h
ea.s ea.o : ea.c ../../include/stddef.h ../../include/linux/math_emu.h ../../include/linux/sched.h \ ea.s ea.o : ea.c ../../include/stddef.h ../../include/linux/math_emu.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/types.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/sys/dirent.h ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/linux/kernel.h ../../include/signal.h ../../include/sys/param.h \
../../include/sys/resource.h ../../include/asm/segment.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h ../../include/asm/segment.h
emulate.s emulate.o : emulate.c ../../include/signal.h ../../include/sys/types.h ../../include/linux/sched.h \ emulate.s emulate.o : emulate.c ../../include/signal.h ../../include/sys/types.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/dirent.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h
error.s error.o : error.c ../../include/signal.h ../../include/sys/types.h ../../include/linux/sched.h \ error.s error.o : error.c ../../include/signal.h ../../include/sys/types.h ../../include/linux/sched.h \
../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/dirent.h \ ../../include/linux/head.h ../../include/linux/fs.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h
get_put.s get_put.o : get_put.c ../../include/signal.h ../../include/sys/types.h ../../include/linux/math_emu.h \ get_put.s get_put.o : get_put.c ../../include/signal.h ../../include/sys/types.h ../../include/linux/math_emu.h \
../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \ ../../include/linux/sched.h ../../include/linux/head.h ../../include/linux/fs.h \
../../include/sys/dirent.h ../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/sys/dirent.h ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h \
../../include/sys/param.h ../../include/sys/time.h ../../include/time.h ../../include/sys/resource.h \ ../../include/linux/kernel.h ../../include/sys/param.h ../../include/sys/time.h \
../../include/asm/segment.h ../../include/time.h ../../include/sys/resource.h ../../include/asm/segment.h
mul.s mul.o : mul.c ../../include/linux/math_emu.h ../../include/linux/sched.h ../../include/linux/head.h \ mul.s mul.o : mul.c ../../include/linux/math_emu.h ../../include/linux/sched.h ../../include/linux/head.h \
../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \ ../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/linux/mm.h ../../include/linux/kernel.h \ ../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/sys/resource.h
sqrt.s sqrt.o : sqrt.c ../../include/linux/math_emu.h ../../include/linux/sched.h ../../include/linux/head.h \
../../include/linux/fs.h ../../include/sys/types.h ../../include/sys/dirent.h \
../../include/limits.h ../../include/sys/vfs.h ../../include/linux/mm.h ../../include/linux/kernel.h \
../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \ ../../include/signal.h ../../include/sys/param.h ../../include/sys/time.h ../../include/time.h \
../../include/sys/resource.h ../../include/sys/resource.h
...@@ -126,10 +126,14 @@ static void do_emu(struct info * info) ...@@ -126,10 +126,14 @@ static void do_emu(struct info * info)
return; return;
case 0x1ef: case 0x1ef:
math_abort(info,1<<(SIGILL-1)); math_abort(info,1<<(SIGILL-1));
case 0x1fa:
fsqrt(PST(0),&tmp);
real_to_real(&tmp,&ST(0));
return;
case 0x1f0: case 0x1f1: case 0x1f2: case 0x1f3: case 0x1f0: case 0x1f1: case 0x1f2: case 0x1f3:
case 0x1f4: case 0x1f5: case 0x1f6: case 0x1f7: case 0x1f4: case 0x1f5: case 0x1f6: case 0x1f7:
case 0x1f8: case 0x1f9: case 0x1fa: case 0x1fb: case 0x1f8: case 0x1f9: case 0x1fb: case 0x1fd:
case 0x1fd: case 0x1fe: case 0x1ff: case 0x1fe: case 0x1ff:
printk("%04x fxxx not implemented\n\r",code + 0xd800); printk("%04x fxxx not implemented\n\r",code + 0xd800);
math_abort(info,1<<(SIGILL-1)); math_abort(info,1<<(SIGILL-1));
case 0x1fc: case 0x1fc:
......
...@@ -11,6 +11,6 @@ ...@@ -11,6 +11,6 @@
void math_error(void) void math_error(void)
{ {
if (last_task_used_math) if (last_task_used_math)
last_task_used_math->signal |= 1<<(SIGFPE-1); send_sig(SIGFPE,last_task_used_math,1);
__asm__("fnclex"); __asm__("fnclex");
} }
/*
* linux/kernel/math/sqrt.c
*
* (C) 1991 Linus Torvalds
*/
/*
* simple and stupid temporary real fsqrt() routine
*
* There are probably better ways to do this, but this should work ok.
*/
#include <linux/math_emu.h>
#include <linux/sched.h>
static void shift_right(int * c)
{
__asm__("shrl $1,12(%0) ; rcrl $1,8(%0) ; rcrl $1,4(%0) ; rcrl $1,(%0)"
::"r" ((long) c));
}
static int sqr64(unsigned long * a, unsigned long * b)
{
unsigned long tmp[4];
__asm__("movl (%0),%%eax ; mull %%eax\n\t"
"movl %%eax,(%1) ; movl %%edx,4(%1)\n\t"
"movl 4(%0),%%eax ; mull %%eax\n\t"
"movl %%eax,8(%1) ; movl %%edx,12(%1)\n\t"
"movl (%0),%%eax ; mull 4(%0)\n\t"
"addl %%eax,%%eax ; adcl %%edx,%%edx\n\t"
"adcl $0,12(%1) ; addl %%eax,4(%1)\n\t"
"adcl %%edx,8(%1) ; adcl $0,12(%1)"
::"b" ((long) a),"c" ((long) tmp)
:"ax","bx","cx","dx");
if (tmp[3] > b[3] ||
(tmp[3] == b[3] && (tmp[2] > b[2] ||
(tmp[2] == b[2] && (tmp[1] > b[1] ||
(tmp[1] == b[1] && tmp[0] > b[0]))))))
return 0;
return 1;
}
void fsqrt(const temp_real * s, temp_real * d)
{
unsigned long src[4];
unsigned long res[2];
int exponent;
unsigned long mask, *c;
int i;
exponent = s->exponent;
src[0] = src[1] = 0;
src[2] = s->a;
src[3] = s->b;
d->exponent = 0;
d->a = d->b = 0;
if (exponent) /* fsqrt(0.0) = 0.0 */
return;
if (!src[2] && !src[3])
return;
if (exponent & 0x8000) {
send_sig(SIGFPE,current,0);
return;
}
if (exponent & 1) {
shift_right(src);
exponent++;
}
exponent >>= 1;
exponent += 0x1fff;
c = res + 2;
mask = 0;
for (i = 64 ; i > 0 ; i--) {
if (!(mask >>= 1)) {
c--;
mask = 0x80000000;
}
res[0] = d->a; res[1] = d->b;
*c |= mask;
if (sqr64(res,src)) {
d->a = res[0];
d->b = res[1];
}
}
if (!d->a && !d->b)
return;
while (!(d->b & 0x80000000)) {
__asm__("addl %%eax,%%eax ; adcl %%edx,%%edx"
:"=a" (d->a),"=d" (d->b)
:"0" (d->a),"1" (d->b));
exponent--;
}
d->exponent = exponent;
}
...@@ -94,7 +94,7 @@ int sys_signal(int signum, long handler, long restorer) ...@@ -94,7 +94,7 @@ int sys_signal(int signum, long handler, long restorer)
return -EINVAL; return -EINVAL;
tmp.sa_handler = (void (*)(int)) handler; tmp.sa_handler = (void (*)(int)) handler;
tmp.sa_mask = 0; tmp.sa_mask = 0;
tmp.sa_flags = SA_ONESHOT | SA_NOMASK; tmp.sa_flags = SA_ONESHOT | SA_NOMASK | SA_INTERRUPT;
tmp.sa_restorer = (void (*)(void)) restorer; tmp.sa_restorer = (void (*)(void)) restorer;
handler = (long) current->sigaction[signum-1].sa_handler; handler = (long) current->sigaction[signum-1].sa_handler;
current->sigaction[signum-1] = tmp; current->sigaction[signum-1] = tmp;
...@@ -135,16 +135,17 @@ int do_signal(long signr,struct pt_regs * regs) ...@@ -135,16 +135,17 @@ int do_signal(long signr,struct pt_regs * regs)
current->pid, signr, regs->eax, regs->orig_eax, current->pid, signr, regs->eax, regs->orig_eax,
sa->sa_flags & SA_INTERRUPT); sa->sa_flags & SA_INTERRUPT);
#endif #endif
sa_handler = (unsigned long) sa->sa_handler;
if ((regs->orig_eax != -1) && if ((regs->orig_eax != -1) &&
((regs->eax == -ERESTARTSYS) || (regs->eax == -ERESTARTNOINTR))) { ((regs->eax == -ERESTARTSYS) || (regs->eax == -ERESTARTNOINTR))) {
if ((regs->eax == -ERESTARTSYS) && ((sa->sa_flags & SA_INTERRUPT))) if ((sa_handler > 1) && (regs->eax == -ERESTARTSYS) &&
(sa->sa_flags & SA_INTERRUPT))
regs->eax = -EINTR; regs->eax = -EINTR;
else { else {
regs->eax = regs->orig_eax; regs->eax = regs->orig_eax;
regs->eip = old_eip -= 2; regs->eip = old_eip -= 2;
} }
} }
sa_handler = (unsigned long) sa->sa_handler;
if (sa_handler==1) { if (sa_handler==1) {
/* check for SIGCHLD: it's special */ /* check for SIGCHLD: it's special */
if (signr == SIGCHLD) if (signr == SIGCHLD)
......
...@@ -489,7 +489,7 @@ int sys_sethostname(char *name, int len) ...@@ -489,7 +489,7 @@ int sys_sethostname(char *name, int len)
if ((thisname.nodename[i] = get_fs_byte(name+i)) == 0) if ((thisname.nodename[i] = get_fs_byte(name+i)) == 0)
return 0; return 0;
} }
thisname.nodename[__NEW_UTS_LEN] = 0; thisname.nodename[i] = 0;
return 0; return 0;
} }
......
...@@ -40,35 +40,19 @@ dep: ...@@ -40,35 +40,19 @@ dep:
cp tmp_make Makefile cp tmp_make Makefile
### Dependencies: ### Dependencies:
_exit.s _exit.o : _exit.c ../include/unistd.h ../include/sys/stat.h ../include/sys/types.h \ _exit.s _exit.o : _exit.c ../include/linux/unistd.h
../include/sys/time.h ../include/time.h ../include/sys/times.h ../include/sys/utsname.h \ close.s close.o : close.c ../include/linux/unistd.h
../include/sys/param.h ../include/sys/resource.h ../include/utime.h ../include/linux/unistd.h
close.s close.o : close.c ../include/unistd.h ../include/sys/stat.h ../include/sys/types.h \
../include/sys/time.h ../include/time.h ../include/sys/times.h ../include/sys/utsname.h \
../include/sys/param.h ../include/sys/resource.h ../include/utime.h ../include/linux/unistd.h
ctype.s ctype.o : ctype.c ../include/linux/ctype.h ctype.s ctype.o : ctype.c ../include/linux/ctype.h
dup.s dup.o : dup.c ../include/unistd.h ../include/sys/stat.h ../include/sys/types.h \ dup.s dup.o : dup.c ../include/linux/unistd.h
../include/sys/time.h ../include/time.h ../include/sys/times.h ../include/sys/utsname.h \
../include/sys/param.h ../include/sys/resource.h ../include/utime.h ../include/linux/unistd.h
errno.s errno.o : errno.c errno.s errno.o : errno.c
execve.s execve.o : execve.c ../include/unistd.h ../include/sys/stat.h ../include/sys/types.h \ execve.s execve.o : execve.c ../include/linux/unistd.h
../include/sys/time.h ../include/time.h ../include/sys/times.h ../include/sys/utsname.h \ itimer.s itimer.o : itimer.c ../include/linux/unistd.h ../include/sys/time.h ../include/time.h \
../include/sys/param.h ../include/sys/resource.h ../include/utime.h ../include/linux/unistd.h ../include/sys/types.h
malloc.s malloc.o : malloc.c ../include/linux/kernel.h ../include/linux/mm.h ../include/linux/fs.h \ malloc.s malloc.o : malloc.c ../include/linux/kernel.h ../include/linux/mm.h ../include/linux/fs.h \
../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/signal.h \ ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h ../include/sys/vfs.h \
../include/asm/system.h ../include/signal.h ../include/asm/system.h
open.s open.o : open.c ../include/unistd.h ../include/sys/stat.h ../include/sys/types.h \ open.s open.o : open.c ../include/linux/unistd.h ../include/stdarg.h
../include/sys/time.h ../include/time.h ../include/sys/times.h ../include/sys/utsname.h \ setsid.s setsid.o : setsid.c ../include/sys/types.h ../include/linux/unistd.h
../include/sys/param.h ../include/sys/resource.h ../include/utime.h ../include/linux/unistd.h \
../include/stdarg.h
setsid.s setsid.o : setsid.c ../include/unistd.h ../include/sys/stat.h ../include/sys/types.h \
../include/sys/time.h ../include/time.h ../include/sys/times.h ../include/sys/utsname.h \
../include/sys/param.h ../include/sys/resource.h ../include/utime.h ../include/linux/unistd.h
string.s string.o : string.c ../include/linux/string.h string.s string.o : string.c ../include/linux/string.h
wait.s wait.o : wait.c ../include/unistd.h ../include/sys/stat.h ../include/sys/types.h \ wait.s wait.o : wait.c ../include/linux/unistd.h ../include/sys/wait.h ../include/sys/types.h
../include/sys/time.h ../include/time.h ../include/sys/times.h ../include/sys/utsname.h \ write.s write.o : write.c ../include/linux/unistd.h ../include/sys/types.h
../include/sys/param.h ../include/sys/resource.h ../include/utime.h ../include/linux/unistd.h \
../include/sys/wait.h
write.s write.o : write.c ../include/unistd.h ../include/sys/stat.h ../include/sys/types.h \
../include/sys/time.h ../include/time.h ../include/sys/times.h ../include/sys/utsname.h \
../include/sys/param.h ../include/sys/resource.h ../include/utime.h ../include/linux/unistd.h
...@@ -39,15 +39,15 @@ dep: ...@@ -39,15 +39,15 @@ dep:
### Dependencies: ### Dependencies:
memory.o : memory.c ../include/signal.h ../include/sys/types.h ../include/asm/system.h \ memory.o : memory.c ../include/signal.h ../include/sys/types.h ../include/asm/system.h \
../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h \ ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h \
../include/limits.h ../include/linux/mm.h ../include/linux/kernel.h ../include/sys/param.h \ ../include/limits.h ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h \
../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h
mmap.o : mmap.c ../include/sys/stat.h ../include/sys/types.h ../include/linux/sched.h \ mmap.o : mmap.c ../include/linux/stat.h ../include/linux/sched.h ../include/linux/head.h \
../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h ../include/limits.h \ ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h ../include/sys/param.h \ ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h ../include/signal.h \
../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/asm/segment.h \ ../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \
../include/asm/system.h ../include/errno.h ../include/sys/mman.h ../include/asm/segment.h ../include/asm/system.h ../include/errno.h ../include/sys/mman.h
swap.o : swap.c ../include/errno.h ../include/sys/stat.h ../include/sys/types.h \ swap.o : swap.c ../include/errno.h ../include/linux/stat.h ../include/linux/mm.h \
../include/linux/mm.h ../include/linux/fs.h ../include/sys/dirent.h ../include/limits.h \ ../include/linux/fs.h ../include/sys/types.h ../include/sys/dirent.h ../include/limits.h \
../include/linux/kernel.h ../include/signal.h ../include/linux/string.h ../include/linux/sched.h \ ../include/sys/vfs.h ../include/linux/kernel.h ../include/signal.h ../include/linux/string.h \
../include/linux/head.h ../include/sys/param.h ../include/sys/time.h ../include/time.h \ ../include/linux/sched.h ../include/linux/head.h ../include/sys/param.h ../include/sys/time.h \
../include/sys/resource.h ../include/time.h ../include/sys/resource.h
...@@ -565,7 +565,7 @@ static int share_page(struct inode * inode, unsigned long address) ...@@ -565,7 +565,7 @@ static int share_page(struct inode * inode, unsigned long address)
struct task_struct ** p; struct task_struct ** p;
int i; int i;
if (inode->i_count < 2 || !inode) if (!inode || inode->i_count < 2)
return 0; return 0;
for (p = &LAST_TASK ; p > &FIRST_TASK ; --p) { for (p = &LAST_TASK ; p > &FIRST_TASK ; --p) {
if (!*p) if (!*p)
......
...@@ -39,13 +39,14 @@ dep: ...@@ -39,13 +39,14 @@ dep:
### Dependencies: ### Dependencies:
socket.o : socket.c ../include/signal.h ../include/sys/types.h ../include/errno.h \ socket.o : socket.c ../include/signal.h ../include/sys/types.h ../include/errno.h \
../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h \ ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h ../include/sys/dirent.h \
../include/limits.h ../include/linux/mm.h ../include/linux/kernel.h ../include/sys/param.h \ ../include/limits.h ../include/sys/vfs.h ../include/linux/mm.h ../include/linux/kernel.h \
../include/sys/time.h ../include/time.h ../include/sys/resource.h ../include/asm/system.h \ ../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \
../include/asm/segment.h ../include/sys/socket.h ../include/sys/stat.h ../include/fcntl.h \ ../include/linux/stat.h ../include/asm/system.h ../include/asm/segment.h ../include/sys/socket.h \
../include/termios.h kern_sock.h socketcall.h ../include/fcntl.h ../include/termios.h kern_sock.h socketcall.h
unix.o : unix.c ../include/signal.h ../include/sys/types.h ../include/errno.h \ unix.o : unix.c ../include/signal.h ../include/sys/types.h ../include/errno.h \
../include/linux/string.h ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \ ../include/linux/string.h ../include/linux/sched.h ../include/linux/head.h ../include/linux/fs.h \
../include/sys/dirent.h ../include/limits.h ../include/linux/mm.h ../include/linux/kernel.h \ ../include/sys/dirent.h ../include/limits.h ../include/sys/vfs.h ../include/linux/mm.h \
../include/sys/param.h ../include/sys/time.h ../include/time.h ../include/sys/resource.h \ ../include/linux/kernel.h ../include/sys/param.h ../include/sys/time.h ../include/time.h \
../include/asm/system.h ../include/asm/segment.h ../include/sys/socket.h ../include/sys/un.h \ ../include/sys/resource.h ../include/linux/stat.h ../include/asm/system.h ../include/asm/segment.h \
../include/sys/stat.h ../include/fcntl.h ../include/termios.h kern_sock.h ../include/sys/socket.h ../include/sys/un.h ../include/fcntl.h ../include/termios.h \
kern_sock.h
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