ENC424J600/624J600
DS39935C-page 102
2010 Microchip Technology Inc.
10.11 Pattern Match Collection Filter
The Pattern Match filter accepts frames that match or
do not match a specific pattern. This filter is useful for
accepting
frames
that
contain
expected
data
sequences.
Pattern matching is accomplished by choosing a 64-byte
window within the first 128 bytes of a frame, then
selecting some or all of those bytes for a checksum
calculation. The checksum algorithm is the same as the
. This checksum is then com-
pared to the EPMCS register and the result is optionally
negated by the NOTPM (ERXFCON<12>) flag.
The Pattern Match filter’s control bits, PMEN<3:0>
(ERXFCON<11:8>), differ from all other filters in that
there are multiple options. The output of the above
match can be ANDed with several other conditions.
This adds significant flexibility to the filter as it can
require both a Pattern Match (or non-match) and other
criteria (such as a Broadcast frame or Hash Table
match).
To use the Pattern Match filter, the host controller must
first program the Pattern Match Offset (EPMO) to
select the 64-byte window to be used. Setting this
register to 0000h selects the first 64 bytes of the frame,
beginning with the first byte of the destination address.
Setting 0006h selects byte numbers, 6 through 69,
beginning with the first byte of the source address. This
window must fall within the first 128 bytes of a frame;
the offset value of 1 is not supported, thus, the valid
values for EPMO are 0, 2-63.
Note that if the frame length is short enough so that the
entire window would not exist in the frame, the filter will
automatically fail to match. This is true even if the
corresponding mask bits are all ‘0’.
Then, the host must select the Pattern Match mask
bytes by using the EPMM registers. Within this 64-byte
window, each byte can be selectively included or
excluded from the checksum computation by setting or
clearing the respective bit in the Pattern Match mask. A
bit set to ‘1’ indicates that the byte is to be included. Data
bytes with corresponding mask bits set to ‘0’ are
completely removed for the purpose of the checksum
calculation (as opposed to treating the data bytes as
zero).
Next, write the expected checksum to the EPMCS reg-
ister. To select frames that match the checksum, clear
NOTPM (ERXFCON<12>). To select only frames that
fail to match the checksum, set NOTPM to ‘1’. Finally,
set the PMEN bits to ‘0001b’ to require only the Pattern
Match criteria, or one of the other values to add
additional conditions.
For example, to filter all frames having a particular
source MAC address of 00-04-A3-FF-FF-FF:
1.
Program the Pattern Match offset to 0000h.
2.
Set bits, 6-11, of EPMM1 (assuming all other
mask bits are ‘0’).
3.
Program the EPMCS register with a checksum
value of 5BFCh.
4.
Clear NOTPM to require an exact match.
Note that the offset is not programmed to 0006h and the
EPMM1<5:0> bits are not set; the checksum would still
be 5BFCh. However, in this second case, frames less
than 70 bytes would never meet the Pattern Match
criteria because there would not be a complete 64-byte
window beginning at offset position, 0006h. Another
example of a Pattern Match filter is illustrated in
The Pattern Match Collection filter is disabled at
power-up. Because this filter has the lowest priority of
all receive filters, if this filter is disabled or the packet
does not meet the configured Pattern Match criteria,
the packet is automatically discarded.
10.12 Promiscuous Mode
To accept all incoming frames regardless of content
(Promiscuous mode), set the CRCEN, RUNTEN, UCEN,
NOTMEEN and MCEN bits. Disable all other filters.
To accept absolutely all recognizable Ethernet frames,
including
those
with
errors,
set
PASSALL
(MACCON1<1>) to ‘1’ and set UCEN, NOTMEEN and
MCEN in ERXFCON.
In any mode, frames which cannot fit in the receive
buffer, or would cause the PKTCNT field (ESTAT<7:0>)
to overflow, are still discarded.