1 | /*
|
---|
2 | * TINET (TCP/IP Protocol Stack)
|
---|
3 | *
|
---|
4 | * Copyright (C) 2001-2009 by Dep. of Computer Science and Engineering
|
---|
5 | * Tomakomai National College of Technology, JAPAN
|
---|
6 | * Copyright (C) 2014-2019 Cores Co., Ltd. Japan
|
---|
7 | *
|
---|
8 | * 上記著作権者は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
|
---|
9 | * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
|
---|
10 | * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
|
---|
11 | * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
|
---|
12 | * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
|
---|
13 | * スコード中に含まれていること.
|
---|
14 | * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
|
---|
15 | * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
|
---|
16 | * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
|
---|
17 | * の無保証規定を掲載すること.
|
---|
18 | * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
|
---|
19 | * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
|
---|
20 | * と.
|
---|
21 | * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
|
---|
22 | * 作権表示,この利用条件および下記の無保証規定を掲載すること.
|
---|
23 | * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
|
---|
24 | * 報告すること.
|
---|
25 | * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
|
---|
26 | * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
|
---|
27 | * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
|
---|
28 | * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
|
---|
29 | * 免責すること.
|
---|
30 | *
|
---|
31 | * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
|
---|
32 | * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
|
---|
33 | * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
|
---|
34 | * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
|
---|
35 | * の責任を負わない.
|
---|
36 | *
|
---|
37 | * @(#) $Id$
|
---|
38 | */
|
---|
39 |
|
---|
40 | #ifndef RX62NRegH
|
---|
41 | #define RX62NRegH
|
---|
42 |
|
---|
43 | #include "t_stddef.h"
|
---|
44 |
|
---|
45 | #define EDMAC_EDMR ((uint32_t *)0x000C0000) /* EDMACモードレジスタ */
|
---|
46 | #define EDMAC_EDMR_SWR_BIT 0x00000001
|
---|
47 | #define EDMAC_EDMR_DE_BIT 0x00000040
|
---|
48 |
|
---|
49 | #define EDMAC_EDTRR ((uint32_t *)0x000C0008) /* EDMAC送信要求レジスタ */
|
---|
50 | #define EDMAC_EDTRR_TR 0x00000001
|
---|
51 |
|
---|
52 | #define EDMAC_EDRRR ((uint32_t *)0x000C0010) /* EDMAC受信要求レジスタ */
|
---|
53 | #define EDMAC_EDRRR_RR 0x00000001
|
---|
54 |
|
---|
55 | #define EDMAC_TDLAR ((uint32_t *)0x000C0018) /* 送信ディスクリプタリスト先頭アドレスレジスタ */
|
---|
56 | #define EDMAC_RDLAR ((uint32_t *)0x000C0020) /* 受信ディスクリプタリスト先頭アドレスレジスタ */
|
---|
57 |
|
---|
58 | #define EDMAC_EESR ((uint32_t *)0x000C0028) /* ETHERC/EDMACステータスレジスタ */
|
---|
59 | #define EDMAC_EESR_FROF 0x00010000
|
---|
60 | #define EDMAC_EESR_RDE 0x00020000
|
---|
61 | #define EDMAC_EESR_FR 0x00040000
|
---|
62 | #define EDMAC_EESR_TC 0x00200000
|
---|
63 | #define EDMAC_EESR_TWB 0x40000000
|
---|
64 |
|
---|
65 | #define EDMAC_EESIPR ((uint32_t *)0x000C0030) /* ETHERC/EDMACステータス割り込み許可レジスタ */
|
---|
66 | #define EDMAC_EESIPR_RMAFIP 0x00000080
|
---|
67 | #define EDMAC_EESIPR_FROFIP 0x00010000
|
---|
68 | #define EDMAC_EESIPR_RDEIP 0x00020000
|
---|
69 | #define EDMAC_EESIPR_FRIP 0x00040000
|
---|
70 | #define EDMAC_EESIPR_TCIP 0x00200000
|
---|
71 | #define EDMAC_EESIPR_TWBIP 0x40000000
|
---|
72 |
|
---|
73 | #define EDMAC_TRSCER ((uint32_t *)0x000C0038) /* 送受信ステータスコピー指示レジスタ */
|
---|
74 | #define EDMAC_RMFCR ((uint32_t *)0x000C0040) /* ミスドフレームカウンタレジスタ */
|
---|
75 | #define EDMAC_TFTR ((uint32_t *)0x000C0048) /* 送信FIFOしきい値指定レジスタ */
|
---|
76 | #define EDMAC_FDR ((uint32_t *)0x000C0050) /* FIFO容量指定レジスタ */
|
---|
77 | #define EDMAC_RMCR ((uint32_t *)0x000C0058) /* 受信方式制御レジスタ */
|
---|
78 | #define EDMAC_TFUCR ((uint32_t *)0x000C0064) /* 送信FIFOアンダランカウント */
|
---|
79 | #define EDMAC_RFOCR ((uint32_t *)0x000C0068) /* 受信FIFOオーバフローカウント */
|
---|
80 | #define EDMAC_IOSR ((uint32_t *)0x000C006C) /* 個別出力信号設定レジスタ */
|
---|
81 | #define EDMAC_FCFTR ((uint32_t *)0x000C0070) /* フロー制御開始FIFOしきい値設定レジスタ */
|
---|
82 | #define EDMAC_RPADIR ((uint32_t *)0x000C0078) /* 受信データパディング挿入設定レジスタ */
|
---|
83 | #define EDMAC_TRIMD ((uint32_t *)0x000C007C) /* 送信割り込み設定レジスタ */
|
---|
84 | #define EDMAC_RBWAR ((uint32_t *)0x000C00C8) /* 受信バッファライトアドレスレジスタ */
|
---|
85 | #define EDMAC_RDFAR ((uint32_t *)0x000C00CC) /* 受信ディスクリプタフェッチアドレスレジスタ */
|
---|
86 | #define EDMAC_TBRAR ((uint32_t *)0x000C00D4) /* 送信バッファリードアドレスレジスタ */
|
---|
87 | #define EDMAC_TDFAR ((uint32_t *)0x000C00D8) /* 送信ディスクリプタフェッチアドレスレジスタ */
|
---|
88 |
|
---|
89 | #define ETHERC_ECMR ((uint32_t *)0x000C0100) /* ETHERCモードレジスタ */
|
---|
90 | #define ETHERC_ECMR_PRM 0x00000001
|
---|
91 | #define ETHERC_ECMR_DM 0x00000002
|
---|
92 | #define ETHERC_ECMR_RTM 0x00000004
|
---|
93 | #define ETHERC_ECMR_TE 0x00000020
|
---|
94 | #define ETHERC_ECMR_RE 0x00000040
|
---|
95 |
|
---|
96 | #define ETHERC_RFLR ((uint32_t *)0x000C0108) /* 受信フレーム長上限レジスタ */
|
---|
97 | #define ETHERC_ECSR ((uint32_t *)0x000C0110) /* ETHERCステータスレジスタ */
|
---|
98 | #define ETHERC_ECSR_LCHNG 0x00000004
|
---|
99 | #define ETHERC_ECSIPR ((uint32_t *)0x000C0118) /* ETHERC割り込み許可レジスタ */
|
---|
100 | #define ETHERC_ECSIPR_LCHNGIP 0x00000004
|
---|
101 | #define ETHERC_PIR ((uint32_t *)0x000C0120) /* PHY部インタフェースレジスタ */
|
---|
102 | #define ETHERC_PIR_MDC 0x00000001
|
---|
103 | #define ETHERC_PIR_MMD 0x00000002
|
---|
104 | #define ETHERC_PIR_MDO 0x00000004
|
---|
105 | #define ETHERC_PIR_MDI 0x00000008
|
---|
106 |
|
---|
107 | #define ETHERC_PSR ((uint32_t *)0x000C0128) /* PHY部ステータスレジスタ */
|
---|
108 | #define ETHERC_PSR_LMON 0x00000001
|
---|
109 |
|
---|
110 | #define ETHERC_RDMLR ((uint32_t *)0x000C0140) /* 乱数生成カウンタ上限値設定レジスタ */
|
---|
111 | #define ETHERC_IPGR ((uint32_t *)0x000C0150) /* IPG設定レジスタ */
|
---|
112 | #define ETHERC_APR ((uint32_t *)0x000C0154) /* 自動PAUSEフレーム設定レジスタ */
|
---|
113 | #define ETHERC_MPR ((uint32_t *)0x000C0158) /* 手動PAUSEフレーム設定レジスタ */
|
---|
114 | #define ETHERC_RFCF ((uint32_t *)0x000C0160) /* 受信PAUSEフレームカウンタ */
|
---|
115 | #define ETHERC_TPAUSER ((uint32_t *)0x000C0164) /* 自動PAUSEフレーム再送回数設定レジスタ */
|
---|
116 | #define ETHERC_TPAUSECR ((uint32_t *)0x000C0168) /* PAUSEフレーム再送回数カウンタ */
|
---|
117 | #define ETHERC_BCFRR ((uint32_t *)0x000C016C) /* Broadcastフレーム受信回数設定レジスタ */
|
---|
118 | #define ETHERC_MAHR ((uint32_t *)0x000C01C0) /* MACアドレス上位設定レジスタ */
|
---|
119 | #define ETHERC_MALR ((uint32_t *)0x000C01C8) /* MACアドレス下位設定レジスタ */
|
---|
120 | #define ETHERC_TROCR ((uint32_t *)0x000C01D0) /* 送信リトライオーバカウンタレジスタ */
|
---|
121 | #define ETHERC_CDCR ((uint32_t *)0x000C01D4) /* 遅延衝突検出カウンタレジスタ */
|
---|
122 | #define ETHERC_LCCR ((uint32_t *)0x000C01D8) /* キャリア消失カウンタレジスタ */
|
---|
123 | #define ETHERC_CNDCR ((uint32_t *)0x000C01DC) /* キャリア未検出カウンタレジスタ */
|
---|
124 | #define ETHERC_CEFCR ((uint32_t *)0x000C01E4) /* CRCエラーフレーム受信カウンタレジスタ */
|
---|
125 | #define ETHERC_FRECR ((uint32_t *)0x000C01E8) /* フレーム受信エラーカウンタレジスタ */
|
---|
126 | #define ETHERC_TSFRCR ((uint32_t *)0x000C01EC) /* 64バイト未満フレーム受信カウンタレジスタ */
|
---|
127 | #define ETHERC_TLFRCR ((uint32_t *)0x000C01F0) /* 指定バイト超フレーム受信カウンタレジスタ */
|
---|
128 | #define ETHERC_RFCR ((uint32_t *)0x000C01F4) /* 端数ビットフレーム受信カウンタレジスタ */
|
---|
129 | #define ETHERC_MAFCR ((uint32_t *)0x000C01F8) /* マルチキャストアドレスフレーム受信カウンタレジスタ */
|
---|
130 |
|
---|
131 | /* 送信ディスクリプタ */
|
---|
132 | typedef struct t_rx62n_tx_desc {
|
---|
133 | uint32_t tfs : 26;
|
---|
134 | uint32_t twbi : 1;
|
---|
135 | uint32_t tfe : 1;
|
---|
136 | uint32_t tfp : 2;
|
---|
137 | uint32_t tdle : 1;
|
---|
138 | uint32_t tact : 1;
|
---|
139 | uint32_t : 16;
|
---|
140 | uint32_t tbl : 16;
|
---|
141 | uint32_t tba;
|
---|
142 | uint32_t binding;
|
---|
143 | } T_RX62N_TX_DESC;
|
---|
144 |
|
---|
145 | /* 受信ディスクリプタ */
|
---|
146 | typedef struct t_rx62n_rx_desc {
|
---|
147 | uint32_t rfs : 27;
|
---|
148 | uint32_t rfe : 1;
|
---|
149 | uint32_t rfp : 2;
|
---|
150 | uint32_t rdle : 1;
|
---|
151 | uint32_t ract : 1;
|
---|
152 | uint32_t rfl : 16;
|
---|
153 | uint32_t rbl : 16;
|
---|
154 | uint32_t rba;
|
---|
155 | uint32_t binding;
|
---|
156 | } T_RX62N_RX_DESC;
|
---|
157 |
|
---|
158 | #endif /* RX62NRegH */
|
---|