Update to the SYM-0.10.0-19991111 patch.

Submitted by:	Gerard Roudier <groudier@club-internet.fr>
This commit is contained in:
David E. O'Brien 1999-11-27 23:35:46 +00:00
parent c19e61b2f2
commit da0e9bf6b5
2 changed files with 88 additions and 25 deletions

View File

@ -56,19 +56,22 @@
* SUCH DAMAGE.
*/
Status: (switched back to EXPERIMENTAL due to some heavy changes)
EXPERIMENTAL
Status:
BETA-RELEASE
This driver is currently developped under the following O/S:
FreeBSD 4.0 SNAPSHOT July 5th 1999
FreeBSD 4.0 current October 1999
Starting with version 0.9.0, the driver contains conditionnal code
for using pre-4.0 BUS stuff for PCI. I have successfully tested driver
version 0.9.0 under:
FreeBSD 3.2 RELEASE
Given that the old bus stuff is still supported under FreeBSD, the driver
should also compile and work just fine under FreeBSD 3.3 RELEASE.
FreeBSD 3.3 RELEASE
Latest revision:
sym-0.9.0-19991024
sym-0.10.0-19991111
Files to download:
SYM-0.9.0-19991024.tar.gz
PATCH-SYM-0.10.0-19991111.tar.gz
Supported SCSI features:
- Initiator mode
@ -100,7 +103,7 @@ Others:
Notes:
(1) Only supported by the LSI53C1010 and not yet
tested due to lack of C1010 based controller.
(2) Not yet checked. May not work as expected.
(2) Not yet reported. May not work as expected.
Files:
README.sym this file
@ -125,9 +128,24 @@ Installation:
If FreeBSD-3, apply the unified patch sym_sys_3.patch
(patch -p0 <sym_sys_3.patch)
Otherwise, leave here. ;)
5) Add sym0 to your kernel configuration as indicated in patched LINT file.
5) Change to /usr/src/sys/pci directory
6) Update to SYM-0.10.0-19991111
gzip -d <PATCH-SYM-0.10.0-19991111.gz | patch -p0
7) Add sym0 to your kernel configuration as indicated in patched LINT file.
Configure and make your kernel.
As seen from the shell history file (driver material assumed from /tmp),
installation should proceed as follow (modulo mistakes from me:)):
cd /tmp
tar zxvf SYM-0.9.0-19991024.tar.gz
cp SYM-0.9.0-19991024/* /usr/src/sys/pci
cd /usr/src/sys
patch -p0 <pci/sym_sys.patch # use sym_sys_3.patch if FreeBSD-3.X
cd pci
gzip -d </tmp/PATCH-SYM-0.10.0-19991111.gz | patch -p0
Warnings:
- This driver uses LOAD/STORE instructions from SCRIPTS and therefore does
not support earliest NCR chips (NCR53C810, NCR53C815, NCR53C825).
@ -139,7 +157,10 @@ Versionning:
- Incremental diff files are of the following pattern:
PATCH-SYM-X.Y.Z-YYYYMMDD
They must be applied from directory: /usr/src/sys/pci/
- Version 1.0.0 will add support for the C1010 (Ultra-3 DT data transfers)
- Version 1.0.0 will happen when the driver will be tested enough but this
driver version will probably not officially support the C1010 (Ultra-3)
since the testing hasn't started yet. Some 1.X.0 version will support the
C1010 (DT data transfer).
- Version 2.0.0 is not planned for now, but will add support for host target
mode if it will ever exist.
@ -183,7 +204,7 @@ Change log:
* SYM-0.8.0-19991016 (diff file PATCH-SYM-0.8.0-19991016)
Heavy rewrite/rewamping of the error handling code in order to conform
to FreeBSD-CAM expectation of commands having to be requeued and device
queue to be freezed on any kind of error. Driver status switched back
queue to be frozen on any kind of error. Driver status switched back
to EXPERIMENTAL due to these changes.
Warn user about targets that are not flagged for SCAN AT BOOT in the
NVRAM, since the driver will not allow the corresponding devices to be
@ -197,4 +218,13 @@ Change log:
Tested under RELENG_3_2_0_RELEASE, but should also be just fine for 3.3.
Other changes against version 0.8.0 are only minor buglet fixes.
October 24 1999. "Gerard Roudier"<groudier@club-internet.fr>
* SYM-0.10.0-19991111 (diff file PATCH-SYM-0.10.0-19991111)
Add support for Alpha - UNTESTED. Consists in some minor changes picked
mostly from the ncr driver and some others as ahc_pci.c.
Fix the LED support through GPIO0 for pre-896 chips. In fact some code
was wrongly conditionned by something that was never met.
Switch driver status to BETA-RELEASE given that this driver has been rock
solid even if s small number of users seems to actually use it.
November 11 1999. "Gerard Roudier"<groudier@club-internet.fr>

View File

@ -56,7 +56,7 @@
* SUCH DAMAGE.
*/
#define SYM_DRIVER_NAME "sym-0.9.0-19991024"
#define SYM_DRIVER_NAME "sym-0.10.0-19991111"
#include <pci.h>
#include <stddef.h> /* For offsetof */
@ -137,10 +137,13 @@ typedef u_int32_t u32;
* ensure that accesses from the CPU to the start and done
* queues are not reordered by either the compiler or the
* CPU and uses 'volatile' for this purpose.
* -> Only x86 architecture is supported, for now.
*/
#ifdef __alpha__
#define MEMORY_BARRIER() alpha_mb()
#else /*__i386__*/
#define MEMORY_BARRIER() do { ; } while(0)
#endif
/*
* A la VMS/CAM-3 queue management.
@ -359,14 +362,21 @@ static int sym_debug = 0;
/*
* Virtual to bus address translation.
* Only x86 supported.
*/
#ifdef __alpha__
#define vtobus(p) alpha_XXX_dmamap((vm_offset_t)(p))
#else /*__i386__*/
#define vtobus(p) vtophys(p)
#endif
/*
* Copy from main memory to PCI memory space.
*/
#ifdef __alpha__
#define memcpy_to_pci(d, s, n) memcpy_toio((u32)(d), (void *)(s), (n))
#else /*__i386__*/
#define memcpy_to_pci(d, s, n) bcopy((s), (void *)(d), (n))
#endif
/*
* Insert a delay in micro-seconds and milli-seconds.
@ -637,8 +647,6 @@ struct sym_nvram {
* If SYMCONF_IOMAPPED is defined, the driver will use
* normal IOs instead of the MEMORY MAPPED IO method
* recommended by PCI specifications.
* For now, we only support flat memory model that should
* limited support to x86 architecture.
*/
/*
@ -652,13 +660,25 @@ struct sym_nvram {
#define io_write16(p, v) outw((p), cpu_to_scr(v))
#define io_write32(p, v) outl((p), cpu_to_scr(v))
#define mmio_read8(a) scr_to_cpu((*(volatile unsigned char *) (a)))
#define mmio_read16(a) scr_to_cpu((*(volatile unsigned short *) (a)))
#define mmio_read32(a) scr_to_cpu((*(volatile unsigned int *) (a)))
#ifdef __alpha__
#define mmio_write8(a, b) (*(volatile unsigned char *) (a)) = cpu_to_scr(b)
#define mmio_write16(a, b) (*(volatile unsigned short *) (a)) = cpu_to_scr(b)
#define mmio_write32(a, b) (*(volatile unsigned int *) (a)) = cpu_to_scr(b)
#define mmio_read8(a) readb(a)
#define mmio_read16(a) readw(a)
#define mmio_read32(a) readl(a)
#define mmio_write8(a, b) writeb(a, b)
#define mmio_write16(a, b) writew(a, b)
#define mmio_write32(a, b) writel(a, b)
#else /*__i386__*/
#define mmio_read8(a) scr_to_cpu((*(volatile unsigned char *) (a)))
#define mmio_read16(a) scr_to_cpu((*(volatile unsigned short *) (a)))
#define mmio_read32(a) scr_to_cpu((*(volatile unsigned int *) (a)))
#define mmio_write8(a, b) (*(volatile unsigned char *) (a)) = cpu_to_scr(b)
#define mmio_write16(a, b) (*(volatile unsigned short *) (a)) = cpu_to_scr(b)
#define mmio_write32(a, b) (*(volatile unsigned int *) (a)) = cpu_to_scr(b)
#endif
/*
* Normal IO
@ -672,7 +692,7 @@ struct sym_nvram {
#define OUTW_OFF(o, v) io_write16(np->io_port + sym_offw(o), (v))
#define INL_OFF(o) io_read32(np->io_port + (o))
#define OUTL_OFF(o, v) io_write32(np->base_io + (o), (v))
#define OUTL_OFF(o, v) io_write32(np->io_port + (o), (v))
#else /* Memory mapped IO */
@ -9773,7 +9793,7 @@ sym_pci_attach2(pcici_t pci_tag, int unit)
#else
if ((command & PCI_COMMAND_IO_ENABLE) != 0) {
pci_port_t io_port;
if (!pci_map_port (pci_tag, SYM_PCI_IO, &io_port))
if (!pci_map_port (pci_tag, SYM_PCI_IO, &io_port)) {
printf("%s: failed to map IO window\n", sym_name(np));
goto attach_failed;
}
@ -9942,7 +9962,7 @@ sym_pci_attach2(pcici_t pci_tag, int unit)
np->scripth0->pm0_data_addr[0] = cpu_to_scr(SCRIPT_BA(np,pm0_data));
np->scripth0->pm1_data_addr[0] = cpu_to_scr(SCRIPT_BA(np,pm1_data));
#ifdef SYM_OPT_LED0
/*
* Still some for LED support.
*/
@ -9954,7 +9974,7 @@ sym_pci_attach2(pcici_t pci_tag, int unit)
np->script0->start[0] =
cpu_to_scr(SCR_REG_REG(gpreg, SCR_AND, 0xfe));
}
#endif
/*
* Load SCNTL4 on reselection for the C10.
*/
@ -10219,6 +10239,19 @@ int sym_cam_attach(hcb_p np)
}
np->path = path;
/*
* Hmmm... This should be useful, but I donnot want to
* know about.
*/
#ifdef __alpha__
#ifdef FreeBSD_4_Bus
alpha_register_pci_scsi(pci_get_bus(np->device),
pci_get_slot(np->device), np->sim);
#else /*__i386__*/
alpha_register_pci_scsi(pci_tag->bus, pci_tag->slot, np->sim);
#endif
#endif
#if 0
/*
* Establish our async notification handler.