AM79C978 Advanced Micro Devices, AM79C978 Datasheet - Page 242

no-image

AM79C978

Manufacturer Part Number
AM79C978
Description
Single-Chip 1/10 Mbps PCI Home Networking Controller
Manufacturer
Advanced Micro Devices
Datasheet

Available stocks

Company
Part Number
Manufacturer
Quantity
Price
Part Number:
AM79C978AKC
Manufacturer:
AMD
Quantity:
15
Part Number:
AM79C978AKC
Manufacturer:
AMD
Quantity:
8 000
Part Number:
AM79C978AKC/W
Manufacturer:
AMD
Quantity:
20 000
Part Number:
AM79C978AKCW
Manufacturer:
AMD
Quantity:
6 605
Note: The labels in the following text are used as ref-
erences in the timeline diagram that follows (Figure
B-1).
Setup
The driver should set up descriptors in groups of three,
with the OWN and STP bits of each set of three de-
scriptors to read as follows: 11b, 10b, 00b.
An option bit (LAPPEN) exists in CSR3, bit position 5;
the software should set this bit. When set, the LAPPEN
bit directs the controller to generate an INTERRUPT
when STP has been written to a receive descriptor by
the controller.
Flow
The controller polls the current receive descriptor at
some point in time before a message arrives. The con-
troller determines that this receive buffer is OWNed by
the controller and it stores the descriptor information to
be used when a message does arrive.
N0
N1
C0
C1
S1
C2
C3
S1
C4
Note: Even though the third buffer is not owned by the
controller, existing AMD Ethernet controllers will con-
tinue to perform data DMA into the buffer space that the
controller already owns (i.e., buffer number 2). The
controller does not know if buffer space in buffer num-
B-2
Frame preamble appears on the wire, followed
by SFD and destination address.
The 64th byte of frame data arrives from the
wire. This causes the controller to begin frame
data DMA operations to the first buffer.
When the 64th byte of the message arrives,
the controller performs a lookahead operation
to the next receive descriptor. This descriptor
should be owned by the controller.
The controller intermittently requests the bus
to transfer frame data to the first buffer as it ar-
rives on the wire.
The driver remains idle.
When the controller has completely filled the
first buffer, it writes status to the first descriptor.
When the first descriptor for the frame has
been written, changing ownership from the
controller to the CPU, the controller will gener-
ate an SRP INTERRUPT. (This interrupt ap-
pears as a RINT interrupt in CSR0).
The SRP INTERRUPT causes the CPU to
switch tasks to allow the controller’s driver to
run.
During the CPU interrupt-generated task
switching, the controller is performing a looka-
head operation to the third descriptor. At this
point in time, the third descriptor is owned by
the CPU.
Am79C978
ber 2 will be sufficient or not for this frame, but it has no
way to tell except by trying to move the entire message
into that space. Only when the message does not fit will
it signal a buffer error condition--there is no need to
panic at this point that it discovers that it does not yet
own descriptor number 3.
S2
S3
C5
S4
S5
C6
C7
After filling the second buffer and performing
the last chance lookahead to the next descrip-
tor, the controller will write the status and
change the ownership bit of descriptor number
2.
routing is to collect the header information
from the controller’s first buffer and pass it to
the application.
pointer to the driver. The driver will add an off-
set to the application data buffer pointer, since
the controller will be placing the first portion of
the message into the first and second buffers.
(the modified application data buffer pointer
will only be directly used by the controller when
it reaches the third buffer.) The driver will place
the modified data buffer pointer into the final
descriptor of the group (#3) and will grant own-
ership of this descriptor to the controller.
the controller will write frame data to buffer
number 2.
tents of the controller’s first buffer to the begin-
ning of the application space. This copy will be
to the exact (unmodified) buffer pointer that
was passed by the application.
into the beginning of the application data
buffer, the driver will begin to poll the owner-
ship bit of the second descriptor. The driver is
waiting for the controller to finish filling the sec-
ond buffer.
owned the third descriptor and knowing that
the current message has not ended (there is
more data in the FIFO), the controller will make
a last ditch lookahead to the final (third) de-
scriptor. This time the ownership will be TRUE
(i.e., the descriptor belongs tot he controller),
because the driver wrote the application
pointer into this descriptor and then changed
the ownership to give the descriptor to the con-
troller back at S3. Note that if steps S1, S2,
and S3 have not completed at this time, a
BUFF error will result.
The first task of the drivers interrupt service
The application will return an application buffer
Interleaved with S2, S3, and S4 driver activity,
The driver will next proceed to copy the con-
After copying all of the data from the first buffer
At this point, knowing that it had not previously

Related parts for AM79C978