source: trunk/modules/vci_ethernet_tsar/include/soclib/ethernet.h

Last change on this file was 528, checked in by lambert, 11 years ago

Introduicing VciEthernetTsar?
This component is modified version of VciEthernet? from soclib
Main differences are :

  • DMA access avoid overlapinging cache line boundaries
  • Pktid is now 0x4 in write cmd
  • IRQ can be reset with the status register
File size: 3.0 KB
RevLine 
[528]1/*
2 * SOCLIB_LGPL_HEADER_BEGIN
3 *
4 * This file is part of SoCLib, GNU LGPLv2.1.
5 *
6 * SoCLib is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU Lesser General Public License as published
8 * by the Free Software Foundation; version 2.1 of the License.
9 *
10 * SoCLib is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13 * Lesser General Public License for more details.
14 *
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with SoCLib; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
18 * 02110-1301 USA
19 *
20 * SOCLIB_LGPL_HEADER_END
21 *
22 * Copyright (c) Telecom ParisTech
23 *         Alexandre Becoulet <alexandre.becoulet@enst.fr>, 2012
24 *
25 * Maintainers: becoulet
26 */
27
28#ifndef ETHERNET_REGS_H
29#define ETHERNET_REGS_H
30
31enum SoclibEthernetRegisters {
32    ETHERNET_TX_SIZE  = 0,       /*< on write: set size of packet to send for next adress push */
33    ETHERNET_TX_FIFO  = 1,       /*< on write: push address and size of packet to send on tx fifo,
34                                     on read:  pop status of sent packet from tx fifo. 0 if empty */
35    ETHERNET_RX_SIZE  = 2,       /*< on write: set size of rx buffer for next adress push,
36                                     on read:  get size of last rx packet, 0 if empty. */
37    ETHERNET_RX_FIFO  = 3,       /*< on write: push address and size of buffer on rx fifo,
38                                     on read:  pop status of last rx packet. 0 if empty */
39    ETHERNET_STATUS   = 4,       /*< on read:  contains device status flags */
40    ETHERNET_CTRL     = 4,       /*< on write: device control actions */
41    ETHERNET_FIFO_SIZE = 5,      /*< contains size of TX & RX FIFOs */
42    ETHERNET_MAC_LOW   = 6,      /*< contains mac address bytes 0, 1, 2 and 3 */
43    ETHERNET_MAC_HIGH  = 7,      /*< contains mac address bytes 4 and 5 */
44};
45
46enum SoclibEthernetRxStatus {
47        ETHERNET_RX_EMPTY = 0,
48        ETHERNET_RX_DONE = 1,
49        ETHERNET_RX_DMA_ERR = 2,
50        ETHERNET_RX_PHY_ERR = 3,
51};
52
53enum SoclibEthernetTxStatus {
54        ETHERNET_TX_EMPTY = 0,
55        ETHERNET_TX_DONE = 1,
56        ETHERNET_TX_DMA_ERR = 2,
57        ETHERNET_TX_PHY_ERR = 3,
58};
59
60enum SoclibEthernetStatus {
61        ETHERNET_ST_LINK_UP = 1,
62        ETHERNET_ST_TX_DONE = 2,     /*< The ETHERNET_TX_FIFO register content is valid */
63        ETHERNET_ST_RX_DONE = 4,     /*< The ETHERNET_RX_FIFO register content is valid */
64};
65
66enum SoclibEthernetCtrl {
67        ETHERNET_CTRL_RESET  = 1,     //< fifos become empty, disable interrupts
68        ETHERNET_CTRL_TX_IRQ = 2,     //< enable TX irq when written to 1
69        ETHERNET_CTRL_RX_IRQ = 4,     //< enable RX irq when written to 1
70        ETHERNET_CTRL_LINK_IRQ = 8,   //< enable link status change irq when written to 1
71};
72
73#endif /* ETHERNET_REGS_H */
74
75// Local Variables:
76// tab-width: 4
77// c-basic-offset: 4
78// c-file-offsets:((innamespace . 0)(inline-open . 0))
79// indent-tabs-mode: nil
80// End:
81
82// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=4:softtabstop=4
83
Note: See TracBrowser for help on using the repository browser.