Update USB documentation.
[qemu] / pc-bios / proll.patch
index e72e0e4..dbe01e4 100644 (file)
@@ -1,6 +1,6 @@
-diff -ruN proll_18.orig/Makefile proll-patch8/Makefile
+diff -ruN proll_18.orig/Makefile proll-patch-15/Makefile
 --- proll_18.orig/Makefile     2002-09-13 14:16:59.000000000 +0000
-+++ proll-patch8/Makefile      2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/Makefile    2005-11-09 18:14:51.000000000 +0000
 @@ -4,6 +4,7 @@
        make -C krups-ser    all
        make -C espresso     all
@@ -14,14 +14,14 @@ diff -ruN proll_18.orig/Makefile proll-patch8/Makefile
        make -C espresso     clean
        make -C espresso-ser clean
 +      make -C qemu clean
-diff -ruN proll_18.orig/qemu/Makefile proll-patch8/qemu/Makefile
+diff -ruN proll_18.orig/qemu/Makefile proll-patch-15/qemu/Makefile
 --- proll_18.orig/qemu/Makefile        1970-01-01 00:00:00.000000000 +0000
-+++ proll-patch8/qemu/Makefile 2005-03-02 16:41:50.000000000 +0000
-@@ -0,0 +1,122 @@
++++ proll-patch-15/qemu/Makefile       2005-08-14 10:25:06.000000000 +0000
+@@ -0,0 +1,123 @@
 +#
 +# proll:
 +# qemu/Makefile - make PROLL for QEMU
-+# $Id: proll.patch,v 1.4 2005-04-06 20:45:26 bellard Exp $
++# $Id: proll.patch,v 1.6 2005-11-11 00:24:57 bellard Exp $
 +#
 +# Copyright 1999 Pete Zaitcev
 +# This is Free Software is licensed under terms of GNU General Public License.
@@ -47,16 +47,16 @@ diff -ruN proll_18.orig/qemu/Makefile proll-patch8/qemu/Makefile
 +# want to shift it to form a PGD entry. A relocatable label will not work.
 +# Linux kernel expects us to be at LINUX_OPPROM_BEGVM <asm-sparc/openprom.h>.
 +PROLBASE =   0xffd00000
-+PROLRODATA = 0xffd07000
-+PROLDATA =   0xffd09000
++PROLRODATA = 0xffd08000
++PROLDATA =   0xffd0b000
 +PROLSIZE = 240*1024
 +
 +# Linux
 +# Fixed %g6 is for arch/sparc/kernel/head.S, it seems ok w/o -ffixed-g6.
 +# Kernel uses -fcall-used-g5 -fcall-used-g7, we probably do not need them.
 +# __ANSI__ is supposed to be on by default but it is not.
-+CFLAGS = -O2 -Wall -DPROLBASE=$(PROLBASE) -DPROLDATA=$(PROLDATA) -DPROLRODATA=$(PROLRODATA) -D__ANSI__=1 -I$(SRC) -mcpu=hypersparc -g -DQEMU
-+ASFLAGS = -D__ASSEMBLY__ -I$(SRC) -DPROLRODATA=$(PROLRODATA) -DPROLDATA=$(PROLDATA) -DPROLSIZE=$(PROLSIZE) -g
++CFLAGS = -O2 -W -Wall -DPROLBASE=$(PROLBASE) -DPROLDATA=$(PROLDATA) -DPROLRODATA=$(PROLRODATA) -D__ANSI__=1 -I$(SRC) -mcpu=hypersparc -Wa,-xarch=v8 -g -DQEMU -m32 -fno-builtin
++ASFLAGS = -D__ASSEMBLY__ -I$(SRC) -DPROLRODATA=$(PROLRODATA) -DPROLDATA=$(PROLDATA) -DPROLSIZE=$(PROLSIZE) -g -Wa,-xarch=v8 -Wa,-32
 +# Solaris or Linux/i386 cross compilation
 +#CFLAGS = -Iinclude -O
 +
@@ -68,7 +68,7 @@ diff -ruN proll_18.orig/qemu/Makefile proll-patch8/qemu/Makefile
 +OBJS = head.o wuf.o wof.o main.o $(CONSOLE) \
 + printf.o le.o system_qemu.o iommu.o \
 + arp.o netinit.o bootp.o packet.o tftp.o udp.o sched_4m.o openprom.o \
-+ vconsole.o hconsole.o rconsole.o vcons_zs.o
++ vconsole.o hconsole.o rconsole.o vcons_zs.o esp.o
 +
 +all:           $(ALL)
 +
@@ -106,7 +106,8 @@ diff -ruN proll_18.orig/qemu/Makefile proll-patch8/qemu/Makefile
 +      $(CROSSCC) $(CFLAGS) -c $(SRC)/$*.c
 +le.o:         $(SRC)/le.c $(SRC)/dma.h $(SRC)/system.h $(SRC)/netpriv.h $(SRC)/romlib.h $(SRC)/general.h $(SRC)/net.h $(SRC)/phys_jj.h
 +      $(CROSSCC) $(CFLAGS) -c $(SRC)/$*.c
-+
++esp.o:                $(SRC)/esp.c $(SRC)/dma.h $(SRC)/system.h $(SRC)/romlib.h $(SRC)/general.h $(SRC)/phys_jj.h
++      $(CROSSCC) $(CFLAGS) -c $(SRC)/$*.c
 +arp.o:                $(SRC)/arp.c $(SRC)/general.h $(SRC)/net.h $(SRC)/romlib.h $(SRC)/netpriv.h $(SRC)/arp.h
 +      $(CROSSCC) $(CFLAGS) -c $(SRC)/$*.c
 +netinit.o:    $(SRC)/netinit.c $(SRC)/general.h $(SRC)/net.h $(SRC)/romlib.h $(SRC)/netpriv.h $(SRC)/arp.h $(SRC)/ip.h $(SRC)/udp.h
@@ -140,17 +141,17 @@ diff -ruN proll_18.orig/qemu/Makefile proll-patch8/qemu/Makefile
 +
 +proll.aout:   $(PROLLEXE)
 +      $(ELFTOAOUT) -o proll.aout $(PROLLEXE)
-diff -ruN proll_18.orig/qemu/head.S proll-patch8/qemu/head.S
+diff -ruN proll_18.orig/qemu/head.S proll-patch-15/qemu/head.S
 --- proll_18.orig/qemu/head.S  1970-01-01 00:00:00.000000000 +0000
-+++ proll-patch8/qemu/head.S   2005-03-02 15:30:47.000000000 +0000
-@@ -0,0 +1,539 @@
++++ proll-patch-15/qemu/head.S 2005-07-12 22:24:17.000000000 +0000
+@@ -0,0 +1,543 @@
 +/**
 + ** Standalone startup code for Linux PROM emulator.
 + ** Copyright 1999 Pete A. Zaitcev
 + ** This code is licensed under GNU General Public License.
 + **/
 +/*
-+ * $Id: proll.patch,v 1.4 2005-04-06 20:45:26 bellard Exp $
++ * $Id: proll.patch,v 1.6 2005-11-11 00:24:57 bellard Exp $
 + */
 +
 +#include <psr.h>
@@ -442,6 +443,10 @@ diff -ruN proll_18.orig/qemu/head.S proll-patch8/qemu/head.S
 +C_LABEL(bootup_user_stack):           .skip 0x2000
 +
 +      .section ".text"
++      .register %g2, #scratch
++      .register %g3, #scratch
++      .register %g6, #scratch
++      .register %g7, #scratch
 +
 +goprol:
 +      ! %g1 contains end of memory
@@ -683,10 +688,10 @@ diff -ruN proll_18.orig/qemu/head.S proll-patch8/qemu/head.S
 +C_LABEL(ldb_bypass):
 +      retl
 +       lduba [%o0] ASI_M_BYPASS, %o0
-diff -ruN proll_18.orig/qemu/main.c proll-patch8/qemu/main.c
+diff -ruN proll_18.orig/qemu/main.c proll-patch-15/qemu/main.c
 --- proll_18.orig/qemu/main.c  1970-01-01 00:00:00.000000000 +0000
-+++ proll-patch8/qemu/main.c   2005-04-03 11:58:46.000000000 +0000
-@@ -0,0 +1,173 @@
++++ proll-patch-15/qemu/main.c 2005-08-14 10:07:48.000000000 +0000
+@@ -0,0 +1,185 @@
 +/**
 + ** Proll (PROM replacement)
 + ** Copyright 1999 Pete Zaitcev
@@ -711,7 +716,9 @@ diff -ruN proll_18.orig/qemu/main.c proll-patch8/qemu/main.c
 +void *init_openprom_qemu(int bankc, struct bank *bankv, unsigned hiphybas, const char *cmdline, char boot_device, int nographic);
 +int vcon_zs_init(struct vconterm *t, unsigned int a0);
 +int vcon_zs_write(struct vconterm *t, char *data, int leng);
-+
++int vcon_zs_getch(struct vconterm *t);
++void esp_probe();
++int esp_boot(int unit);
 +static void init_idprom(void);
 +
 +struct vconterm dp0;
@@ -733,7 +740,7 @@ diff -ruN proll_18.orig/qemu/main.c proll-patch8/qemu/main.c
 +} *hw_idprom;
 +
 +int ignore_fault, fault_ignored;
-+void *printk_fn;
++void *printk_fn, *getch_fn;
 +unsigned int q_height, q_width;
 +
 +/*
@@ -745,7 +752,7 @@ diff -ruN proll_18.orig/qemu/main.c proll-patch8/qemu/main.c
 +      unsigned int hiphybas;
 +      const void *romvec;
 +      unsigned int ram_size;
-+      char nographic;
++      char nographic, bootdev;
 +
 +      nographic = ldb_bypass(PHYS_JJ_EEPROM + 0x2F);
 +      if (!nographic) {
@@ -753,10 +760,12 @@ diff -ruN proll_18.orig/qemu/main.c proll-patch8/qemu/main.c
 +          q_height = ldh_bypass(PHYS_JJ_EEPROM + 0x56);
 +          vcon_init(&dp0, PHYS_JJ_TCX_FB);
 +          printk_fn = vcon_write;
++          getch_fn = vcon_getch;
 +      }
 +      else {
 +          vcon_zs_init(&dp0, 0x71100004);
 +          printk_fn = vcon_zs_write;
++          getch_fn = vcon_zs_getch;
 +      }
 +
 +
@@ -790,9 +799,13 @@ diff -ruN proll_18.orig/qemu/main.c proll-patch8/qemu/main.c
 +      sched_init();
 +      le_probe();
 +      init_net();
++      esp_probe();
 +
-+      printk("Boot device: %c\n", hw_idprom->boot_device);
-+      if (hw_idprom->boot_device == 'n') {
++      bootdev = hw_idprom->boot_device;
++      printk("Boot device: %c\n", bootdev);
++      if (hw_idprom->kernel_size > 0) {
++          printk("Kernel already loaded\n");
++      } else if (bootdev == 'n') {
 +          if (bootp() != 0) fatal();
 +          /*
 +           * boot_rec.bp_file cannot be used because system PROM
@@ -809,6 +822,10 @@ diff -ruN proll_18.orig/qemu/main.c proll-patch8/qemu/main.c
 +          fname[14] = 0;
 +          
 +          if (load(boot_rec.bp_siaddr, fname) != 0) fatal();
++      } else if (bootdev == 'c') {
++          if (esp_boot(0) != 0) fatal();
++      } else if (bootdev == 'd') {
++          if (esp_boot(2) != 0) fatal();
 +      }
 +
 +      romvec = init_openprom_qemu(bb.nbanks, bb.bankv, hiphybas,
@@ -839,7 +856,7 @@ diff -ruN proll_18.orig/qemu/main.c proll-patch8/qemu/main.c
 +
 +/*
 + */
-+void udelay(unsigned long usecs)
++void udelay(__attribute__((unused)) unsigned long usecs)
 +{
 +    // Qemu hardware is perfect and does not need any delays!
 +}
@@ -860,10 +877,10 @@ diff -ruN proll_18.orig/qemu/main.c proll-patch8/qemu/main.c
 +      hw_idprom = va_prom; 
 +}
 +
-diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
+diff -ruN proll_18.orig/qemu/openprom.c proll-patch-15/qemu/openprom.c
 --- proll_18.orig/qemu/openprom.c      1970-01-01 00:00:00.000000000 +0000
-+++ proll-patch8/qemu/openprom.c       2005-04-06 16:53:31.000000000 +0000
-@@ -0,0 +1,665 @@
++++ proll-patch-15/qemu/openprom.c     2005-11-07 20:11:04.000000000 +0000
+@@ -0,0 +1,910 @@
 +/*
 + * PROM interface support
 + * Copyright 1996 The Australian National University.
@@ -882,10 +899,12 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +
 +//#define DEBUG_OBP
 +
++#define PAGE_SIZE 4096
++
 +struct property {
 +      const char *name;
 +      const char *value;
-+      const int length;
++      int length;
 +};
 +
 +struct node {
@@ -905,12 +924,13 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +static const struct property null_properties = { NULL, NULL, -1 };
 +static const int prop_true = -1;
 +
-+static const struct property propv_root[] = {
-+      {"name",        "SUNW,JavaStation-1", sizeof("SUNW,JavaStation-1") },
++static struct property propv_root[7];
++
++static const struct property propv_root_templ[] = {
++      {"name",        "SUNW,SparcStation-5", sizeof("SUNW,SparcStation-5") },
 +      {"idprom",      obp_idprom, IDPROM_SIZE},
-+      {"banner-name", "JavaStation", sizeof("JavaStation")},
++      {"banner-name", "SparcStation", sizeof("SparcStation")},
 +      {"compatible",  "sun4m", 6},
-+      {NULL, NULL, -1}
 +};
 +
 +static const int prop_iommu_reg[] = {
@@ -971,7 +991,7 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +static const int height = 0x300;
 +static const int width = 0x400;
 +static const int linebytes = 0x400;
-+static const int depth = 8;
++static const int depth = 24;
 +static const int tcx_intr[] = { 5, 0 };
 +static const int tcx_interrupts = 5;
 +static const struct property propv_sbus_tcx[] = {
@@ -989,7 +1009,7 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +      {"linebytes",   (char*)&linebytes, sizeof(int)},
 +      {"depth",       (char*)&depth, sizeof(int)},
 +      {"reg",         (char*)&prop_tcx_regs[0], sizeof(prop_tcx_regs)},
-+      {"tcx-8-bit",   (char*)&prop_true, 0},
++      {"tcx-8-bit",   0, -1},
 +      {"intr",        (char*)&tcx_intr[0], sizeof(tcx_intr)},
 +      {"interrupts",  (char*)&tcx_interrupts, sizeof(tcx_interrupts)},
 +      {"device_type", "display", sizeof("display")},
@@ -1086,15 +1106,17 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +static const int prop_zs_reg[] = {
 +      0x0, 0x00000000, 0x00000008,
 +};
-+static const int prop_zs_slave[] = { 1 };
 +static void *prop_zs_addr;
++static const int prop_zs_slave = 1;
 +static const struct property propv_obio_zs[] = {
 +      {"name",        "zs", sizeof("zs")},
 +      {"reg",         (char*)&prop_zs_reg[0], sizeof(prop_zs_reg) },
-+      {"slave",       (char*)&prop_zs_slave[0], sizeof(prop_zs_slave) },
++      {"slave",       (char*)&prop_zs_slave, sizeof(prop_zs_slave) },
 +      {"device_type", "serial", sizeof("serial") },
 +      {"intr",        (char*)&prop_zs_intr[0], sizeof(prop_zs_intr) },
 +      {"address",     (char*)&prop_zs_addr, sizeof(prop_zs_addr) },
++      {"keyboard",    (char*)&prop_true, 0},
++      {"mouse",       (char*)&prop_true, 0},
 +      {NULL, NULL, -1}
 +};
 +
@@ -1103,11 +1125,11 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +      0x0, 0x00100000, 0x00000008,
 +};
 +static void *prop_zs1_addr;
-+static const int prop_zs1_slave[] = { 0 };
++static const int prop_zs1_slave = 0;
 +static const struct property propv_obio_zs1[] = {
 +      {"name",        "zs", sizeof("zs")},
 +      {"reg",         (char*)&prop_zs1_reg[0], sizeof(prop_zs1_reg) },
-+      {"slave",       (char*)&prop_zs1_slave[0], sizeof(prop_zs1_slave) },
++      {"slave",       (char*)&prop_zs1_slave, sizeof(prop_zs1_slave) },
 +      {"device_type", "serial", sizeof("serial") },
 +      {"intr",        (char*)&prop_zs1_intr[0], sizeof(prop_zs1_intr) },
 +      {"address",     (char*)&prop_zs1_addr, sizeof(prop_zs1_addr) },
@@ -1170,6 +1192,15 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +      {NULL, NULL, -1}
 +};
 +
++static const int prop_apc_reg[] = {
++      0x4, 0x0a000000, 0x00000010,
++};
++static const struct property propv_sbus_apc[] = {
++      {"name",        "xxxpower-management", sizeof("xxxpower-management")},
++      {"reg",         (char*)&prop_apc_reg[0], sizeof(prop_apc_reg) },
++      {NULL, NULL, -1}
++};
++
 +static const int prop_fd_intr[] = { 0x2b, 0x0 };
 +static const int prop_fd_reg[] = {
 +      0x0, 0x00400000, 0x0000000f,
@@ -1206,41 +1237,62 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +      {"name",        "options", sizeof("options")},
 +      {"screen-#columns",     "80", sizeof("80")},
 +      {"screen-#rows",        "25", sizeof("25")},
-+      {"tpe-link-test?",      "true", sizeof("true")},
++      {"tpe-link-test?",      (char *)&prop_true, 0},
 +      {"ttya-mode",           "9600,8,n,1,-", sizeof("9600,8,n,1,-")},
-+      {"ttya-ignore-cd",      "true", sizeof("true")},
-+      {"ttya-rts-dtr-off",    "false", sizeof("false")},
++      {"ttya-ignore-cd",      (char *)&prop_true, 0},
++      {"ttya-rts-dtr-off",    0, -1},
 +      {"ttyb-mode",           "9600,8,n,1,-", sizeof("9600,8,n,1,-")},
-+      {"ttyb-ignore-cd",      "true", sizeof("true")},
-+      {"ttyb-rts-dtr-off",    "false", sizeof("false")},
++      {"ttyb-ignore-cd",      (char *)&prop_true, 0},
++      {"ttyb-rts-dtr-off",    0, -1},
++      {NULL, NULL, -1}
++};
++
++static int prop_mem_reg[3];
++static int prop_mem_avail[3];
++
++static const struct property propv_memory[] = {
++      {"name",        "memory", sizeof("memory")},
++      {"reg",         (char*)&prop_mem_reg[0], sizeof(prop_mem_reg) },
++      {"available",   (char*)&prop_mem_avail[0], sizeof(prop_mem_avail) },
++      {NULL, NULL, -1}
++};
++
++static int prop_vmem_avail[6];
++
++static const struct property propv_vmemory[] = {
++      {"name",        "virtual-memory", sizeof("virtual-memory")},
++      {"available",   (char*)&prop_vmem_avail[0], sizeof(prop_vmem_avail) },
 +      {NULL, NULL, -1}
 +};
 +
 +static const struct node nodes[] = {
 +      { &null_properties,      1,  0 }, /* 0 = big brother of root */
 +      { propv_root,            0,  2 }, /*  1 "/" */
-+      { propv_iommu,          11,  3 }, /*  2 "/iommu" */
++      { propv_iommu,          12,  3 }, /*  2 "/iommu" */
 +      { propv_sbus,            0,  4 }, /*  3 "/iommu/sbus" */
 +      { propv_sbus_tcx,        5,  0 }, /*  4 "/iommu/sbus/SUNW,tcx" */
 +      { propv_sbus_ledma,      7,  6 }, /*  5 "/iommu/sbus/ledma" */
 +      { propv_sbus_ledma_le,   0,  0 }, /*  6 "/iommu/sbus/ledma/le" */
 +      { propv_sbus_cs4231,     8,  0 }, /*  7 "/iommu/sbus/SUNW,CS4231 */
 +      { propv_sbus_bpp,        9,  0 }, /*  8 "/iommu/sbus/SUNW,bpp */
-+      { propv_sbus_espdma,     0, 10 }, /*  9 "/iommu/sbus/espdma" */
++      { propv_sbus_espdma,    11, 10 }, /*  9 "/iommu/sbus/espdma" */
 +      { propv_sbus_espdma_esp, 0,  0 }, /* 10 "/iommu/sbus/espdma/esp" */
-+      { propv_cpu,            12,  0 }, /* 11 "/STP1012PGA" */
-+      { propv_obio,           22, 13 }, /* 12 "/obio" */
-+      { propv_obio_int,       14,  0 }, /* 13 "/obio/interrupt" */
-+      { propv_obio_cnt,       15,  0 }, /* 14 "/obio/counter" */
-+      { propv_obio_eep,       16,  0 }, /* 15 "/obio/eeprom" */
-+      { propv_obio_auxio,     17,  0 }, /* 16 "/obio/auxio" */
-+      { propv_obio_zs1,       18,  0 }, /* 17 "/obio/zs@0,100000"
++      { propv_sbus_apc,        0,  0 }, /* 11 "/iommu/sbus/power-management */
++      { propv_cpu,            13,  0 }, /* 12 "/STP1012PGA" */
++      { propv_obio,           23, 14 }, /* 13 "/obio" */
++      { propv_obio_int,       15,  0 }, /* 14 "/obio/interrupt" */
++      { propv_obio_cnt,       16,  0 }, /* 15 "/obio/counter" */
++      { propv_obio_eep,       17,  0 }, /* 16 "/obio/eeprom" */
++      { propv_obio_auxio,     18,  0 }, /* 17 "/obio/auxio" */
++      { propv_obio_zs1,       19,  0 }, /* 18 "/obio/zs@0,100000"
 +                                           Must be before zs@0,0! */
-+      { propv_obio_zs,        19,  0 }, /* 18 "/obio/zs@0,0" */
-+      { propv_obio_fd,        20,  0 }, /* 19 "/obio/SUNW,fdtwo" */
-+      { propv_obio_pw,        21,  0 }, /* 20 "/obio/power" */
-+      { propv_obio_cf,         0,  0 }, /* 21 "/obio/slavioconfig@0,800000" */
-+      { propv_options,         0,  0 }, /* 22 "/options" */
++      { propv_obio_zs,        20,  0 }, /* 19 "/obio/zs@0,0" */
++      { propv_obio_fd,        21,  0 }, /* 20 "/obio/SUNW,fdtwo" */
++      { propv_obio_pw,        22,  0 }, /* 21 "/obio/power" */
++      { propv_obio_cf,         0,  0 }, /* 22 "/obio/slavioconfig@0,800000" */
++      { propv_options,        24,  0 }, /* 23 "/options" */
++      { propv_memory,         25,  0 }, /* 24 "/memory" */
++      { propv_vmemory,         0,  0 }, /* 25 "/virtual-memory" */
 +};
 +
 +static struct linux_mlist_v0 totphys[MAX_BANKS];
@@ -1266,6 +1318,7 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +
 +static void (*synch_hook)(void);
 +static char obp_stdin, obp_stdout;
++static int obp_fd_stdin, obp_fd_stdout;
 +
 +static int obp_nbgetchar(void);
 +static int obp_nbputchar(int ch);
@@ -1274,7 +1327,13 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +static void obp_halt(void);
 +static int obp_devopen(char *str);
 +static int obp_devclose(int dev_desc);
++static int obp_devread(int dev_desc, char *buf, int nbytes);
++static int obp_devwrite(int dev_desc, char *buf, int nbytes);
++static int obp_devseek(int dev_desc, int hi, int lo);
 +static int obp_rdblkdev(int dev_desc, int num_blks, int blk_st, char *buf);
++static char *obp_dumb_mmap(char *va, int which_io, unsigned int pa, unsigned int size);
++static void obp_dumb_munmap(char *va, unsigned int size);
++static int obp_inst2pkg(int dev_desc);
 +
 +static void doublewalk(unsigned ptab1, unsigned va)
 +{
@@ -1287,6 +1346,17 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +
 +static struct linux_romvec romvec0;
 +
++struct fd {
++    int unit, part;
++    int offset;
++    int (*pread)(int dev_desc, int offset, char *buf, unsigned int nbytes);
++    int (*pwrite)(int dev_desc, int offset, char *buf, unsigned int nbytes);
++} fd_table[16];
++
++static int fd_index;
++static int con_pread(int dev_desc, int offset, char *buf, unsigned int nbytes);
++static int con_pwrite(int dev_desc, int offset, char *buf, unsigned int nbytes);
++
 +void *
 +init_openprom_qemu(int bankc, struct bank *bankv, unsigned hiphybas,
 +                 const char *cmdline, char boot_device, int nographic)
@@ -1328,6 +1398,18 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +      totmap[0].theres_more = 0;
 +      totmap[0].start_adr = (char*) PROLBASE;
 +      totmap[0].num_bytes = PROLSIZE;
++      prop_mem_reg[0] = 0;
++      prop_mem_reg[1] = 0;
++      prop_mem_reg[2] = bankv[0].length;
++      prop_mem_avail[0] = 0;
++      prop_mem_avail[1] = 0;
++      prop_mem_avail[2] = hiphybas;
++      prop_vmem_avail[0] = 0;
++      prop_vmem_avail[1] = 0;
++      prop_vmem_avail[2] = PROLBASE-1;
++      prop_vmem_avail[3] = 0;
++      prop_vmem_avail[4] = 0xffe00000;
++      prop_vmem_avail[5] = 0x00200000;
 +
 +      /*
 +       * idprom
@@ -1336,6 +1418,7 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +
 +      // Linux wants a R/W romvec table
 +      romvec0.pv_magic_cookie = LINUX_OPPROM_MAGIC;
++      romvec0.pv_romvers = 3;
 +      romvec0.pv_plugin_revision = 77;
 +      romvec0.pv_printrev = 0x10203;
 +      romvec0.pv_v0mem.v0_totphys = &ptphys;
@@ -1353,30 +1436,77 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +      romvec0.pv_nbgetchar = obp_nbgetchar;
 +      romvec0.pv_nbputchar = obp_nbputchar;
 +      romvec0.pv_reboot = obp_reboot;
++      romvec0.pv_printf = (void (*)(const char *fmt, ...))printk;
 +      romvec0.pv_abort = obp_abort;
 +      romvec0.pv_halt = obp_halt;
 +      romvec0.pv_synchook = &synch_hook;
 +      romvec0.pv_v0bootargs = &obp_argp;
++      romvec0.pv_v2devops.v2_inst2pkg = obp_inst2pkg;
++      romvec0.pv_v2devops.v2_dumb_mmap = obp_dumb_mmap;
++      romvec0.pv_v2devops.v2_dumb_munmap = obp_dumb_munmap;
++      romvec0.pv_v2devops.v2_dev_open = obp_devopen;
++      romvec0.pv_v2devops.v2_dev_close = (void (*)(int))obp_devclose;
++      romvec0.pv_v2devops.v2_dev_read = obp_devread;
++      romvec0.pv_v2devops.v2_dev_write = obp_devwrite;
++      romvec0.pv_v2devops.v2_dev_seek = obp_devseek;
++      obp_arg.boot_dev_ctrl = 0;
++      obp_arg.boot_dev_unit = '0';
++      obp_arg.argv[0] = "sd(0,0,0):d";
 +      switch(boot_device) {
 +      default:
 +      case 'a':
 +          obp_arg.argv[0] = "fd()";
++          obp_arg.boot_dev[0] = 'f';
++          obp_arg.boot_dev[1] = 'd';
 +          break;
++      case 'd':
++          obp_arg.boot_dev_unit = '2';
++          obp_arg.argv[0] = "sd(0,2,0):d";
++          // Fall through
 +      case 'c':
-+          obp_arg.argv[0] = "sd()";
++          obp_arg.boot_dev[0] = 's';
++          obp_arg.boot_dev[1] = 'd';
 +          break;
 +      case 'n':
 +          obp_arg.argv[0] = "le()";
++          obp_arg.boot_dev[0] = 'l';
++          obp_arg.boot_dev[1] = 'e';
 +          break;
 +      }
 +      obp_arg.argv[1] = cmdline;
-+
++      romvec0.pv_v2bootargs.bootpath = &obp_arg.argv[0];
++      romvec0.pv_v2bootargs.bootargs = &cmdline;
++      romvec0.pv_v2bootargs.fd_stdin = &obp_fd_stdin;
++      romvec0.pv_v2bootargs.fd_stdout = &obp_fd_stdout;
++
++      bcopy(propv_root_templ, propv_root, sizeof(propv_root_templ));
++      propv_root[4].name = "stdin-path";
++      propv_root[5].name = "stdout-path";
++      obp_fd_stdin = 0;
++      obp_fd_stdout = 1;
++      fd_table[0].pread = con_pread;
++      fd_table[0].pwrite = con_pwrite;
++      fd_table[1].pread = con_pread;
++      fd_table[1].pwrite = con_pwrite;
++      fd_index = 2;
 +      if (nographic) {
 +          obp_stdin = PROMDEV_TTYA;
++          propv_root[4].value = "/obio/zs@0,100000:a";
++          propv_root[4].length = sizeof("/obio/zs@0,100000:a");
++          fd_table[0].unit = 18;
 +          obp_stdout = PROMDEV_TTYA;
++          propv_root[5].value = "/obio/zs@0,100000:a";
++          propv_root[5].length = sizeof("/obio/zs@0,100000:a");
++          fd_table[1].unit = 18;
 +      } else {
 +          obp_stdin = PROMDEV_KBD;
++          propv_root[4].value = "/obio/zs@0,0";
++          propv_root[4].length = sizeof("/obio/zs@0,0");
++          fd_table[0].unit = 19;
 +          obp_stdout = PROMDEV_SCREEN;
++          propv_root[5].value = "/iommu/sbus/SUNW,tcx";
++          propv_root[5].length = sizeof("/iommu/sbus/SUNW,tcx");
++          fd_table[1].unit = 4;
 +      }
 +      prop_zs_addr = map_io(0x71000000, 8);
 +      prop_zs1_addr = map_io(0x71100000, 8);
@@ -1450,7 +1580,10 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +      return -1;
 +}
 +
-+static int obp_setprop(int node, char *name, char *value, int len)
++static int obp_setprop(__attribute__((unused)) int node,
++                     __attribute__((unused)) char *name,
++                     __attribute__((unused)) char *value,
++                     __attribute__((unused)) int len)
 +{
 +#ifdef DEBUG_OBP
 +        printk("obp_setprop(%d, %s) = %s (%d)\n", node, name, value, len);
@@ -1480,12 +1613,14 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +#ifdef DEBUG_OBP
 +        printk("obp_nextprop(%d, %s): not found\n", node, name);
 +#endif
-+      return (const char *)-1;
++      return "";
 +}
 +
++extern int (*getch_fn)(struct vconterm *v);
++
 +static int obp_nbgetchar(void) {
 +      extern struct vconterm dp0;
-+      return vcon_getch(&dp0);
++      return getch_fn(&dp0);
 +}
 +
 +static int obp_nbputchar(int ch) {
@@ -1494,45 +1629,172 @@ diff -ruN proll_18.orig/qemu/openprom.c proll-patch8/qemu/openprom.c
 +}
 +
 +static void obp_reboot(char *str) {
-+      printk("rebooting (%s): not implemented, freezing\n", str);
++      printk("rebooting (%s)\n", str);
++      stb_bypass(0x71f00000, 1);
 +      for (;;) {}
 +}
 +
 +static void obp_abort() {
-+      printk("abort, freezing\n");
++      printk("abort, power off\n");
++      stb_bypass(0x71910000, 1);
 +      for (;;) {}
 +}
 +
 +static void obp_halt() {
-+      printk("halt, freezing\n");
++      printk("halt, power off\n");
++      stb_bypass(0x71910000, 1);
 +      for (;;) {}
 +}
 +
++extern void *esp_read(int unit, int part, int offset, short len);
++
++static int esp_pread(int dev_desc, int offset, char *buf, unsigned int nbytes)
++{
++    unsigned int i;
++    void *src;
++
++    for(i = 0; i < nbytes; i += 512) {
++      src = esp_read(fd_table[dev_desc].unit, fd_table[dev_desc].part, (offset + i) / 512, 512);
++      memcpy(&buf[i], src, 512);
++    }
++    return nbytes;
++}
++
++static int con_pread(__attribute__((unused)) int dev_desc, __attribute__((unused)) int offset, char *buf, unsigned int nbytes)
++{
++    unsigned int i;
++
++    for(i = 0; i < nbytes; i ++) {
++      buf[i] = obp_nbgetchar();
++    }
++    return nbytes;
++}
++
++static int con_pwrite(__attribute__((unused)) int dev_desc, __attribute__((unused)) int offset, char *buf, unsigned int nbytes)
++{
++    unsigned int i;
++
++    for(i = 0; i < nbytes; i ++) {
++      obp_nbputchar(buf[i]);
++    }
++    return nbytes;
++}
++
++#define isnum(c) ((c >= '0') && (c < '9'))
++#define ctoi(c) (c - '0')
++
 +static int obp_devopen(char *str) {
 +#ifdef DEBUG_OBP
-+        printk("open %s\n", str);
++        printk("obp_devopen(%s)\n", str);
++#endif
++      if (str[0] == 's' && str[1] == 'd' && str[4] == ',') {
++          unsigned int target;
++
++          if (str[5] < 7)
++              target = str[5];
++          else if (isnum(str[6]) && isnum(str[5])) {
++              target = (ctoi(str[5]) * 10 + ctoi(str[6])) & 7;
++          }
++          else {
++              target = ctoi(str[5]) & 7;
++          }
++          fd_table[fd_index].unit = target;
++          fd_table[fd_index].part = str[10] - 'a';
++          fd_table[fd_index].pread = esp_pread;
++          return fd_index++; // XXX
++      }
++      return 0;
++}
++
++static int obp_devclose(__attribute__((unused)) int dev_desc) {
++#ifdef DEBUG_OBP
++        printk("obp_devclose %d\n", dev_desc);
 +#endif
++      fd_index--; // XXX
 +      return 0;
 +}
 +
-+static int obp_devclose(int dev_desc) {
++static int obp_rdblkdev(int dev_desc, int num_blks, int offset, char *buf)
++{
++#ifdef DEBUG_OBP
++    printk("obp_rdblkdev: fd %d, num_blks %d, offset %d, buf 0x%x\n", dev_desc, num_blks, offset, buf);
++#endif
++    return fd_table[dev_desc].pread(dev_desc, offset, buf, num_blks * 512);
++}
++
++static char *obp_dumb_mmap(char *va, __attribute__((unused)) int which_io,
++                         unsigned int pa, unsigned int size)
++{
++      unsigned int npages;
++      unsigned int off;
++      unsigned int mva;
++
++#ifdef DEBUG_OBP
++      printk("obp_dumb_mmap: virta %x, which_io %d, paddr %x, sz %d\n", va, which_io, pa, size);
++#endif
++      off = pa & (PAGE_SIZE-1);
++      npages = (off + size + (PAGE_SIZE-1)) / PAGE_SIZE;
++      pa &= ~(PAGE_SIZE-1);
++
++      mva = (unsigned int) va;
++      while (npages-- != 0) {
++              map_page(pmem.pl1, mva, pa, 1, pmem.pbas);
++              mva += PAGE_SIZE;
++              pa += PAGE_SIZE;
++      }
++      return va;
++}
++
++static void obp_dumb_munmap(__attribute__((unused)) char *va,
++                          __attribute__((unused)) unsigned int size)
++{
++#ifdef DEBUG_OBP
++      printk("obp_dumb_munmap: virta %x, sz %d\n", va, size);
++#endif
++}
++
++static int obp_devread(int dev_desc, char *buf, int nbytes)
++{
++      int ret;
++#ifdef DEBUG_OBP
++      printk("obp_devread: fd %d, nbytes %d\n", dev_desc, nbytes);
++#endif
++      ret = fd_table[dev_desc].pread(dev_desc, fd_table[dev_desc].offset, buf, nbytes);
++      fd_table[dev_desc].offset += nbytes;
++      return ret;
++}
++
++static int obp_devwrite(int dev_desc, char *buf, int nbytes)
++{
++      int ret;
 +#ifdef DEBUG_OBP
-+        printk("close %d\n", dev_desc);
++      printk("obp_devwrite: fd %d, buf %s, nbytes %d\n", dev_desc, buf, nbytes);
 +#endif
++      ret = fd_table[dev_desc].pwrite(dev_desc, fd_table[dev_desc].offset, buf, nbytes);
++      fd_table[dev_desc].offset += nbytes;
++      return ret;
++}
++
++static int obp_devseek(int dev_desc, __attribute__((unused)) int hi, int lo)
++{
++#ifdef DEBUG_OBP
++      printk("obp_devseek: fd %d, hi %d, lo %d\n", dev_desc, hi, lo);
++#endif
++      fd_table[dev_desc].offset = lo;
 +      return 0;
 +}
 +
-+static int obp_rdblkdev(int dev_desc, int num_blks, int blk_st, char *buf) {
++static int obp_inst2pkg(int dev_desc)
++{
 +#ifdef DEBUG_OBP
-+    printk("rdblkdev: fd %d, num_blks %d, blk_st %d, buf 0x%x\n", dev_desc, num_blks, blk_st, buf);
++      printk("obp_inst2pkg: fd %d\n", dev_desc);
 +#endif
-+    //buf[8] = 'L';
-+    return num_blks;
++      return fd_table[dev_desc].unit;
 +}
-diff -ruN proll_18.orig/qemu/system_qemu.c proll-patch8/qemu/system_qemu.c
+diff -ruN proll_18.orig/qemu/system_qemu.c proll-patch-15/qemu/system_qemu.c
 --- proll_18.orig/qemu/system_qemu.c   1970-01-01 00:00:00.000000000 +0000
-+++ proll-patch8/qemu/system_qemu.c    2005-03-02 16:10:20.000000000 +0000
-@@ -0,0 +1,416 @@
++++ proll-patch-15/qemu/system_qemu.c  2005-04-16 06:16:20.000000000 +0000
+@@ -0,0 +1,430 @@
 +/**
 + ** Proll (PROM replacement)
 + ** system.c: shared miscallenea.
@@ -1859,19 +2121,30 @@ diff -ruN proll_18.orig/qemu/system_qemu.c proll-patch8/qemu/system_qemu.c
 +{
 +      char *p;
 +
-+      if ((p = mem_alloc(t, size, align)) != 0) bzero(p, size);
++      if ((p = mem_alloc(t, size, align)) != 0) memset(p, 0, size);
 +      return p;
 +}
 +
 +/*
 + * Library functions
 + */
-+void bzero(void *s, int len) {
-+      while (len--) *((char *)s)++ = 0;
++void *memset(void *s, int c, size_t len)
++{
++      void *p = s;
++
++      while (len--) {
++              *(char *)s = c;
++              s++;
++      }
++      return p;
 +}
 +
 +void bcopy(const void *f, void *t, int len) {
-+      while (len--) *((char *)t)++ = *((char *)f)++;
++      while (len--) {
++              *(char *)t = *(char *)f;
++              f++;
++              t++;
++      }
 +}
 +
 +/* Comparison is 7-bit */
@@ -1881,8 +2154,11 @@ diff -ruN proll_18.orig/qemu/system_qemu.c proll-patch8/qemu/system_qemu.c
 +      char ch;
 +
 +      while (len--) {
-+              ch = *((char *)s1)++;
-+              if ((i = ch - *((char *)s2)++) != 0)
++              ch = *(char *)s1;
++              i = ch - *(char *)s2;
++              s1++;
++              s2++;
++              if (i != 0)
 +                      return i;
 +              if (ch == 0)
 +                      return 0;
@@ -1949,9 +2225,9 @@ diff -ruN proll_18.orig/qemu/system_qemu.c proll-patch8/qemu/system_qemu.c
 +      n = (n>>24 & 0xFF) | (n>>8 & 0xFF00) | ((n&0xFF00) << 8) | (n<<24);
 +      st_bypass(ptr, n);
 +};
-diff -ruN proll_18.orig/src/arp.c proll-patch8/src/arp.c
+diff -ruN proll_18.orig/src/arp.c proll-patch-15/src/arp.c
 --- proll_18.orig/src/arp.c    2001-12-24 05:12:31.000000000 +0000
-+++ proll-patch8/src/arp.c     2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/arp.c   2005-08-14 10:10:11.000000000 +0000
 @@ -45,7 +45,7 @@
  #endif
  static struct arp_cache arp_list[ARPNUM];     /* ARP address cache    */
@@ -1961,7 +2237,19 @@ diff -ruN proll_18.orig/src/arp.c proll-patch8/src/arp.c
  
  
  
-@@ -144,7 +144,7 @@
+@@ -100,10 +100,7 @@
+  * 
+  * ARP receiver routine
+  */
+-static int arp_recv(buf, bufsize, addr)
+-unsigned char *buf;
+-int            bufsize;
+-unsigned char *addr;
++static int arp_recv(unsigned char *buf, unsigned int bufsize, unsigned char *addr)
+ {
+   register struct arphdr *ahp = (struct arphdr *)buf;
+@@ -144,7 +141,7 @@
   * 
   * Resolve IP address and return pointer to hardware address.
   */
@@ -1970,7 +2258,7 @@ diff -ruN proll_18.orig/src/arp.c proll-patch8/src/arp.c
  t_ipaddr ip;
  {
    int i;
-@@ -230,14 +230,11 @@
+@@ -230,14 +227,11 @@
   */
  int init_arp()
  {
@@ -1986,9 +2274,9 @@ diff -ruN proll_18.orig/src/arp.c proll-patch8/src/arp.c
 +  def_gw = IP_ANY;
    return(TRUE);
  }
-diff -ruN proll_18.orig/src/arp.h proll-patch8/src/arp.h
+diff -ruN proll_18.orig/src/arp.h proll-patch-15/src/arp.h
 --- proll_18.orig/src/arp.h    1999-03-18 03:39:43.000000000 +0000
-+++ proll-patch8/src/arp.h     2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/arp.h   2004-11-13 15:50:49.000000000 +0000
 @@ -104,7 +104,7 @@
  extern int init_arp __P((void));
  
@@ -1998,9 +2286,330 @@ diff -ruN proll_18.orig/src/arp.h proll-patch8/src/arp.h
  
  /* Add a new antry to the ARP cache */
  extern void addcache __P((unsigned char *ha, t_ipaddr ip));
-diff -ruN proll_18.orig/src/hconsole.c proll-patch8/src/hconsole.c
+diff -ruN proll_18.orig/src/bootp.c proll-patch-15/src/bootp.c
+--- proll_18.orig/src/bootp.c  1999-12-15 17:20:30.000000000 +0000
++++ proll-patch-15/src/bootp.c 2005-08-14 10:16:09.000000000 +0000
+@@ -151,7 +151,7 @@
+   while (TRUE) {
+       boot_xid = get_ticks() + random();
+       bootp_send();
+-      i = udp_read((char *)(&boot_rec), BOOTP_REC_SIZE, timeout, CHR_ESC);
++      i = udp_read((char *)(&boot_rec), BOOTP_REC_SIZE, timeout);
+       if (i < 0) {                            /* user pressed ESC */
+               printf("\nAborted\n");
+               return(1);
+diff -ruN proll_18.orig/src/esp.c proll-patch-15/src/esp.c
+--- proll_18.orig/src/esp.c    1970-01-01 00:00:00.000000000 +0000
++++ proll-patch-15/src/esp.c   2005-08-15 18:42:46.000000000 +0000
+@@ -0,0 +1,305 @@
++#include <system.h>           /* == <asm/system.h> */
++#include <general.h>          /* __P for netpriv.h */
++#include <dma.h>              /* dmaga */
++#include <romlib.h>
++
++#define PHYS_JJ_ESPDMA  0x78400000      /* ESP DMA controller */
++#define PHYS_JJ_ESP     0x78800000      /* ESP SCSI */
++#define PHYS_JJ_ESP_IRQ    4
++#define BUFSIZE         4096
++/*
++ * XXX Crude
++ */
++struct esp_dma {
++      struct sparc_dma_registers *regs;
++      enum dvma_rev revision;
++};
++
++struct esp_regs {
++    unsigned int regs[16];
++};
++
++struct esp_private {
++      int active;                     /* initialized */
++      int inst;                       /* iface number */
++
++      volatile struct esp_regs *ll;
++      __u32 buffer_dvma;
++      unsigned int irq;               /* device IRQ number    */
++        int interrupt;
++
++      struct esp_dma *espdma;         /* If set this points to espdma    */
++
++        unsigned char *buffer;
++      struct disk_info {
++              unsigned int hw_sector;
++              unsigned int part_offset[8];
++      } disk[8];
++};
++
++static void esp_interrupt(void *dev_id)
++{
++      struct esp_private *lp = (struct esp_private *)dev_id;
++
++      lp->interrupt = 1;
++      /* Acknowledge all the interrupt sources ASAP */
++
++      lp->interrupt = 0;
++}
++
++static int esp_open (void *dev)
++{
++      struct esp_private *lp = (struct esp_private *)dev;
++      int status = 0;
++
++      if (request_irq(lp->irq, &esp_interrupt, (void *)dev)) {
++              printk ("Esp: Can't get irq %d\n", lp->irq);
++              return -1;
++      }
++
++      /* On the 4m, setup the espdma to provide the upper bits for buffers */
++      if (lp->espdma)
++              lp->espdma->regs->dma_test = ((__u32) lp->buffer_dvma) & 0xff000000;
++
++      return status;
++}
++
++static int esp_close (void *dev)
++{
++      struct esp_private *lp = (struct esp_private *)dev;
++
++      free_irq (lp->irq, (void *) dev);
++      return 0;
++}
++
++static int 
++esp_init(struct esp_private *esp, struct esp_dma *espdma, int irq)
++{
++      volatile struct esp_regs *ll;
++
++      /* Get the IO region */
++      ll = map_io(PHYS_JJ_ESP, sizeof (struct esp_regs));
++      if (ll == 0) return -1;
++
++      esp->buffer = dvma_alloc(BUFSIZE, &esp->buffer_dvma);
++      esp->ll = ll;
++      esp->espdma = espdma;
++      esp->irq = irq;
++
++      // Chip reset
++      stb_bypass((int)ll + 3*2, 2);
++      return 0;
++}
++
++static int espdma_init(struct esp_dma *espdma)
++{
++      void *p;
++
++      /* Hardcode everything for MrCoffee. */
++      if ((p = map_io(PHYS_JJ_ESPDMA, 0x10)) == 0) {
++              printk("espdma_init: cannot map registers\n");
++              return -1;
++      }
++      espdma->regs = p;
++
++      printk("dma1: ");
++
++      switch((espdma->regs->cond_reg)&DMA_DEVICE_ID) {
++      case DMA_VERS0:
++              espdma->revision=dvmarev0;
++              printk("Revision 0 ");
++              break;
++      case DMA_ESCV1:
++              espdma->revision=dvmaesc1;
++              printk("ESC Revision 1 ");
++              break;
++      case DMA_VERS1:
++              espdma->revision=dvmarev1;
++              printk("Revision 1 ");
++              break;
++      case DMA_VERS2:
++              espdma->revision=dvmarev2;
++              printk("Revision 2 ");
++              break;
++      case DMA_VERHME:
++              espdma->revision=dvmahme;
++              printk("HME DVMA gate array ");
++              break;
++      case DMA_VERSPLUS:
++              espdma->revision=dvmarevplus;
++              printk("Revision 1 PLUS ");
++              break;
++      default:
++              printk("unknown dma version %x",
++                     (espdma->regs->cond_reg)&DMA_DEVICE_ID);
++              /* espdma->allocated = 1; */
++              break;
++      }
++      printk("\n");
++      return 0;
++}
++
++static struct esp_dma espdma0;
++static struct esp_private esp;
++/*
++ * Find all the esp cards on the system and initialize them
++ */
++void esp_probe ()
++{
++      if (espdma_init(&espdma0) != 0) {
++              return;
++      }
++
++      if (esp_init(&esp, &espdma0, PHYS_JJ_ESP_IRQ) != 0) {
++              printk("esp_probe: esp0 init failed\n");
++              return;
++      }
++      return;
++}
++
++void esp_read_capacity(int unit)
++{
++      // Set SCSI target
++      stb_bypass(PHYS_JJ_ESP + 4*4, unit & 7);
++      // Set DMA address
++      st_bypass(PHYS_JJ_ESPDMA + 4, esp.buffer_dvma);
++      // Set DMA length
++      stb_bypass(PHYS_JJ_ESP + 0*4, 10);
++      stb_bypass(PHYS_JJ_ESP + 1*4, 0);
++      // Set DMA direction
++      st_bypass(PHYS_JJ_ESPDMA + 0, 0x000);
++      // Setup command = Read Capacity
++      esp.buffer[0] = 0x80;
++      esp.buffer[1] = 0x25;
++      esp.buffer[2] = 0x00;
++      esp.buffer[3] = 0x00;
++      esp.buffer[4] = 0x00;
++      esp.buffer[5] = 0x00;
++      esp.buffer[6] = 0x00;
++      esp.buffer[7] = 0x00;
++      esp.buffer[8] = 0x00;
++      esp.buffer[9] = 0x00;
++      esp.buffer[10] = 0x00;
++      // Set ATN, issue command
++      stb_bypass(PHYS_JJ_ESP + 3*4, 0xc2);
++
++      // Set DMA length = 512 * read length
++      stb_bypass(PHYS_JJ_ESP + 0*4, 0);
++      stb_bypass(PHYS_JJ_ESP + 1*4, 8 & 0xff);
++      // Set DMA direction
++      st_bypass(PHYS_JJ_ESPDMA + 0, 0x100);
++      // Transfer
++      stb_bypass(PHYS_JJ_ESP + 3*4, 0x90);
++      esp.disk[unit].hw_sector = (esp.buffer[4] << 24) | (esp.buffer[5] << 16) | (esp.buffer[6] << 8) | esp.buffer[7];
++}
++
++// offset is multiple of 512, len in bytes
++void *esp_read(int unit, int part, int offset, short len)
++{
++      int pos, hw_sect, sect_offset, spb;
++
++      // Set SCSI target
++      stb_bypass(PHYS_JJ_ESP + 4*4, unit & 7);
++      // Set DMA address
++      st_bypass(PHYS_JJ_ESPDMA + 4, esp.buffer_dvma);
++      // Set DMA length
++      stb_bypass(PHYS_JJ_ESP + 0*4, 10);
++      stb_bypass(PHYS_JJ_ESP + 1*4, 0);
++      // Set DMA direction
++      st_bypass(PHYS_JJ_ESPDMA + 0, 0x000);
++      hw_sect = esp.disk[unit].hw_sector;
++      offset += esp.disk[unit].part_offset[part];
++      spb = hw_sect / 512;
++      sect_offset = offset / spb;
++      pos = (offset - sect_offset * spb) * 512;
++      len /= 512;
++      //printk("Read unit %d, offset %d -> offset %d, pos %d, hw_sect %d\n", unit, offset, sect_offset, pos, hw_sect);
++      // Setup command = Read(10)
++      esp.buffer[0] = 0x80;
++      esp.buffer[1] = 0x28;
++      esp.buffer[2] = 0x00;
++      esp.buffer[3] = (sect_offset >> 24) & 0xff;
++      esp.buffer[4] = (sect_offset >> 16) & 0xff;
++      esp.buffer[5] = (sect_offset >> 8) & 0xff;
++      esp.buffer[6] = sect_offset & 0xff;
++      esp.buffer[7] = 0x00;
++      esp.buffer[8] = (len >> 8) & 0xff;
++      esp.buffer[9] = len & 0xff;
++      // Set ATN, issue command
++      stb_bypass(PHYS_JJ_ESP + 3*4, 0xc2);
++
++      // Set DMA length = sector size * read length
++      stb_bypass(PHYS_JJ_ESP + 0*4, (len * hw_sect) & 0xff);
++      stb_bypass(PHYS_JJ_ESP + 1*4, ((len * hw_sect) >> 8) & 0xff);
++      // Set DMA direction
++      st_bypass(PHYS_JJ_ESPDMA + 0, 0x100);
++      // Transfer
++      stb_bypass(PHYS_JJ_ESP + 3*4, 0x90);
++      return esp.buffer + pos;
++}
++
++// Sparc boot sequence can be found in SILO docs,
++// first-isofs/README.SILO_ISOFS
++int esp_boot(int unit)
++{
++        struct sun_disklabel {
++                unsigned char info[128];   /* Informative text string */
++                unsigned char spare0[14];
++                struct sun_info {
++                        unsigned char spare1;
++                        unsigned char id;
++                        unsigned char spare2;
++                        unsigned char flags;
++                } infos[8];
++                unsigned char spare[246];  /* Boot information etc. */
++                short rspeed;     /* Disk rotational speed */
++                short pcylcount;  /* Physical cylinder count */
++                short sparecyl;   /* extra sects per cylinder */
++                unsigned char spare2[4];   /* More magic... */
++                short ilfact;     /* Interleave factor */
++                short ncyl;       /* Data cylinder count */
++                short nacyl;      /* Alt. cylinder count */
++                short ntrks;      /* Tracks per cylinder */
++                short nsect;      /* Sectors per track */
++                unsigned char spare3[4];   /* Even more magic... */
++                struct sun_partition {
++                        int start_cylinder;
++                        int num_sectors;
++                } partitions[8];
++                short magic;      /* Magic number */
++                short csum;       /* Label xor'd checksum */
++        } *label;
++      unsigned int i, offset;
++      void *src, *dst;
++
++      printk("Loading partition table from target %d:\n", unit);
++      // Chip reset
++      stb_bypass(PHYS_JJ_ESP + 3*4, 2);
++
++      esp_open(&esp);
++      esp_read_capacity(unit);
++
++      label = esp_read(unit, 0, 0, 512);
++      printk("hw sector: %d, CHS: %d/%d/%d, partitions:\n", esp.disk[unit].hw_sector, 
++             label->ncyl, label->ntrks, label->nsect);
++      for (i = 0; i < 8; i++) {
++          printk("%c: %d + %d, id %x, flags %x\n", 'a' + i, label->partitions[i].start_cylinder,
++                 label->partitions[i].num_sectors, label->infos[i].id, label->infos[i].flags);
++          esp.disk[unit].part_offset[i] = label->partitions[3].start_cylinder * label->ntrks * label->nsect;
++      }
++      offset = 1;
++      printk("booting sd(0,%d,0):d (offset %d)\n", unit, offset);
++      // Skip a.out header (0x20)
++      dst = (void *)0x4000;
++      src = esp_read(unit, 3, offset, 512);
++      src = (void *)((unsigned int) src + 0x20);
++      memcpy(dst, src, 512 - 0x20);
++      dst = (void *)0x4000 + 512 - 0x20;
++      for (i = 1; i < 7680/512; i++) {
++          src = esp_read(unit, 3,  offset + i, 512);
++          memcpy(dst, src, 512);
++          dst += 512;
++      }
++      esp_close(&esp);
++      return 0;
++}
+diff -ruN proll_18.orig/src/hconsole.c proll-patch-15/src/hconsole.c
 --- proll_18.orig/src/hconsole.c       2002-07-23 05:52:48.000000000 +0000
-+++ proll-patch8/src/hconsole.c        2005-03-02 17:03:09.000000000 +0000
++++ proll-patch-15/src/hconsole.c      2005-11-09 18:46:34.000000000 +0000
 @@ -29,6 +29,10 @@
         struct raster r_master;        /* For a case of resize, whole fb */
         struct raster r_0;     /* malloc() erzatz */
@@ -2024,9 +2633,156 @@ diff -ruN proll_18.orig/src/hconsole.c proll-patch8/src/hconsole.c
        t->r_ = r;
        t->r0_ = q;
        t->f_ = &f_master;
-diff -ruN proll_18.orig/src/lat7_2.bm proll-patch8/src/lat7_2.bm
+@@ -67,7 +75,7 @@
+       return 0;
+ }
+-void hcon_fini (struct hconsole *t)
++void hcon_fini (__attribute((unused)) struct hconsole *t)
+ {
+       return;
+ }
+@@ -77,12 +85,12 @@
+ {
+       struct rfont *f = t->f_;
+-      if (sy < 0 || sy >= t->ydim_) return -1;
+-      if (sx < 0 || sx >= t->xdim_) return -1;
++      if (sy < 0 || (unsigned)sy >= t->ydim_) return -1;
++      if (sx < 0 || (unsigned)sx >= t->xdim_) return -1;
+       if (height < 0) return -1;
+-      if (sy + height > t->ydim_) height = t->ydim_ - sy;
++      if ((unsigned)sy + (unsigned)height > t->ydim_) height = t->ydim_ - sy;
+       if (width < 0) return -1;
+-      if (sx + width > t->xdim_) width = t->xdim_ - sx;
++      if ((unsigned)sx + (unsigned)width > t->xdim_) width = t->xdim_ - sx;
+       /* XXX Clear with correct background color */
+       (*t->r_->clear_)(t->r_,
+@@ -107,10 +115,10 @@
+       char c0 = c;
+       RC_color rfg, rbg;
+-      if (y < 0 || y >= t->ydim_) return -1;
+-      if (x < 0 || x >= t->xdim_) return -1;
++      if (y < 0 || (unsigned)y >= t->ydim_) return -1;
++      if (x < 0 || (unsigned)x >= t->xdim_) return -1;
+-      if (t->curson_ && t->ypos_ == y && t->xpos_ == x) {
++      if (t->curson_ && t->ypos_ == (unsigned)y && t->xpos_ == (unsigned)x) {
+               rfg = t->bg_;    rbg = t->fg_;
+       } else {
+               rfg = t->fg_;    rbg = t->bg_;
+@@ -126,9 +134,9 @@
+ {     
+       struct rfont *f = t->f_;
+-      if (y < 0 || y >= t->ydim_) return -1;
+-      if (x < 0 || x >= t->xdim_) return -1;
+-      if (x + count >= t->xdim_) count = t->xdim_ - x;
++      if (y < 0 || (unsigned)y >= t->ydim_) return -1;
++      if (x < 0 || (unsigned)x >= t->xdim_) return -1;
++      if ((unsigned)x + (unsigned)count >= t->xdim_) count = t->xdim_ - x;
+       (*t->r_->render_)(t->r_, y*f->height_, x*f->width_,
+                           s, count, t->bg_, t->fg_, f);
+@@ -200,8 +208,8 @@
+       rc = 0;
+       if (dir == SM_UP) {
+-              if (d < 0 || d >= t->ydim_) return -1;
+-              if (b <= d || b > t->ydim_) return -1;
++              if (d < 0 || (unsigned)d >= t->ydim_) return -1;
++              if (b <= d || (unsigned)b > t->ydim_) return -1;
+               if (d + count >= b) count = b - d;
+               if (d + count >= b) count = b - d;
+               (*t->r_->yscroll_)(t->r_,
+@@ -213,8 +221,8 @@
+                                  count*f->height_, raster_qwidth(t->r_),
+                                  t->bg_);
+       } else if (dir == SM_DOWN) {
+-              if (d < 0 || d >= t->ydim_) return -1;
+-              if (b <= d || b > t->ydim_) return -1;
++              if (d < 0 || (unsigned)d >= t->ydim_) return -1;
++              if (b <= d || (unsigned)b > t->ydim_) return -1;
+               if (d + count >= b) count = b - d;
+               (*t->r_->yscroll_)(t->r_,
+                                    d*f->height_, 0,
+diff -ruN proll_18.orig/src/hme.c proll-patch-15/src/hme.c
+--- proll_18.orig/src/hme.c    2002-07-23 05:52:52.000000000 +0000
++++ proll-patch-15/src/hme.c   2005-04-16 06:16:20.000000000 +0000
+@@ -655,10 +655,10 @@
+                                   unsigned int flags,
+                                   unsigned int addr)
+ {
+-      __asm__ __volatile__("
+-      stwa    %3, [%0] %2
+-      stwa    %4, [%1] %2
+-"     : /* no outputs */
++      __asm__ __volatile__(
++      "stwa   %3, [%0] %2\n\t"
++      "stwa   %4, [%1] %2\n\t"
++      : /* no outputs */
+       : "r" (&rp->rx_addr), "r" (&rp->rx_flags),
+         "i" (ASI_PL), "r" (addr), "r" (flags));
+ }
+@@ -667,10 +667,10 @@
+                                   unsigned int flags,
+                                   unsigned int addr)
+ {
+-      __asm__ __volatile__("
+-      stwa    %3, [%0] %2
+-      stwa    %4, [%1] %2
+-"     : /* no outputs */
++      __asm__ __volatile__(
++      "stwa   %3, [%0] %2\n\t"
++      "stwa   %4, [%1] %2\n\t"
++      : /* no outputs */
+       : "r" (&tp->tx_addr), "r" (&tp->tx_flags),
+         "i" (ASI_PL), "r" (addr), "r" (flags));
+ }
+@@ -2404,7 +2404,7 @@
+               TXD(("[%d]", elem));
+               this = &txbase[elem];
+ #ifdef  __sparc_v9__
+-              __asm__ __volatile__("lduwa [%1] %2, %0"
++              __asm__ __volatile__("lduwa [%1] %2, %0\n\t"
+                                    : "=r" (flags)
+                                    : "r" (&this->tx_flags), "i" (ASI_PL));
+ #else
+@@ -2447,7 +2447,7 @@
+       RXD(("RX<"));
+       this = &rxbase[elem];
+ #ifdef  __sparc_v9__
+-      __asm__ __volatile__("lduwa [%1] %2, %0"
++      __asm__ __volatile__("lduwa [%1] %2, %0\n\t"
+                            : "=r" (flags)
+                            : "r" (&this->rx_flags), "i" (ASI_PL));
+ #else
+@@ -2530,7 +2530,7 @@
+               elem = NEXT_RX(elem);
+               this = &rxbase[elem];
+ #ifdef __sparc_v9__ 
+-              __asm__ __volatile__("lduwa [%1] %2, %0"
++              __asm__ __volatile__("lduwa [%1] %2, %0\n\t"
+                                    : "=r" (flags)
+                                    : "r" (&this->rx_flags), "i" (ASI_PL));
+ #else
+diff -ruN proll_18.orig/src/iommu.c proll-patch-15/src/iommu.c
+--- proll_18.orig/src/iommu.c  2002-07-23 05:52:49.000000000 +0000
++++ proll-patch-15/src/iommu.c 2005-08-14 10:08:17.000000000 +0000
+@@ -36,7 +36,7 @@
+       unsigned int pa, ba;
+       unsigned int npages;
+       unsigned int mva, mpa;
+-      int i;
++      unsigned int i;
+       unsigned int *iopte;
+       npages = (size + (PAGE_SIZE-1)) / PAGE_SIZE;
+diff -ruN proll_18.orig/src/lat7_2.bm proll-patch-15/src/lat7_2.bm
 --- proll_18.orig/src/lat7_2.bm        1999-02-27 05:48:54.000000000 +0000
-+++ proll-patch8/src/lat7_2.bm 2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/lat7_2.bm       2004-11-13 15:50:49.000000000 +0000
 @@ -1,6 +1,6 @@
  #define lat7_2_width 128
  #define lat7_2_height 88
@@ -2035,9 +2791,9 @@ diff -ruN proll_18.orig/src/lat7_2.bm proll-patch8/src/lat7_2.bm
     0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
     0x00, 0x00, 0x00, 0x00, 0x00, 0xaa, 0x12, 0x1e, 0x0c, 0x02, 0x70, 0x18,
     0x22, 0x22, 0x18, 0x00, 0x00, 0x18, 0x18, 0xff, 0x18, 0x00, 0x12, 0x02,
-diff -ruN proll_18.orig/src/lat7_2_swapped.bm proll-patch8/src/lat7_2_swapped.bm
+diff -ruN proll_18.orig/src/lat7_2_swapped.bm proll-patch-15/src/lat7_2_swapped.bm
 --- proll_18.orig/src/lat7_2_swapped.bm        1970-01-01 00:00:00.000000000 +0000
-+++ proll-patch8/src/lat7_2_swapped.bm 2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/lat7_2_swapped.bm       2004-11-13 15:50:49.000000000 +0000
 @@ -0,0 +1,121 @@
 +#define lat7_2_width 128
 +#define lat7_2_height 88
@@ -2160,9 +2916,9 @@ diff -ruN proll_18.orig/src/lat7_2_swapped.bm proll-patch8/src/lat7_2_swapped.bm
 +   0x18, 0x18, 0x30, 0x00, 0x00, 0x00, 0x00, 0x36, 0x6c, 0x00, 0x00, 0x00, 
 +   0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x7e, 0x42, 0x00, 0x00, 0x00, 0x00, 
 +   0x00, 0x00, 0x00, 0x00};
-diff -ruN proll_18.orig/src/le.c proll-patch8/src/le.c
+diff -ruN proll_18.orig/src/le.c proll-patch-15/src/le.c
 --- proll_18.orig/src/le.c     2002-07-23 05:52:49.000000000 +0000
-+++ proll-patch8/src/le.c      2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/le.c    2005-04-16 06:16:20.000000000 +0000
 @@ -185,8 +185,6 @@
        unsigned short rap;                     /* register address port */
  };
@@ -2172,9 +2928,30 @@ diff -ruN proll_18.orig/src/le.c proll-patch8/src/le.c
  /* The Lance uses 24 bit addresses */
  /* On the Sun4c the DVMA will provide the remaining bytes for us */
  /* On the Sun4m we have to instruct the ledma to provide them    */
-diff -ruN proll_18.orig/src/netinit.c proll-patch8/src/netinit.c
+@@ -771,7 +769,7 @@
+       /* Clear the slack of the packet, do I need this? */
+       /* For a firewall its a good idea - AC */
+       if (len != skblen)
+-              bzero((char *) &ib->tx_buf [entry][skblen], len - skblen);
++              memset((char *) &ib->tx_buf [entry][skblen], 0, len - skblen);
+     
+       /* Now, give the packet to the lance */
+       ib->btx_ring [entry].tmd1_bits = (LE_T1_POK|LE_T1_OWN);
+diff -ruN proll_18.orig/src/net.h proll-patch-15/src/net.h
+--- proll_18.orig/src/net.h    1999-12-15 17:20:17.000000000 +0000
++++ proll-patch-15/src/net.h   2005-08-14 10:17:02.000000000 +0000
+@@ -124,7 +124,7 @@
+ extern int udp_open __P((t_ipaddr daddr, int source, int dest));
+ /* Read from a UDP socket */
+-extern int udp_read __P((char *buf, int bufsize, int timeout, char abortch));
++extern int udp_read(char *buf, unsigned int bufsize, int timeout);
+ /* Write to a UDP socket */
+ extern int udp_write __P((char *buf, int writelen));
+diff -ruN proll_18.orig/src/netinit.c proll-patch-15/src/netinit.c
 --- proll_18.orig/src/netinit.c        2002-09-13 21:53:33.000000000 +0000
-+++ proll-patch8/src/netinit.c 2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/netinit.c       2004-11-13 15:50:49.000000000 +0000
 @@ -49,13 +49,20 @@
  unsigned char     myhwaddr[ETH_ALEN];         /* my own hardware addr */
           t_ipaddr myipaddr;                   /* my own IP address    */
@@ -2218,9 +2995,18 @@ diff -ruN proll_18.orig/src/netinit.c proll-patch8/src/netinit.c
        fatal();
    }
  }
-diff -ruN proll_18.orig/src/netpriv.h proll-patch8/src/netpriv.h
+diff -ruN proll_18.orig/src/netpriv.h proll-patch-15/src/netpriv.h
 --- proll_18.orig/src/netpriv.h        1999-04-27 05:39:37.000000000 +0000
-+++ proll-patch8/src/netpriv.h 2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/netpriv.h       2005-08-14 10:12:20.000000000 +0000
+@@ -83,7 +83,7 @@
+        */
+       struct device *dev;
+       char *data;
+-      int len;
++      unsigned int len;
+       int protocol;
+       unsigned char ip_summed;
+ };
 @@ -130,10 +130,9 @@
   *
   */
@@ -2242,10 +3028,10 @@ diff -ruN proll_18.orig/src/netpriv.h proll-patch8/src/netpriv.h
  
  /* Empty read buffer */
  extern void empty_buf __P((void));
-diff -ruN proll_18.orig/src/openprom.h proll-patch8/src/openprom.h
+diff -ruN proll_18.orig/src/openprom.h proll-patch-15/src/openprom.h
 --- proll_18.orig/src/openprom.h       2002-07-14 02:26:30.000000000 +0000
-+++ proll-patch8/src/openprom.h        2004-11-13 15:50:49.000000000 +0000
-@@ -54,20 +54,20 @@
++++ proll-patch-15/src/openprom.h      2005-05-13 16:23:14.000000000 +0000
+@@ -54,29 +54,29 @@
  };
  
  struct linux_mem_v0 {
@@ -2271,6 +3057,19 @@ diff -ruN proll_18.orig/src/openprom.h proll-patch8/src/openprom.h
        void *aieee1;           /* XXX */
  };
  
+ /* V2 and up boot things. */
+ struct linux_bootargs_v2 {
+-      char **bootpath;
+-      char **bootargs;
+-      int *fd_stdin;
+-      int *fd_stdout;
++      const char **bootpath;
++      const char **bootargs;
++      const int *fd_stdin;
++      const int *fd_stdout;
+ };
+ /* The top level PROM vector. */
 @@ -91,13 +91,13 @@
        struct linux_mem_v0 pv_v0mem;
  
@@ -2306,9 +3105,9 @@ diff -ruN proll_18.orig/src/openprom.h proll-patch8/src/openprom.h
  };
  
  /* More fun PROM structures for device probing. */
-diff -ruN proll_18.orig/src/packet.c proll-patch8/src/packet.c
+diff -ruN proll_18.orig/src/packet.c proll-patch-15/src/packet.c
 --- proll_18.orig/src/packet.c 2000-02-11 04:56:45.000000000 +0000
-+++ proll-patch8/src/packet.c  2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/packet.c        2005-08-14 10:12:49.000000000 +0000
 @@ -41,7 +41,7 @@
        int aligner;
  } wbuf;
@@ -2336,9 +3135,24 @@ diff -ruN proll_18.orig/src/packet.c proll-patch8/src/packet.c
  {
        struct sk_buff *skb;
        unsigned char *s;
-diff -ruN proll_18.orig/src/printf.c proll-patch8/src/printf.c
+@@ -209,12 +211,12 @@
+ /*
+  */
+ void
+-eth_copy_and_sum(struct sk_buff *dest, unsigned char *src, int len, int base)
++eth_copy_and_sum(struct sk_buff *dest, unsigned char *src, int len, __attribute__((unused)) int base)
+ {
+       bcopy(src, dest->data, len);
+ }
+-unsigned short eth_type_trans(struct sk_buff *skb, struct device *dev)
++unsigned short eth_type_trans(struct sk_buff *skb, __attribute__((unused)) struct device *dev)
+ {
+       unsigned char *s = skb->data + 12;
+       return s[0] << 8 | s[1];                /* Network order word */
+diff -ruN proll_18.orig/src/printf.c proll-patch-15/src/printf.c
 --- proll_18.orig/src/printf.c 1999-03-19 07:03:59.000000000 +0000
-+++ proll-patch8/src/printf.c  2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/printf.c        2005-08-14 10:07:26.000000000 +0000
 @@ -19,7 +19,7 @@
  static void printn(struct prf_fp *, unsigned long, unsigned int);
  static void putchar(char, struct prf_fp *);
@@ -2366,9 +3180,20 @@ diff -ruN proll_18.orig/src/printf.c proll-patch8/src/printf.c
                                putchar(c,filog);
                        } else if (c == 'l' || c == 'O') {
                        printn(filog, (long)va_arg(adx,long), c=='l'?10:8);
-diff -ruN proll_18.orig/src/rconsole.c proll-patch8/src/rconsole.c
+@@ -77,10 +77,6 @@
+         char prbuf[24];
+         register char *cp;
+-        if (b == 10 && n < 0) {
+-                putchar('-',filog);
+-                n = (~n) + 1;         /* n = -n */
+-        }
+         cp = prbuf;
+         do
+               *cp++ = hextab[(unsigned int)(n%b)];
+diff -ruN proll_18.orig/src/rconsole.c proll-patch-15/src/rconsole.c
 --- proll_18.orig/src/rconsole.c       1999-01-16 07:16:55.000000000 +0000
-+++ proll-patch8/src/rconsole.c        2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/rconsole.c      2005-08-14 10:25:53.000000000 +0000
 @@ -28,12 +28,18 @@
   * move to California. Only plain lat7 survived. 
   * I recreated lat7-1 changes in lat7-2.  --zaitcev
@@ -2388,6 +3213,37 @@ diff -ruN proll_18.orig/src/rconsole.c proll-patch8/src/rconsole.c
  
  #if 1
  /*
+@@ -46,18 +52,18 @@
+ #endif
+ static __inline__ void stfb_w(void *ptr, unsigned int data) {
+-      __asm__ __volatile__ ("sta %0, [%1] %2" : :
++      __asm__ __volatile__ ("sta %0, [%1] %2\n\t" : :
+                               "r" (data), "r" (ptr), "i" (ASI_M_BYPASS));
+ }
+ static __inline__ void stfb_b(void *ptr, unsigned int data) {
+-      __asm__ __volatile__ ("stba %0, [%1] %2" : :
++      __asm__ __volatile__ ("stba %0, [%1] %2\n\t" : :
+                               "r" (data), "r" (ptr), "i" (ASI_M_BYPASS));
+ }
+ static __inline__ unsigned int ldfb_w(void *ptr) {
+       unsigned int data;
+-      __asm__ __volatile__ ("lda [%1] %2, %0" :
++      __asm__ __volatile__ ("lda [%1] %2, %0\n\t" :
+                               "=r" (data) :
+                               "r" (ptr), "i" (ASI_M_BYPASS));
+       return data;
+@@ -65,7 +71,7 @@
+ static __inline__ unsigned int ldfb_b(void *ptr) {
+       unsigned int data;
+-      __asm__ __volatile__ ("lduba [%1] %2, %0" :
++      __asm__ __volatile__ ("lduba [%1] %2, %0\n\t" :
+                               "=r" (data) :
+                               "r" (ptr), "i" (ASI_M_BYPASS));
+       return data;
 @@ -94,6 +100,7 @@
  
  #endif
@@ -2423,9 +3279,18 @@ diff -ruN proll_18.orig/src/rconsole.c proll-patch8/src/rconsole.c
    p->nchars_ = LAT7_NCHARS;
    p->width_ = LAT7_WIDTH;
    p->height_ = LAT7_HEIGHT;
-diff -ruN proll_18.orig/src/rconsole.h proll-patch8/src/rconsole.h
+@@ -175,7 +188,7 @@
+   r->render_ = p->render_;
+ }
+-void raster_dest(struct raster *r)
++void raster_dest(__attribute((unused)) struct raster *r)
+ {
+ }
+diff -ruN proll_18.orig/src/rconsole.h proll-patch-15/src/rconsole.h
 --- proll_18.orig/src/rconsole.h       1999-01-16 05:00:59.000000000 +0000
-+++ proll-patch8/src/rconsole.h        2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/rconsole.h      2004-11-13 15:50:49.000000000 +0000
 @@ -13,10 +13,10 @@
   */
  
@@ -2439,18 +3304,21 @@ diff -ruN proll_18.orig/src/rconsole.h proll-patch8/src/rconsole.h
    int nchars_;                 /* 128 for ASCII ...  65536 for Unicode   */
    int width_;                  /* [Pixels]. Maximum size is 16.          */
    int height_;                 /* [Pixels == scan lines].                */
-diff -ruN proll_18.orig/src/romlib.h proll-patch8/src/romlib.h
+diff -ruN proll_18.orig/src/romlib.h proll-patch-15/src/romlib.h
 --- proll_18.orig/src/romlib.h 1999-04-20 04:26:45.000000000 +0000
-+++ proll-patch8/src/romlib.h  2004-11-13 15:50:49.000000000 +0000
-@@ -73,12 +73,12 @@
++++ proll-patch-15/src/romlib.h        2005-04-16 20:32:49.000000000 +0000
+@@ -72,13 +72,13 @@
+  */
  #define memcpy(dst, src, len) bcopy(src, dst, len)
  #define memcmp(x1, x2, len)   bcmp(x1, x2, len)
- #define memset(p, len, zero)  bzero(p, len)
+-#define memset(p, len, zero)  bzero(p, len)
 -extern void bcopy(void *b1, void *b2, int length);
 -extern int  bcmp(void *b1, void *b2, int length);
+-extern void bzero(void *b, int c);
 +extern void bcopy(const void *b1, void *b2, int length);
 +extern int  bcmp(const void *b1, const void *b2, int length);
- extern void bzero(void *b, int c);
++typedef unsigned int size_t;
++extern void *memset(void *p, int c, size_t len);
  /* gcc complains about "conflicting types for builtin function strlen". */
  #define strlen(s)             ssize(s)
 -extern int ssize(char *s);
@@ -2458,9 +3326,9 @@ diff -ruN proll_18.orig/src/romlib.h proll-patch8/src/romlib.h
  
  
  /*
-diff -ruN proll_18.orig/src/sched_4m.c proll-patch8/src/sched_4m.c
+diff -ruN proll_18.orig/src/sched_4m.c proll-patch-15/src/sched_4m.c
 --- proll_18.orig/src/sched_4m.c       1999-04-27 05:48:51.000000000 +0000
-+++ proll-patch8/src/sched_4m.c        2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/sched_4m.c      2005-08-14 10:18:14.000000000 +0000
 @@ -108,7 +108,7 @@
  static int set_bolt;                  /* Tick counter limit */
  static struct handsc hndv[16];
@@ -2470,9 +3338,36 @@ diff -ruN proll_18.orig/src/sched_4m.c proll-patch8/src/sched_4m.c
        0,      0,      0,      0,      0,      0, SUN4M_INT_ETHERNET,  0,
        0,      0,      0,      0,      0,      0,      0,      0,
  };
-diff -ruN proll_18.orig/src/swap.c proll-patch8/src/swap.c
+@@ -130,7 +130,7 @@
+ int   /* 0 - not expired yet; <>0 - timer expired */
+ chk_timeout()
+ {
+-      int lim = (((1000000/HZ) + 1) << 10);
++      unsigned int lim = (((1000000/HZ) + 1) << 10);
+       unsigned int clear;
+       unsigned int intc;
+       int n;
+@@ -182,7 +182,7 @@
+       struct handsc *hndp;
+       unsigned int mask;
+-      if (irq < 0 || irq >= 16) {
++      if (irq == 0 || irq >= 16) {
+               printk("request_irq: bad irq %d\n", irq);
+               return -1;
+       }
+@@ -207,7 +207,7 @@
+ {
+       struct handsc *hndp;
+-      if (irq < 0 || irq >= 16) {
++      if (irq == 0 || irq >= 16) {
+               printk("free_irq: bad irq %d\n", irq);
+               return;
+       }
+diff -ruN proll_18.orig/src/swap.c proll-patch-15/src/swap.c
 --- proll_18.orig/src/swap.c   1970-01-01 00:00:00.000000000 +0000
-+++ proll-patch8/src/swap.c    2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/swap.c  2004-11-13 15:50:49.000000000 +0000
 @@ -0,0 +1,21 @@
 +// Convert the lat7 font so that no conversion is needed at runtime.
 +#define ORIG
@@ -2495,9 +3390,9 @@ diff -ruN proll_18.orig/src/swap.c proll-patch8/src/swap.c
 +    }
 +    printf("\n");
 +}
-diff -ruN proll_18.orig/src/system.c proll-patch8/src/system.c
+diff -ruN proll_18.orig/src/system.c proll-patch-15/src/system.c
 --- proll_18.orig/src/system.c 2002-07-23 05:52:49.000000000 +0000
-+++ proll-patch8/src/system.c  2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/system.c        2005-04-16 06:16:20.000000000 +0000
 @@ -298,8 +298,8 @@
        }
  
@@ -2509,13 +3404,39 @@ diff -ruN proll_18.orig/src/system.c proll-patch8/src/system.c
                map_page(l1, va, pa, 0, highbase);
                pa += PAGE_SIZE;
        }
-@@ -518,12 +518,12 @@
-       while (len--) *((char *)s)++ = 0;
+@@ -507,30 +507,44 @@
+ {
+       char *p;
+-      if ((p = mem_alloc(t, size, align)) != 0) bzero(p, size);
++      if ((p = mem_alloc(t, size, align)) != 0) memset(p, 0, size);
+       return p;
+ }
+ /*
+  * Library functions
+  */
+-void bzero(void *s, int len) {
+-      while (len--) *((char *)s)++ = 0;
++void *memset(void *s, int c, size_t len)
++{
++      void *p = s;
++
++      while (len--) {
++              *(char *)s = c;
++              s++;
++      }
++      return p;
  }
  
 -void bcopy(void *f, void *t, int len) {
+-      while (len--) *((char *)t)++ = *((char *)f)++;
 +void bcopy(const void *f, void *t, int len) {
-       while (len--) *((char *)t)++ = *((char *)f)++;
++      while (len--) {
++              *(char *)t = *(char *)f;
++              f++;
++              t++;
++      }
  }
  
  /* Comparison is 7-bit */
@@ -2524,7 +3445,19 @@ diff -ruN proll_18.orig/src/system.c proll-patch8/src/system.c
  {
        int i;
        char ch;
-@@ -538,8 +538,8 @@
+       while (len--) {
+-              ch = *((char *)s1)++;
+-              if ((i = ch - *((char *)s2)++) != 0)
++              ch = *(char *)s1;
++              i = ch - *(char *)s2;
++              s1++;
++              s2++;
++              if (i != 0)
+                       return i;
+               if (ch == 0)
+                       return 0;
+@@ -538,8 +552,8 @@
        return 0;
  }
  
@@ -2535,7 +3468,7 @@ diff -ruN proll_18.orig/src/system.c proll-patch8/src/system.c
        for (p = s; *p != 0; p++) { }
        return p - s;
  }
-@@ -560,14 +560,6 @@
+@@ -560,14 +574,6 @@
        va_end(x1);
  }
  
@@ -2550,9 +3483,9 @@ diff -ruN proll_18.orig/src/system.c proll-patch8/src/system.c
  void fatal()
  {
        printk("fatal.");
-diff -ruN proll_18.orig/src/system.h proll-patch8/src/system.h
+diff -ruN proll_18.orig/src/system.h proll-patch-15/src/system.h
 --- proll_18.orig/src/system.h 2002-09-13 21:53:32.000000000 +0000
-+++ proll-patch8/src/system.h  2004-11-13 15:50:49.000000000 +0000
++++ proll-patch-15/src/system.h        2005-04-16 06:16:20.000000000 +0000
 @@ -16,7 +16,7 @@
  #define IOMAPSIZE (1*1024*1024) /* 1 Meg maximum: we do not map framebuffer. */
  #define NCTX_SWIFT  0x100
@@ -2562,19 +3495,181 @@ diff -ruN proll_18.orig/src/system.h proll-patch8/src/system.h
  
  #ifndef __ASSEMBLY__
  struct bank {
-diff -ruN proll_18.orig/src/udp.c proll-patch8/src/udp.c
+@@ -164,10 +164,10 @@
+ extern __inline__ void setipl(unsigned long __orig_psr)
+ {
+-      __asm__ __volatile__("
+-              wr      %0, 0x0, %%psr
+-              nop; nop; nop
+-"             : /* no outputs */
++      __asm__ __volatile__(
++              "wr     %0, 0x0, %%psr\n\t"
++              "nop; nop; nop\n\t"
++              : /* no outputs */
+               : "r" (__orig_psr)
+               : "memory", "cc");
+ }
+@@ -176,13 +176,13 @@
+ {
+       unsigned long tmp;
+-      __asm__ __volatile__("
+-              rd      %%psr, %0
+-              nop; nop; nop;          /* Sun4m + Cypress + SMP bug */
+-              or      %0, %1, %0
+-              wr      %0, 0x0, %%psr
+-              nop; nop; nop
+-"             : "=r" (tmp)
++      __asm__ __volatile__(
++              "rd     %%psr, %0\n\t"
++              "nop; nop; nop;\n\t"    /* Sun4m + Cypress + SMP bug */
++              "or     %0, %1, %0\n\t"
++              "wr     %0, 0x0, %%psr\n\t"
++              "nop; nop; nop\n\t"
++              : "=r" (tmp)
+               : "i" (PSR_PIL)
+               : "memory");
+ }
+@@ -191,13 +191,13 @@
+ {
+       unsigned long tmp;
+-      __asm__ __volatile__("
+-              rd      %%psr, %0       
+-              nop; nop; nop;          /* Sun4m + Cypress + SMP bug */
+-              andn    %0, %1, %0
+-              wr      %0, 0x0, %%psr
+-              nop; nop; nop
+-"             : "=r" (tmp)
++      __asm__ __volatile__(
++              "rd     %%psr, %0\n\t"
++              "nop; nop; nop;\n\t"    /* Sun4m + Cypress + SMP bug */
++              "andn   %0, %1, %0\n\t"
++              "wr     %0, 0x0, %%psr\n\t"
++              "nop; nop; nop\n\t"
++              : "=r" (tmp)
+               : "i" (PSR_PIL)
+               : "memory");
+ }
+@@ -214,18 +214,18 @@
+ {
+       unsigned long retval;
+-      __asm__ __volatile__("
+-              rd      %%psr, %0
+-              nop; nop; nop;          /* Sun4m + Cypress + SMP bug */
+-              and     %0, %2, %%g1
+-              and     %1, %2, %%g2
+-              xorcc   %%g1, %%g2, %%g0
+-              be      1f
+-               nop
+-              wr      %0, %2, %%psr
+-              nop; nop; nop;
+-1:
+-"             : "=r" (retval)
++      __asm__ __volatile__(
++              "rd     %%psr, %0\n\t"
++              "nop; nop; nop;\n\t"    /* Sun4m + Cypress + SMP bug */
++              "and    %0, %2, %%g1\n\t"
++              "and    %1, %2, %%g2\n\t"
++              "xorcc  %%g1, %%g2, %%g0\n\t"
++              "be     1f\n\t"
++              "nop\n\t"
++              "wr     %0, %2, %%psr\n\t"
++              "nop; nop; nop;\n\t"
++              "1:\n\t"
++              : "=r" (retval)
+               : "r" (__new_psr), "i" (PSR_PIL)
+               : "g1", "g2", "memory", "cc");
+@@ -236,13 +236,13 @@
+ {
+       unsigned long retval;
+-      __asm__ __volatile__("
+-              rd      %%psr, %0
+-              nop; nop; nop;          /* Sun4m + Cypress + SMP bug */
+-              or      %0, %1, %%g1
+-              wr      %%g1, 0x0, %%psr
+-              nop; nop; nop
+-"             : "=r" (retval)
++      __asm__ __volatile__(
++              "rd     %%psr, %0\n\t"
++              "nop; nop; nop;\n\t"    /* Sun4m + Cypress + SMP bug */
++              "or     %0, %1, %%g1\n\t"
++              "wr     %%g1, 0x0, %%psr\n\t"
++              "nop; nop; nop\n\t"
++              : "=r" (retval)
+               : "i" (PSR_PIL)
+               : "g1", "memory");
+diff -ruN proll_18.orig/src/tftp.c proll-patch-15/src/tftp.c
+--- proll_18.orig/src/tftp.c   2002-09-13 21:53:34.000000000 +0000
++++ proll-patch-15/src/tftp.c  2005-08-14 10:16:15.000000000 +0000
+@@ -127,7 +127,7 @@
+   int len;
+   /* Read packet with timeout */
+-  len = udp_read((char *)(&inpbuf), sizeof(inpbuf), TFTP_TIMEOUT, CHR_ESC);
++  len = udp_read((char *)(&inpbuf), sizeof(inpbuf), TFTP_TIMEOUT);
+   if (len == 0) {
+       printf("TFTP: Timeout\n");
+       return(ERR_TIMEOUT);
+diff -ruN proll_18.orig/src/udp.c proll-patch-15/src/udp.c
 --- proll_18.orig/src/udp.c    2001-12-24 05:12:53.000000000 +0000
-+++ proll-patch8/src/udp.c     2004-11-13 15:50:49.000000000 +0000
-@@ -81,7 +81,7 @@
- int      source;
- int      dest;
++++ proll-patch-15/src/udp.c   2005-08-14 10:17:19.000000000 +0000
+@@ -76,12 +76,9 @@
+  * 
+  * Open a new UDP socket.
+  */
+-int udp_open(daddr, source, dest)
+-t_ipaddr daddr;
+-int      source;
+-int      dest;
++int udp_open(t_ipaddr daddr, int source, int dest)
  {
 -  register unsigned char *addr;
-+  const register unsigned char *addr;
++  const unsigned char *addr;
  
    /* Set global variables */
    usource = source;
-@@ -299,9 +299,6 @@
+@@ -101,16 +98,13 @@
+  * 
+  * IP receiver routine
+  */
+-static int ip_recv(buf, bufsize, addr)
+-unsigned char *buf;
+-int            bufsize;
+-unsigned char *addr;
++static int ip_recv(unsigned char *buf, unsigned int bufsize, unsigned char *addr)
+ {
+   struct iphdr *ipp = ((struct iphdr *)buf);
+   struct udphdr *udpp = ((struct udphdr *)(buf + IP_MIN_HSIZE));
+   struct udp_pseudo psehdr;
+-  int size;
++  unsigned int size;
+   t_ipaddr dadr;
+ #ifdef DEBUG
+@@ -194,13 +188,9 @@
+  * 
+  * Read one packet from a UDP socket
+  */
+-int udp_read(buf, bufsize, timeout, abortch)
+-char *buf;
+-int   bufsize;
+-int   timeout;
+-char  abortch;
++int udp_read(char *buf, unsigned int bufsize, int timeout)
+ {
+-  int len;
++  unsigned int len;
+   /* Wait until we get something */
+   set_timeout(timeout);
+@@ -299,9 +289,6 @@
   */
  int init_udp()
  {
@@ -2584,9 +3679,21 @@ diff -ruN proll_18.orig/src/udp.c proll-patch8/src/udp.c
    /* Register IP packet type and set write buffer pointer */
    if ((writebuf = reg_type(htons(ETH_P_IP), ip_recv)) == NULL)
        return(FALSE);
-diff -ruN proll_18.orig/src/vcons_zs.c proll-patch8/src/vcons_zs.c
+diff -ruN proll_18.orig/src/udp.h proll-patch-15/src/udp.h
+--- proll_18.orig/src/udp.h    2001-12-24 05:12:34.000000000 +0000
++++ proll-patch-15/src/udp.h   2005-08-14 10:16:40.000000000 +0000
+@@ -53,7 +53,7 @@
+ extern int udp_open __P((t_ipaddr daddr, int source, int dest));
+ /* Read from a UDP socket */
+-extern int udp_read __P((char *buf, int bufsize, int timeout, char abortch));
++extern int udp_read(char *buf, unsigned int bufsize, int timeout);
+ /* Write to a UDP socket */
+ extern int udp_write __P((char *buf, int writelen));
+diff -ruN proll_18.orig/src/vcons_zs.c proll-patch-15/src/vcons_zs.c
 --- proll_18.orig/src/vcons_zs.c       1970-01-01 00:00:00.000000000 +0000
-+++ proll-patch8/src/vcons_zs.c        2005-03-20 10:25:39.000000000 +0000
++++ proll-patch-15/src/vcons_zs.c      2005-08-14 10:25:51.000000000 +0000
 @@ -0,0 +1,68 @@
 +/**
 + ** Console over 'zs' (Zilog serial port)
@@ -2634,7 +3741,7 @@ diff -ruN proll_18.orig/src/vcons_zs.c proll-patch8/src/vcons_zs.c
 +      return leng;
 +}
 +
-+int vcon_zs_read(struct vconterm *t, char *data, int leng)
++int vcon_zs_read(struct vconterm *t, char *data, __attribute((unused)) int leng)
 +{
 +      unsigned zs_ptr = (unsigned) t->impl;
 +
@@ -2648,18 +3755,25 @@ diff -ruN proll_18.orig/src/vcons_zs.c proll-patch8/src/vcons_zs.c
 +      unsigned zs_ptr = (unsigned) t->impl;
 +
 +      while ((ldb_bypass(zs_ptr) & 1) != 1) { }
-+      return ldb_bypass(zs_ptr + ZS_DATA);
++      return ldb_bypass(zs_ptr + ZS_DATA) & 0xff;
 +}
 +
-+void vcon_zs_fini(struct vconterm *t)
++void vcon_zs_fini(__attribute((unused)) struct vconterm *t)
 +{
 +      /* violent crash in the end */
 +      ;
 +}
-diff -ruN proll_18.orig/src/vconsole.c proll-patch8/src/vconsole.c
+diff -ruN proll_18.orig/src/vconsole.c proll-patch-15/src/vconsole.c
 --- proll_18.orig/src/vconsole.c       1999-11-08 03:10:28.000000000 +0000
-+++ proll-patch8/src/vconsole.c        2005-03-02 14:29:05.000000000 +0000
-@@ -13,6 +13,10 @@
++++ proll-patch-15/src/vconsole.c      2005-08-14 10:24:49.000000000 +0000
+@@ -7,12 +7,17 @@
+ #include "vconsole.h"
+ #include "hconsole.h"
++#include <system.h>
+ static void vcon_i_cursfeed(struct vconterm *t);
+ static void vcon_i_backflush(struct vconterm *t);
  
  struct hconsole hcons0;
  
@@ -2670,7 +3784,7 @@ diff -ruN proll_18.orig/src/vconsole.c proll-patch8/src/vconsole.c
  int vcon_init(struct vconterm *t, unsigned int a0)
  {
        struct hconsole *hconp;
-@@ -25,11 +29,49 @@
+@@ -25,11 +30,49 @@
  
        t->vc_x = 0;    t->vc_y = 0;
        t->backp = 0;    t->backc = 0;
@@ -2720,7 +3834,7 @@ diff -ruN proll_18.orig/src/vconsole.c proll-patch8/src/vconsole.c
  int vcon_write(struct vconterm *t, char *data, int leng)
  {
        int l = leng;
-@@ -40,29 +82,84 @@
+@@ -40,29 +83,101 @@
                if (l <= 0) break;
                c = *data++;    --l;
  
@@ -2741,6 +3855,9 @@ diff -ruN proll_18.orig/src/vconsole.c proll-patch8/src/vconsole.c
 +                      case 'M':
 +                              hcon_scroll(hconp, 0, hcon_qydim(hconp), SM_UP, 1);
 +                              break;
++                      default:
++                              //printk("Unhandled escape code '%c'\n", c);
++                              break;
 +                      }
                        break;
 -              case 0x0D:              /* Return */
@@ -2768,9 +3885,23 @@ diff -ruN proll_18.orig/src/vconsole.c proll-patch8/src/vconsole.c
 +                              if (t->vc_par[1]) t->vc_par[1]--;
 +                              gotoxay(t, t->vc_par[1], t->vc_par[0]);
 +                              break;
++                      case 'J':
++                              if (t->vc_par[0] == 0) {
++                                      //erase from cursor to end of display
++                                      hcon_clear(hconp, t->vc_y, t->vc_x, hconp->ydim_, hconp->xdim_);
++                              }
++                              break;
 +                      case 'M':
 +                              hcon_scroll(hconp, 0, hcon_qydim(hconp), SM_UP, 1);
 +                              break;
++                      case 'm':
++                              break;
++                      default:
++#if 0
++                              printk("Unhandled escape code '%c', par[%d, %d, %d, %d, %d]\n",
++                                 c, t->vc_par[0], t->vc_par[1], t->vc_par[2], t->vc_par[3], t->vc_par[4]);
++#endif
++                              break;
 +                      }
                        break;
                default:
@@ -2815,7 +3946,7 @@ diff -ruN proll_18.orig/src/vconsole.c proll-patch8/src/vconsole.c
 +                              } else {
 +                                      t->backc++;
 +                              }
-+                              if (t->vc_x + t->backc >= hcon_qxdim(hconp)) {
++                              if ((unsigned int)t->vc_x + t->backc >= hcon_qxdim(hconp)) {
 +                                      vcon_i_backflush(t);
 +                                      t->vc_x = 0;
 +                                      vcon_i_cursfeed(t);
@@ -2823,9 +3954,99 @@ diff -ruN proll_18.orig/src/vconsole.c proll-patch8/src/vconsole.c
                        }
                }
        }
-diff -ruN proll_18.orig/src/vconsole.h proll-patch8/src/vconsole.h
+@@ -73,7 +188,7 @@
+ static void vcon_i_cursfeed(struct vconterm *t) {
+       struct hconsole *hconp = t->impl;
+-      if (++t->vc_y >= hcon_qydim(hconp)) {
++      if ((unsigned int)++t->vc_y >= hcon_qydim(hconp)) {
+               t->vc_y = hcon_qydim(hconp)-1;
+               hcon_scroll(hconp, 0, hcon_qydim(hconp), SM_UP, 1);
+       }
+@@ -90,22 +205,75 @@
+       t->backp = 0;    t->backc = 0;
+ }
+-int vcon_putch(struct vconterm *t, char c)
++int vcon_putch(__attribute__((unused)) struct vconterm *t, __attribute__((unused)) char c)
+ {
+       return -1;
+ }
+-int vcon_read(struct vconterm *t, char *data, int leng)
++int vcon_read(__attribute__((unused)) struct vconterm *t, __attribute__((unused)) char *data, __attribute__((unused)) int leng)
+ {
+       return 0;
+ }
+-int vcon_getch(struct vconterm *t)
++static const unsigned char sunkbd_keycode[128] = {
++    0, 0, 0, 0, 0, 0, 0, 0,  0, 0, 0, 0, 0, 0, 0, 0,
++    0, 0, 0, 0, 0, 0, 0, 0,  0, 0, 0, 0, 0, 0,
++    '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '-', '=', 0, 8,
++    0, 0, 0, 0, 0, 0, 0, 0, 0, 9,
++    'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p', '[', ']',
++    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++    'a', 's', 'd', 'f', 'g', 'h', 'j', 'k', 'l', ';', '\'', '\\', 13,
++    0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++    'z', 'x', 'c', 'v', 'b', 'n', 'm', ',', '.', '/',
++    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++    ' ',
++};
++
++static const unsigned char sunkbd_keycode_shifted[128] = {
++    0, 0, 0, 0, 0, 0, 0, 0,  0, 0, 0, 0, 0, 0, 0, 0,
++    0, 0, 0, 0, 0, 0, 0, 0,  0, 0, 0, 0, 0, 0,
++    '!', '@', '#', '$', '%', '^', '&', '*', '(', ')', '_', '+', 0, 8,
++    0, 0, 0, 0, 0, 0, 0, 0, 0, 9,
++    'Q', 'W', 'E', 'R', 'T', 'Y', 'U', 'I', 'O', 'P', '{', '}',
++    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++    'A', 'S', 'D', 'F', 'G', 'H', 'J', 'K', 'L', ':', '"', '|', 13,
++    0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++    'Z', 'X', 'C', 'V', 'B', 'N', 'M', '<', '>', '?',
++    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++    ' ',
++};
++
++static int shiftstate;
++
++int vcon_getch(__attribute__((unused)) struct vconterm *t)
+ {
+-      return -1;
++        int ch;
++
++      while ((ldb_bypass(0x71000004) & 1) != 1) { }
++      do {
++          ch = ldb_bypass(0x71000006) & 0xff;
++          if (ch == 99)
++              shiftstate |= 1;
++          else if (ch == 110)
++              shiftstate |= 2;
++          else if (ch == 227)
++              shiftstate &= ~1;
++          else if (ch == 238)
++              shiftstate &= ~2;
++          //printk("getch: %d\n", ch);
++      }
++      while ((ch & 0x80) == 0 || ch == 238 || ch == 227); // Wait for key release
++      //printk("getch rel: %d\n", ch);
++      ch &= 0x7f;
++      if (shiftstate)
++          ch = sunkbd_keycode_shifted[ch];
++      else
++          ch = sunkbd_keycode[ch];
++      //printk("getch xlate: %d\n", ch);
++      return ch;
+ }
+-void vcon_fini(struct vconterm *t)
++void vcon_fini(__attribute__((unused)) struct vconterm *t)
+ {
+       /* violent crash in the end */
+       ;
+diff -ruN proll_18.orig/src/vconsole.h proll-patch-15/src/vconsole.h
 --- proll_18.orig/src/vconsole.h       1999-11-08 00:58:13.000000000 +0000
-+++ proll-patch8/src/vconsole.h        2005-03-02 12:40:12.000000000 +0000
++++ proll-patch-15/src/vconsole.h      2005-03-02 12:40:12.000000000 +0000
 @@ -6,6 +6,8 @@
  #ifndef VCONSOLE_H
  #define VCONSOLE_H