Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 22 Jan 2001 13:03:49 -0800 (PST)
From:      "Justin T. Gibbs" <gibbs@FreeBSD.org>
To:        cvs-committers@FreeBSD.org, cvs-all@FreeBSD.org
Subject:   cvs commit: src/sys/dev/aic7xxx ahc_eisa.c ahc_pci.c aic7770.c aic7xxx.c aic7xxx.h aic7xxx.reg aic7xxx.seq aic7xxx_93cx6.c aic7xxx_freebsd.c aic7xxx_inline.h aic7xxx_pci.c
Message-ID:  <200101222103.f0ML3nK90312@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help
gibbs       2001/01/22 13:03:49 PST

  Modified files:
    sys/dev/aic7xxx      ahc_eisa.c ahc_pci.c aic7770.c aic7xxx.c 
                         aic7xxx.h aic7xxx.reg aic7xxx.seq 
                         aic7xxx_93cx6.c aic7xxx_freebsd.c 
                         aic7xxx_inline.h aic7xxx_pci.c 
  Log:
  ahc_eisa.c:
  	Initialize rid to 0.  This doesn't seem to make any difference
  	(the driver doesn't care what rid it gets and no-one seems to
  	check rid's value), but follows standard conventions.
  
  	Pass in our device_t to ahc_alloc().  We now use device_T
  	softc storage, so passing NULL results in a panic.
  
  	Set the unit number in our softc so that the driver core
  	can retrieve it.
  
  ahc_pci.c:
  	Set the unit number in our softc so that the driver core
  	can retrieve it.
  
  aic7770.c:
  	Insert our softc into the list of softcs when initialization
  	is successful.
  
  aic7xxx.c:
  	Remove a workaround for an aic7895 bug we will never trigger.
  
  	Add additional diagnostic info to ahc_dump_card_state().
  
  	Always panic the system if a sequencer assertion fails.
  
  	AHC_SCB_BTT is a "flag" not a "feature".  Check the right
  	field in the softc.
  
  	Replace a hard coded number with a constant.
  
  	Guard against looping forever in ahc_pause_and_flushwork().
  	A hot eject or card failure may make the intstat register
  	return 0xFF, so limit the number of interrupts we'll process.
  
  	Correct the code in ahc_search_qinfifo() that guarantees that
  	the sequencer will see an abort collision if the qinfifo is
  	modified when a DMA is in progress.  We now do this fixup
  	after modifying the queue.  This guarantees that the HSCB
  	we place at the head of the queue is not the same as the
  	old head.  Using "next hscb" (guaranteed not to be the
  	same as the first SCB) before clearing the queue could free
  	up the original head hscb to be used during a remove operation
  	placing it again at the head of the qinfifo.
  
  aic7xxx.h:
  	Reduce the maximum number of outstanding commands to 253 from
  	254.  To handle our output queue correctly on machines that only
  	support 32bit stores, we must clear the array 4 bytes at a
  	time.  To avoid colliding with a DMA write from the sequencer,
  	we must be sure that 4 slots are empty when we write to clear
  	the queue.  This reduces us to 253 SCBs: 1 that just completed
  	and the known three additional empty slots in the queue that
  	preceed it.  Yahoo was able to force this race on one of their
  	systems.  Interrupts were disabled for such a time that the
  	entire output queue was filled (254 entries complete without
  	any processing), and our 32bit write to clear the status clobbered
  	one entry.
  
  	Add a feature tag for devices that are removable.
  
  aic7xxx.reg:
  	Never use the sequencer interrupt value of 0xF0.  We need
  	to guanrantee that an INTSTAT value of 0xFF can only occur
  	during card failure or a hot-eject.
  
  	Align the busy targets table with the begining of scratch
  	space.  This seems to appease a chip bug in the aic7895.
  
  aic7xxx.seq:
  	Be sure to disable select-out after a bus free event that occurs
  	early in a selection.  If we don't disable select-out, we will
  	believe that it is enabled even though a new selection will never
  	occur.
  
  	Move the clearing of SELDI to just before a jump.  This appeases
  	another chip bug of the aic7895.
  
  	Make the target mode command loop a bit more efficient.
  
  	AHC_SCB_BTT is a "flag" not a "feature".  Check the right
  	field in the softc.
  
  	Properly cleanup the last SCB we tested against should we
  	fail to properly find an SCB for a reselection.
  
  	Add some additional sequencer debugging code.
  
  aic7xxx_freebsd.c:
  	Limit the driver to 253 outstanding commands per adapter.
  
  	Guard against overflow in timeout handling.
  
  aic7xxx_inline.h:
  	AHC_SCB_BTT is a "flag" not a "feature".  Check the right
  	field in the softc.
  
  aic7xxx_pci.c:
  	Set the removable feature for the apa1480 cardbus and the 29160C
  	Compact PCI card.
  
  	Don't report high byte termination information for narrow cards.
  
  	Use a PCI read rather than a questionable delay when fetching/setting
  	termination settings.
  
  Revision  Changes    Path
  1.19      +6 -2      src/sys/dev/aic7xxx/ahc_eisa.c
  1.39      +3 -1      src/sys/dev/aic7xxx/ahc_pci.c
  1.2       +7 -2      src/sys/dev/aic7xxx/aic7770.c
  1.65      +65 -57    src/sys/dev/aic7xxx/aic7xxx.c
  1.33      +24 -6     src/sys/dev/aic7xxx/aic7xxx.h
  1.32      +8 -15     src/sys/dev/aic7xxx/aic7xxx.reg
  1.108     +45 -31    src/sys/dev/aic7xxx/aic7xxx.seq
  1.11      +1 -1      src/sys/dev/aic7xxx/aic7xxx_93cx6.c
  1.18      +25 -13    src/sys/dev/aic7xxx/aic7xxx_freebsd.c
  1.11      +5 -5      src/sys/dev/aic7xxx/aic7xxx_inline.h
  1.9       +68 -39    src/sys/dev/aic7xxx/aic7xxx_pci.c



To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe cvs-all" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200101222103.f0ML3nK90312>