Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/drv/nic/rtl8139/defs.h

    r5cd3d67 rbf84871  
    2929/** @file rtl8139_defs.h
    3030 *
    31  * Registers, bit positions and masks definition
    32  * of the RTL8139 network family cards
    33  */
    34 
    35 #ifndef RTL8139_DEFS_H_
    36 #define RTL8139_DEFS_H_
    37 
     31 *  Registers, bit positions and masks definition of the RTL8139 network family
     32 *  cards
     33 */
     34
     35#ifndef RTL8139_DEFS_H_INCLUDED_
     36#define RTL8139_DEFS_H_INCLUDED_
    3837#include <sys/types.h>
    3938#include <libarch/ddi.h>
    4039
    41 /** Size of RTL8139 registers address space */
    42 #define RTL8139_IO_SIZE  256
    43 
    44 /** Maximal transmitted frame length
    45  *
    46  * Maximal transmitted frame length in bytes
    47  * allowed according to the RTL8139 documentation
    48  * (see SIZE part of TSD documentation).
    49  *
    50  */
    51 #define RTL8139_FRAME_MAX_LENGTH  1792
     40
     41/** The size of RTL8139 registers address space */
     42#define RTL8139_IO_SIZE 256
     43
     44/** The maximal transmitted packet length in bytes allowed according to RTL8139
     45 *  documentation (see SIZE part of TSD documentation)
     46 */
     47#define RTL8139_PACKET_MAX_LENGTH 1792
     48
    5249
    5350/** HW version
    5451 *
    55  * As can be detected from HWVERID part of TCR
    56  * (Transmit Configuration Register).
    57  *
    58  */
    59 typedef enum {
     52 *  as can be detected from HWVERID part of TCR
     53 *  (Transmit Configuration Register)
     54 */
     55enum rtl8139_version_id {
    6056        RTL8139 = 0,          /**< RTL8139 */
    6157        RTL8139A,             /**< RTL8139A */
     
    7066        RTL8101,              /**< RTL8101 */
    7167        RTL8139_VER_COUNT     /**< Count of known RTL versions, the last value */
    72 } rtl8139_version_id_t;
     68};
     69
     70extern const char* model_names[RTL8139_VER_COUNT];
    7371
    7472/** Registers of RTL8139 family card offsets from the memory address base */
     
    7775        MAC0  = IDR0,    /**< Alias for IDR0 */
    7876
    79         // 0x06 - 0x07 reserved
     77        // 0x6 - 0x7 reserved
    8078
    8179        MAR0    = 0x08,  /**< Multicast mask registers 8 1b registers sequence */
     
    9694
    9795        CR      = 0x37,  /**< Command register, 1b */
    98         CAPR    = 0x38,  /**< Current address of frame read, 2b */
     96        CAPR    = 0x38,  /**< Current address of packet read, 2b */
    9997        CBA     = 0x3a,  /**< Current buffer address, 2b */
    10098
     
    215213        pio_write_8(io_base + CR9346, RTL8139_REGS_LOCKED);
    216214}
    217 
    218215/** Allow to change Config0-4 and BMCR register  */
    219216static inline void rtl8139_regs_unlock(void *io_base)
     
    285282        RCR_MulERINT = 1 << 17,    /**< Multiple early interrupt select */
    286283
    287         /** Minimal error frame length (1 = 8B, 0 = 64B). If AER/AR is set, RER8
     284        /** Minimal error packet length (1 = 8B, 0 = 64B). If AER/AR is set, RER8
    288285         * is "Don't care"
    289286         */
     
    305302
    306303        RCR_WRAP              = 1 << 7,  /**< Rx buffer wrapped */
    307         RCR_ACCEPT_ERROR      = 1 << 5,  /**< Accept error frame */
    308         RCR_ACCEPT_RUNT       = 1 << 4,  /**< Accept Runt (8-64 bytes) frames */
     304        RCR_ACCEPT_ERROR      = 1 << 5,  /**< Accept error packet */
     305        RCR_ACCEPT_RUNT       = 1 << 4,  /**< Accept Runt (8-64 bytes) packets */
    309306        RCR_ACCEPT_BROADCAST  = 1 << 3,  /**< Accept broadcast */
    310307        RCR_ACCEPT_MULTICAST  = 1 << 2,  /**< Accept multicast */
    311308        RCR_ACCEPT_PHYS_MATCH = 1 << 1,  /**< Accept device MAC address match */
    312         RCR_ACCEPT_ALL_PHYS   = 1 << 0,  /**< Accept all frames with
     309        RCR_ACCEPT_ALL_PHYS   = 1 << 0,  /**< Accept all packets with
    313310                                          * phys. desticnation
    314311                                                                          */
     
    365362        ANAR_ACK          = (1 << 14),  /**< Capability reception acknowledge */
    366363        ANAR_REMOTE_FAULT = (1 << 13),  /**< Remote fault detection capability */
    367         ANAR_PAUSE        = (1 << 10),  /**< Symetric pause frame capability */
     364        ANAR_PAUSE        = (1 << 10),  /**< Symetric pause packet capability */
    368365        ANAR_100T4        = (1 << 9),   /**< T4, not supported by the device */
    369366        ANAR_100TX_FD     = (1 << 8),   /**< 100BASE_TX full duplex */
     
    402399        CONFIG3_GNT_SELECT = (1 << 7),  /**< Gnt select */
    403400        CONFIG3_PARM_EN    = (1 << 6),  /**< Parameter enabled (100MBit mode) */
    404         CONFIG3_MAGIC      = (1 << 5),  /**< WoL Magic frame enable */
     401        CONFIG3_MAGIC      = (1 << 5),  /**< WoL Magic packet enable */
    405402        CONFIG3_LINK_UP    = (1 << 4),  /**< Wakeup if link is reestablished */
    406403        CONFIG3_CLKRUN_EN  = (1 << 2),  /**< CLKRUN enabled */ /* TODO: check what does it mean */
     
    419416};
    420417
    421 /** Maximal runt frame size + 1 */
    422 #define RTL8139_RUNT_MAX_SIZE  64
    423 
    424 /** Bits in frame header */
    425 enum rtl8139_frame_header {
     418/** Maximal runt packet size + 1 */
     419#define RTL8139_RUNT_MAX_SIZE 64
     420
     421/** Bits in packet header */
     422enum rtl8139_packet_header {
    426423        RSR_MAR  = (1 << 15),  /**< Multicast received */
    427424        RSR_PAM  = (1 << 14),  /**< Physical address match */
     
    429426
    430427        RSR_ISE  = (1 << 5),   /**< Invalid symbol error, 100BASE-TX only */
    431         RSR_RUNT = (1 << 4),   /**< Runt frame (< RTL8139_RUNT_MAX_SIZE bytes) */
    432 
    433         RSR_LONG = (1 << 3),   /**< Long frame (size > 4k bytes) */
     428        RSR_RUNT = (1 << 4),   /**< Runt packet (< RTL8139_RUNT_MAX_SIZE bytes) */
     429
     430        RSR_LONG = (1 << 3),   /**< Long packet (size > 4k bytes) */
    434431        RSR_CRC  = (1 << 2),   /**< CRC error */
    435432        RSR_FAE  = (1 << 1),   /**< Frame alignment error */
    436         RSR_ROK  = (1 << 0)    /**< Good frame received */
     433        RSR_ROK  = (1 << 0)    /**< Good packet received */
    437434};
    438435
     
    454451                                                                          */
    455452
    456         APPEND_CRC = 1 << 16,        /**< Append CRC at the end of a frame */
     453        APPEND_CRC = 1 << 16,        /**< Append CRC at the end of a packet */
    457454
    458455        MXTxDMA_SHIFT = 8,  /**< Max. DMA Burst per TxDMA shift, burst = 16^value */
     
    462459        TX_RETRY_COUNT_SIZE  = 4,            /**< Retries before aborting size */
    463460
    464         CLEAR_ABORT = 1 << 0    /**< Retransmit aborted frame at the last
     461        CLEAR_ABORT = 1 << 0    /**< Retransmit aborted packet at the last
    465462                                  *  transmitted descriptor
    466463                                                          */
     
    473470
    474471/** Mapping of HW version -> version ID */
    475 struct rtl8139_hwver_map {
    476         uint32_t hwverid;             /**< HW version value in the register */
    477         rtl8139_version_id_t ver_id;  /**< appropriate version id */
     472struct rtl8139_hwver_map { 
     473        uint32_t hwverid;                /**< HW version value in the register */
     474        enum rtl8139_version_id ver_id;  /**< appropriate version id */
    478475};
    479476
    480477/** Mapping of HW version -> version ID */
    481478extern const struct rtl8139_hwver_map rtl8139_versions[RTL8139_VER_COUNT + 1];
    482 extern const char* model_names[RTL8139_VER_COUNT];
    483 
    484 /** Size in the frame header while copying from RxFIFO to Rx buffer */
    485 #define RTL8139_EARLY_SIZE  UINT16_C(0xfff0)
    486 
    487 /** The only supported pause frame time value */
    488 #define RTL8139_PAUSE_VAL  UINT16_C(0xFFFF)
    489 
    490 /** Size of the frame header in front of the received frame */
    491 #define RTL_FRAME_HEADER_SIZE  4
     479
     480/** Size in the packet header while copying from RxFIFO to Rx buffer */
     481#define RTL8139_EARLY_SIZE UINT16_C(0xfff0)
     482/** The only supported pause packet time value */
     483#define RTL8139_PAUSE_VAL UINT16_C(0xFFFF)
     484
     485/** Size of the packet header in front of the received frame */
     486#define RTL_PACKET_HEADER_SIZE 4
    492487
    493488/** 8k buffer */
Note: See TracChangeset for help on using the changeset viewer.