OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [packages/] [hal/] [powerpc/] [quicc/] [v2_0/] [include/] [ppc8xx.h] - Blame information for rev 279

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 27 unneback
#ifndef CYGONCE_HAL_PPC_QUICC_PPC8XX_H
2
#define CYGONCE_HAL_PPC_QUICC_PPC8XX_H
3
 
4
//==========================================================================
5
//
6
//      ppc8xx.h
7
//
8
//      PowerPC QUICC register definitions
9
//
10
//==========================================================================
11
//####ECOSGPLCOPYRIGHTBEGIN####
12
// -------------------------------------------
13
// This file is part of eCos, the Embedded Configurable Operating System.
14
// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.
15
// Copyright (C) 2002, 2003 Gary Thomas
16
//
17
// eCos is free software; you can redistribute it and/or modify it under
18
// the terms of the GNU General Public License as published by the Free
19
// Software Foundation; either version 2 or (at your option) any later version.
20
//
21
// eCos is distributed in the hope that it will be useful, but WITHOUT ANY
22
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
23
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
24
// for more details.
25
//
26
// You should have received a copy of the GNU General Public License along
27
// with eCos; if not, write to the Free Software Foundation, Inc.,
28
// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
29
//
30
// As a special exception, if other files instantiate templates or use macros
31
// or inline functions from this file, or you compile this file and link it
32
// with other works to produce a work based on this file, this file does not
33
// by itself cause the resulting work to be covered by the GNU General Public
34
// License. However the source code for this file must still be made available
35
// in accordance with section (3) of the GNU General Public License.
36
//
37
// This exception does not invalidate any other reasons why a work based on
38
// this file might be covered by the GNU General Public License.
39
//
40
// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.
41
// at http://sources.redhat.com/ecos/ecos-license/
42
// -------------------------------------------
43
//####ECOSGPLCOPYRIGHTEND####
44
//==========================================================================
45
//#####DESCRIPTIONBEGIN####
46
//
47
// Author(s):    Red Hat
48
// Contributors: hmt
49
// Date:         1999-06-08
50
// Purpose:      Provide PPC QUICC definitions
51
// Description:  Provide PPC QUICC definitions
52
// Usage:        THIS IS NOT AN EXTERNAL API
53
//               This file is in the include dir to share it between
54
//               QUICC serial code and MBX initialization code.
55
//               #include <cyg/hal/quicc/ppc8xx.h>
56
//               ...
57
//              
58
//
59
//####DESCRIPTIONEND####
60
//
61
//==========================================================================
62
 
63
#ifdef __ASSEMBLER__
64
 
65
#define SIUMCR     0x000        /* SIU Module configuration */
66
#define SYPCR      0x004        /* SIU System Protection Control */
67
#define SIPEND     0x010        /* SIU Interrupt Pending Register */
68
#define SIMASK     0x014        /* SIU Interrupt MASK Register */
69
#define SIEL       0x018        /* SIU Interrupt Edge/Level Register */
70
#define SIVEC      0x01C        /* SIU Interrupt Vector Register */
71
#define SDCR       0x030        /* SDMA Config Register */
72
#define BR0        0x100        /* Base Register 0 */
73
#define OR0        0x104        /* Option Register 0 */
74
#define BR1        0x108        /* Base Register 1 */
75
#define OR1        0x10C        /* Option Register 1 */
76
#define BR2        0x110        /* Base Register 2 */
77
#define OR2        0x114        /* Option Register 2 */
78
#define BR3        0x118        /* Base Register 2 */
79
#define OR3        0x11C        /* Option Register 2 */
80
#define BR4        0x120        /* Base Register 2 */
81
#define OR4        0x124        /* Option Register 2 */
82
#define BR5        0x128        /* Base Register 2 */
83
#define OR5        0x12C        /* Option Register 2 */
84
#define BR6        0x130        /* Base Register 2 */
85
#define OR6        0x134        /* Option Register 2 */
86
#define BR7        0x138        /* Base Register 2 */
87
#define OR7        0x13C        /* Option Register 2 */
88
#define MAR        0x164        /* Memory Address */
89
#define MCR        0x168        /* Memory Command */
90
#define MAMR       0x170        /* Machine A Mode Register */
91
#define MBMR       0x174        /* Machine B Mode Register */
92
#define MPTPR      0x17A        /* Memory Periodic Timer Prescaler */
93
#define MDR        0x17C        /* Memory Data */
94
#define TBSCR      0x200        /* Time Base Status and Control Register */
95
#define RTCSC      0x220        /* Real Timer Clock Status and Control */
96
#define PISCR      0x240        /* PIT Status and Control */
97
#define SCCR       0x280        /* System Clock Control Register */
98
#define PLPRCR     0x284        /* PLL, Low power & Reset Control Register */
99
#define RTCSCK     0x320
100
#define RTCK       0x324
101
#define RTSECK     0x328
102
#define RTCALK     0x32C
103
#define PADIR      0x950        /* Port A - Pin direction */
104
#define PAPAR      0x952        /* Port A - Pin assignment */
105
#define PAODR      0x954        /* Port A - Open Drain Control */
106
#define PADAT      0x956        /* Port A - Data */
107
 
108
#else
109
 
110
#include <cyg/infra/cyg_type.h>
111
 
112
/*****************************************************************
113
        Communications Processor Buffer Descriptor
114
*****************************************************************/
115
struct cp_bufdesc {
116
    volatile unsigned short ctrl;       /* status/control register */
117
    volatile unsigned short length;     /* buffer length */
118
    volatile char           *buffer;    /* buffer pointer */
119
};
120
 
121
/*****************************************************************
122
        HDLC parameter RAM
123
*****************************************************************/
124
 
125
struct hdlc_pram {
126
    /*
127
     * SCC parameter RAM
128
     */
129
    unsigned short      rbase;          /* RX BD base address */
130
    unsigned short      tbase;          /* TX BD base address */
131
    unsigned char       rfcr;           /* Rx function code */
132
    unsigned char       tfcr;           /* Tx function code */
133
    unsigned short      mrblr;          /* Rx buffer length */
134
    unsigned long       rstate;         /* Rx internal state */
135
    unsigned long       rptr;           /* Rx internal data pointer */
136
    unsigned short      rbptr;          /* rb BD Pointer */
137
    unsigned short      rcount;         /* Rx internal byte count */
138
    unsigned long       rtemp;          /* Rx temp */
139
    unsigned long       tstate;         /* Tx internal state */
140
    unsigned long       tptr;           /* Tx internal data pointer */
141
    unsigned short      tbptr;          /* Tx BD pointer */
142
    unsigned short      tcount;         /* Tx byte count */
143
    unsigned long       ttemp;          /* Tx temp */
144
    unsigned long       rcrc;           /* temp receive CRC */
145
    unsigned long       tcrc;           /* temp transmit CRC */
146
 
147
    /*
148
     * HDLC specific parameter RAM
149
     */
150
    unsigned char       RSRVD1[4];
151
    unsigned long       c_mask;         /* CRC constant */
152
    unsigned long       c_pres;         /* CRC preset */
153
    unsigned short      disfc;          /* discarded frame counter */
154
    unsigned short      crcec;          /* CRC error counter */
155
    unsigned short      abtsc;          /* abort sequence counter */
156
    unsigned short      nmarc;          /* nonmatching address rx cnt */
157
    unsigned short      retrc;          /* frame retransmission cnt */
158
    unsigned short      mflr;           /* maximum frame length reg */
159
    unsigned short      max_cnt;        /* maximum length counter */
160
    unsigned short      rfthr;          /* received frames threshold */
161
    unsigned short      rfcnt;          /* received frames count */
162
    unsigned short      hmask;          /* user defined frm addr mask */
163
    unsigned short      haddr1;         /* user defined frm address 1 */
164
    unsigned short      haddr2;         /* user defined frm address 2 */
165
    unsigned short      haddr3;         /* user defined frm address 3 */
166
    unsigned short      haddr4;         /* user defined frm address 4 */
167
    unsigned short      tmp;            /* temp */
168
    unsigned short      tmp_mb;         /* temp */
169
};
170
 
171
 
172
/*****************************************************************
173
        ASYNC HDLC parameter RAM
174
*****************************************************************/
175
 
176
struct async_hdlc_pram {
177
    /*
178
     * SCC parameter RAM
179
     */
180
    unsigned short      rbase;          /* RX BD base address */
181
    unsigned short      tbase;          /* TX BD base address */
182
    unsigned char       rfcr;           /* Rx function code */
183
    unsigned char       tfcr;           /* Tx function code */
184
    unsigned short      mrblr;          /* Rx buffer length */
185
    unsigned long       rstate;         /* Rx internal state */
186
    unsigned long       rptr;           /* Rx internal data pointer */
187
    unsigned short      rbptr;          /* rb BD Pointer */
188
    unsigned short      rcount;         /* Rx internal byte count */
189
    unsigned long       rtemp;          /* Rx temp */
190
    unsigned long       tstate;         /* Tx internal state */
191
    unsigned long       tptr;           /* Tx internal data pointer */
192
    unsigned short      tbptr;          /* Tx BD pointer */
193
    unsigned short      tcount;         /* Tx byte count */
194
    unsigned long       ttemp;          /* Tx temp */
195
    unsigned long       rcrc;           /* temp receive CRC */
196
    unsigned long       tcrc;           /* temp transmit CRC */
197
 
198
    /*
199
     * ASYNC HDLC specific parameter RAM
200
     */
201
    unsigned char       RSRVD1[4];
202
    unsigned long       c_mask;         /* CRC constant */
203
    unsigned long       c_pres;         /* CRC preset */
204
    unsigned short      bof;            /* begining of flag character */
205
    unsigned short      eof;            /* end of flag character */
206
    unsigned short      esc;            /* control escape character */
207
    unsigned char       RSRVD2[4];
208
    unsigned short      zero;           /* zero */
209
    unsigned char       RSRVD3[2];
210
    unsigned short      rfthr;          /* received frames threshold */
211
    unsigned char       RSRVD4[4];
212
    unsigned long       txctl_tbl;      /* Tx ctl char mapping table */
213
    unsigned long       rxctl_tbl;      /* Rx ctl char mapping table */
214
    unsigned short      nof;            /* Number of opening flags */
215
};
216
 
217
 
218
/*****************************************************************
219
        UART parameter RAM
220
*****************************************************************/
221
 
222
/*
223
 * bits in uart control characters table
224
 */
225
#define CC_INVALID      0x8000          /* control character is valid */
226
#define CC_REJ          0x4000          /* don't store char in buffer */
227
#define CC_CHAR         0x00ff          /* control character */
228
 
229
/* UART */
230
struct uart_pram {
231
    /*
232
     * SCC parameter RAM
233
     */
234
    unsigned short      rbase;          /* RX BD base address */
235
    unsigned short      tbase;          /* TX BD base address */
236
    unsigned char       rfcr;           /* Rx function code */
237
    unsigned char       tfcr;           /* Tx function code */
238
    unsigned short      mrblr;          /* Rx buffer length */
239
    unsigned long       rstate;         /* Rx internal state */
240
    unsigned long       rptr;           /* Rx internal data pointer */
241
    unsigned short      rbptr;          /* rb BD Pointer */
242
    unsigned short      rcount;         /* Rx internal byte count */
243
    unsigned long       rx_temp;        /* Rx temp */
244
    unsigned long       tstate;         /* Tx internal state */
245
    unsigned long       tptr;           /* Tx internal data pointer */
246
    unsigned short      tbptr;          /* Tx BD pointer */
247
    unsigned short      tcount;         /* Tx byte count */
248
    unsigned long       ttemp;          /* Tx temp */
249
    unsigned long       rcrc;           /* temp receive CRC */
250
    unsigned long       tcrc;           /* temp transmit CRC */
251
 
252
    /*
253
     * UART specific parameter RAM
254
     */
255
    unsigned char       RSRVD1[8];
256
    unsigned short      max_idl;        /* maximum idle characters */
257
    unsigned short      idlc;           /* rx idle counter (internal) */
258
    unsigned short      brkcr;          /* break count register */
259
 
260
    unsigned short      parec;          /* Rx parity error counter */
261
    unsigned short      frmer;          /* Rx framing error counter */
262
    unsigned short      nosec;          /* Rx noise counter */
263
    unsigned short      brkec;          /* Rx break character counter */
264
    unsigned short      brkln;          /* Reaceive break length */
265
 
266
    unsigned short      uaddr1;         /* address character 1 */
267
    unsigned short      uaddr2;         /* address character 2 */
268
    unsigned short      rtemp;          /* temp storage */
269
    unsigned short      toseq;          /* Tx out of sequence char */
270
    unsigned short      cc[8];          /* Rx control characters */
271
    unsigned short      rccm;           /* Rx control char mask */
272
    unsigned short      rccr;           /* Rx control char register */
273
    unsigned short      rlbc;           /* Receive last break char */
274
};
275
 
276
 
277
 
278
/*****************************************************************
279
        BISYNC parameter RAM
280
*****************************************************************/
281
 
282
struct bisync_pram {
283
    /*
284
     * SCC parameter RAM
285
     */
286
    unsigned short      rbase;          /* RX BD base address */
287
    unsigned short      tbase;          /* TX BD base address */
288
    unsigned char       rfcr;           /* Rx function code */
289
    unsigned char       tfcr;           /* Tx function code */
290
    unsigned short      mrblr;          /* Rx buffer length */
291
    unsigned long       rstate;         /* Rx internal state */
292
    unsigned long       rptr;           /* Rx internal data pointer */
293
    unsigned short      rbptr;          /* rb BD Pointer */
294
    unsigned short      rcount;         /* Rx internal byte count */
295
    unsigned long       rtemp;          /* Rx temp */
296
    unsigned long       tstate;         /* Tx internal state */
297
    unsigned long       tptr;           /* Tx internal data pointer */
298
    unsigned short      tbptr;          /* Tx BD pointer */
299
    unsigned short      tcount;         /* Tx byte count */
300
    unsigned long       ttemp;          /* Tx temp */
301
    unsigned long       rcrc;           /* temp receive CRC */
302
    unsigned long       tcrc;           /* temp transmit CRC */
303
 
304
    /*
305
     * BISYNC specific parameter RAM
306
     */
307
    unsigned char       RSRVD1[4];
308
    unsigned long       crcc;           /* CRC Constant Temp Value */
309
    unsigned short      prcrc;          /* Preset Receiver CRC-16/LRC */
310
    unsigned short      ptcrc;          /* Preset Transmitter CRC-16/LRC */
311
    unsigned short      parec;          /* Receive Parity Error Counter */
312
    unsigned short      bsync;          /* BISYNC SYNC Character */
313
    unsigned short      bdle;           /* BISYNC DLE Character */
314
    unsigned short      cc[8];          /* Rx control characters */
315
    unsigned short      rccm;           /* Receive Control Character Mask */
316
};
317
 
318
/*****************************************************************
319
        IOM2 parameter RAM
320
        (overlaid on tx bd[5] of SCC channel[2])
321
*****************************************************************/
322
struct iom2_pram {
323
    unsigned short      ci_data;        /* ci data */
324
    unsigned short      monitor_data;   /* monitor data */
325
    unsigned short      tstate;         /* transmitter state */
326
    unsigned short      rstate;         /* receiver state */
327
};
328
 
329
/*****************************************************************
330
        SPI/SMC parameter RAM
331
        (overlaid on tx bd[6,7] of SCC channel[2])
332
*****************************************************************/
333
 
334
#define SPI_R   0x8000          /* Ready bit in BD */
335
 
336
struct spi_pram {
337
    unsigned short      rbase;          /* Rx BD Base Address */
338
    unsigned short      tbase;          /* Tx BD Base Address */
339
    unsigned char       rfcr;           /* Rx function code */
340
    unsigned char       tfcr;           /* Tx function code */
341
    unsigned short      mrblr;          /* Rx buffer length */
342
    unsigned long       rstate;         /* Rx internal state */
343
    unsigned long       rptr;           /* Rx internal data pointer */
344
    unsigned short      rbptr;          /* rb BD Pointer */
345
    unsigned short      rcount;         /* Rx internal byte count */
346
    unsigned long       rtemp;          /* Rx temp */
347
    unsigned long       tstate;         /* Tx internal state */
348
    unsigned long       tptr;           /* Tx internal data pointer */
349
    unsigned short      tbptr;          /* Tx BD pointer */
350
    unsigned short      tcount;         /* Tx byte count */
351
    unsigned long       ttemp;          /* Tx temp */
352
};
353
 
354
struct smc_uart_pram {
355
    unsigned short      rbase;          /* Rx BD Base Address */
356
    unsigned short      tbase;          /* Tx BD Base Address */
357
    unsigned char       rfcr;           /* Rx function code */
358
    unsigned char       tfcr;           /* Tx function code */
359
    unsigned short      mrblr;          /* Rx buffer length */
360
    unsigned long       rstate;         /* Rx internal state */
361
    unsigned long       rptr;           /* Rx internal data pointer */
362
    unsigned short      rbptr;          /* rb BD Pointer */
363
    unsigned short      rcount;         /* Rx internal byte count */
364
    unsigned long       rtemp;          /* Rx temp */
365
    unsigned long       tstate;         /* Tx internal state */
366
    unsigned long       tptr;           /* Tx internal data pointer */
367
    unsigned short      tbptr;          /* Tx BD pointer */
368
    unsigned short      tcount;         /* Tx byte count */
369
    unsigned long       ttemp;          /* Tx temp */
370
    unsigned short      max_idl;        /* Maximum IDLE Characters */
371
    unsigned short      idlc;           /* Temporary IDLE Counter */
372
    unsigned short      brkln;          /* Last Rx Break Length */
373
    unsigned short      brkec;          /* Rx Break Condition Counter */
374
    unsigned short      brkcr;          /* Break Count Register (Tx) */
375
    unsigned short      r_mask;         /* Temporary bit mask */
376
};
377
 
378
struct smc_trnsp_pram {
379
    unsigned short      rbase;          /* Rx BD Base Address */
380
    unsigned short      tbase;          /* Tx BD Base Address */
381
    unsigned char       rfcr;           /* Rx function code */
382
    unsigned char       tfcr;           /* Tx function code */
383
    unsigned short      mrblr;          /* Rx buffer length */
384
    unsigned long       rstate;         /* Rx internal state */
385
    unsigned long       rptr;           /* Rx internal data pointer */
386
    unsigned short      rbptr;          /* rb BD Pointer */
387
    unsigned short      rcount;         /* Rx internal byte count */
388
    unsigned long       rtemp;          /* Rx temp */
389
    unsigned long       tstate;         /* Tx internal state */
390
    unsigned long       tptr;           /* Tx internal data pointer */
391
    unsigned short      tbptr;          /* Tx BD pointer */
392
    unsigned short      tcount;         /* Tx byte count */
393
    unsigned long       ttemp;          /* Tx temp */
394
    unsigned short      RSRVD[5];       /* RSRVD */
395
};
396
 
397
struct centronics_pram {
398
    unsigned short      rbase;          /* Rx BD Base Address */
399
    unsigned short      tbase;          /* Tx BD Base Address */
400
    unsigned char       fcr;            /* function code */
401
    unsigned char       smask;          /* Status Mask */
402
    unsigned short      mrblr;          /* Rx buffer length */
403
    unsigned long       rstate;         /* Rx internal state */
404
    unsigned long       rptr;           /* Rx internal data pointer */
405
    unsigned short      rbptr;          /* rb BD Pointer */
406
    unsigned short      rcount;         /* Rx internal byte count */
407
    unsigned long       rtemp;          /* Rx temp */
408
    unsigned long       tstate;         /* Tx internal state */
409
    unsigned long       tptr;           /* Tx internal data pointer */
410
    unsigned short      tbptr;          /* Tx BD pointer */
411
    unsigned short      tcount;         /* Tx byte count */
412
    unsigned long       ttemp;          /* Tx temp */
413
    unsigned short      max_sl;         /* Maximum Silence period */
414
    unsigned short      sl_cnt;         /* Silence Counter */
415
    unsigned short      char1;          /* CONTROL char 1 */
416
    unsigned short      char2;          /* CONTROL char 2 */
417
    unsigned short      char3;          /* CONTROL char 3 */
418
    unsigned short      char4;          /* CONTROL char 4 */
419
    unsigned short      char5;          /* CONTROL char 5 */
420
    unsigned short      char6;          /* CONTROL char 6 */
421
    unsigned short      char7;          /* CONTROL char 7 */
422
    unsigned short      char8;          /* CONTROL char 8 */
423
    unsigned short      rccm;           /* Rx Control Char Mask */
424
    unsigned short      rccr;           /* Rx Char Control Register */
425
};
426
 
427
struct idma_pram {
428
    unsigned short      ibase;          /* IDMA BD Base Address */
429
    unsigned short      ibptr;          /* IDMA buffer descriptor pointer */
430
    unsigned long       istate;         /* IDMA internal state */
431
    unsigned long       itemp;          /* IDMA temp */
432
};
433
 
434
struct ethernet_pram {
435
    /*
436
     * SCC parameter RAM
437
     */
438
    unsigned short      rbase;          /* RX BD base address */
439
    unsigned short      tbase;          /* TX BD base address */
440
    unsigned char       rfcr;           /* Rx function code */
441
    unsigned char       tfcr;           /* Tx function code */
442
    unsigned short      mrblr;          /* Rx buffer length */
443
    unsigned long       rstate;         /* Rx internal state */
444
    unsigned long       rptr;           /* Rx internal data pointer */
445
    unsigned short      rbptr;          /* rb BD Pointer */
446
    unsigned short      rcount;         /* Rx internal byte count */
447
    unsigned long       rtemp;          /* Rx temp */
448
    unsigned long       tstate;         /* Tx internal state */
449
    unsigned long       tptr;           /* Tx internal data pointer */
450
    unsigned short      tbptr;          /* Tx BD pointer */
451
    unsigned short      tcount;         /* Tx byte count */
452
    unsigned long       ttemp;          /* Tx temp */
453
    unsigned long       rcrc;           /* temp receive CRC */
454
    unsigned long       tcrc;           /* temp transmit CRC */
455
 
456
    /*
457
     * ETHERNET specific parameter RAM
458
     */
459
    unsigned long       c_pres;         /* preset CRC */
460
    unsigned long       c_mask;         /* constant mask for CRC */
461
    unsigned long       crcec;          /* CRC error counter */
462
    unsigned long       alec;           /* alighnment error counter */
463
    unsigned long       disfc;          /* discard frame counter */
464
    unsigned short      pads;           /* short frame PAD characters */
465
    unsigned short      ret_lim;        /* retry limit threshold */
466
    unsigned short      ret_cnt;        /* retry limit counter */
467
    unsigned short      mflr;           /* maximum frame length reg */
468
    unsigned short      minflr;         /* minimum frame length reg */
469
    unsigned short      maxd1;          /* maximum DMA1 length reg */
470
    unsigned short      maxd2;          /* maximum DMA2 length reg */
471
    unsigned short      maxd;           /* rx max DMA */
472
    unsigned short      dma_cnt;        /* rx dma counter */
473
    unsigned short      max_b;          /* max bd byte count */
474
    unsigned short      gaddr1;         /* group address filter 1 */
475
    unsigned short      gaddr2;         /* group address filter 2 */
476
    unsigned short      gaddr3;         /* group address filter 3 */
477
    unsigned short      gaddr4;         /* group address filter 4 */
478
    unsigned long       tbuf0_data0;    /* save area 0 - current frm */
479
    unsigned long       tbuf0_data1;    /* save area 1 - current frm */
480
    unsigned long       tbuf0_rba0;
481
    unsigned long       tbuf0_crc;
482
    unsigned short      tbuf0_bcnt;
483
    unsigned short      paddr_h;        /* physical address (MSB) */
484
    unsigned short      paddr_m;        /* physical address */
485
    unsigned short      paddr_l;        /* physical address (LSB) */
486
    unsigned short      p_per;          /* persistence */
487
    unsigned short      rfbd_ptr;       /* rx first bd pointer */
488
    unsigned short      tfbd_ptr;       /* tx first bd pointer */
489
    unsigned short      tlbd_ptr;       /* tx last bd pointer */
490
    unsigned long       tbuf1_data0;    /* save area 0 - next frame */
491
    unsigned long       tbuf1_data1;    /* save area 1 - next frame */
492
    unsigned long       tbuf1_rba0;
493
    unsigned long       tbuf1_crc;
494
    unsigned short      tbuf1_bcnt;
495
    unsigned short      tx_len;         /* tx frame length counter */
496
    unsigned short      iaddr1;         /* individual address filter 1*/
497
    unsigned short      iaddr2;         /* individual address filter 2*/
498
    unsigned short      iaddr3;         /* individual address filter 3*/
499
    unsigned short      iaddr4;         /* individual address filter 4*/
500
    unsigned short      boff_cnt;       /* back-off counter */
501
    unsigned short      taddr_h;        /* temp address (MSB) */
502
    unsigned short      taddr_m;        /* temp address */
503
    unsigned short      taddr_l;        /* temp address (LSB) */
504
};
505
 
506
struct transparent_pram {
507
    /*
508
     * SCC parameter RAM
509
     */
510
    unsigned short      rbase;          /* RX BD base address */
511
    unsigned short      tbase;          /* TX BD base address */
512
    unsigned char       rfcr;           /* Rx function code */
513
    unsigned char       tfcr;           /* Tx function code */
514
    unsigned short      mrblr;          /* Rx buffer length */
515
    unsigned long       rstate;         /* Rx internal state */
516
    unsigned long       rptr;           /* Rx internal data pointer */
517
    unsigned short      rbptr;          /* rb BD Pointer */
518
    unsigned short      rcount;         /* Rx internal byte count */
519
    unsigned long       rtemp;          /* Rx temp */
520
    unsigned long       tstate;         /* Tx internal state */
521
    unsigned long       tptr;           /* Tx internal data pointer */
522
    unsigned short      tbptr;          /* Tx BD pointer */
523
    unsigned short      tcount;         /* Tx byte count */
524
    unsigned long       ttemp;          /* Tx temp */
525
    unsigned long       rcrc;           /* temp receive CRC */
526
    unsigned long       tcrc;           /* temp transmit CRC */
527
 
528
    /*
529
     * TRANSPARENT specific parameter RAM
530
     */
531
    unsigned long       crc_p;          /* CRC Preset */
532
    unsigned long       crc_c;          /* CRC constant */
533
};
534
 
535
struct timer_pram {
536
    /*
537
     * RISC timers parameter RAM
538
     */
539
    unsigned short      tm_base;        /* RISC timer table base adr */
540
    unsigned short      tm_ptr;         /* RISC timer table pointer */
541
    unsigned short      r_tmr;          /* RISC timer mode register */
542
    unsigned short      r_tmv;          /* RISC timer valid register */
543
    unsigned long       tm_cmd;         /* RISC timer cmd register */
544
    unsigned long       tm_cnt;         /* RISC timer internal cnt */
545
};
546
 
547
struct ucode_pram {
548
    /*
549
     * RISC ucode parameter RAM
550
     */
551
    unsigned short      rev_num;        /* Ucode Revision Number */
552
    unsigned short      d_ptr;          /* MISC Dump area pointer */
553
    unsigned long       temp1;          /* MISC Temp1 */
554
    unsigned long       temp2;          /* MISC Temp2 */
555
};
556
 
557
struct i2c_pram {
558
    /*
559
     * I2C parameter RAM
560
     */
561
    unsigned short      rbase;          /* RX BD base address */
562
    unsigned short      tbase;          /* TX BD base address */
563
    unsigned char       rfcr;           /* Rx function code */
564
    unsigned char       tfcr;           /* Tx function code */
565
    unsigned short      mrblr;          /* Rx buffer length */
566
    unsigned long       rstate;         /* Rx internal state */
567
    unsigned long       rptr;           /* Rx internal data pointer */
568
    unsigned short      rbptr;          /* rb BD Pointer */
569
    unsigned short      rcount;         /* Rx internal byte count */
570
    unsigned long       rtemp;          /* Rx temp */
571
    unsigned long       tstate;         /* Tx internal state */
572
    unsigned long       tptr;           /* Tx internal data pointer */
573
    unsigned short      tbptr;          /* Tx BD pointer */
574
    unsigned short      tcount;         /* Tx byte count */
575
    unsigned long       ttemp[2];       /* Tx temp */
576
    unsigned short      rpbase;         /* Relocated param block pointer */
577
    unsigned short      res;            /* unused */
578
};
579
 
580
/*
581
 * definitions of EPPC memory structures
582
 */
583
typedef struct eppc {
584
    /* BASE + 0x0000: INTERNAL REGISTERS */
585
 
586
    /* SIU */
587
    volatile unsigned long      siu_mcr;        /* module configuration reg */
588
    volatile unsigned long      siu_sypcr;      /* System protection cnt */
589
    unsigned char               RSRVD58[0x6];
590
    volatile unsigned short     siu_swsr;       /* sw service */
591
    volatile unsigned long      siu_sipend;     /* Interrupt pend reg */
592
    volatile unsigned long      siu_simask;     /* Interrupt mask reg */
593
    volatile unsigned long      siu_siel;       /* Interrupt edge level mask reg */
594
    volatile unsigned long      siu_sivec;      /* Interrupt vector */
595
    volatile unsigned long      siu_tesr;       /* Transfer error status */
596
    volatile unsigned char      RSRVD1[0xc];
597
    volatile unsigned long      dma_sdcr;       /* SDMA configuration reg */
598
    unsigned char               RSRVD55[0x4c];
599
 
600
    /* PCMCIA */
601
    volatile unsigned long      pcmcia_pbr0;    /* PCMCIA Base Reg: Window 0 */
602
    volatile unsigned long      pcmcia_por0;    /* PCMCIA Option Reg: Window 0 */
603
    volatile unsigned long      pcmcia_pbr1;    /* PCMCIA Base Reg: Window 1 */
604
    volatile unsigned long      pcmcia_por1;    /* PCMCIA Option Reg: Window 1 */
605
    volatile unsigned long      pcmcia_pbr2;    /* PCMCIA Base Reg: Window 2 */
606
    volatile unsigned long      pcmcia_por2;    /* PCMCIA Option Reg: Window 2 */
607
    volatile unsigned long      pcmcia_pbr3;    /* PCMCIA Base Reg: Window 3 */
608
    volatile unsigned long      pcmcia_por3;    /* PCMCIA Option Reg: Window 3 */
609
    volatile unsigned long      pcmcia_pbr4;    /* PCMCIA Base Reg: Window 4 */
610
    volatile unsigned long      pcmcia_por4;    /* PCMCIA Option Reg: Window 4 */
611
    volatile unsigned long      pcmcia_pbr5;    /* PCMCIA Base Reg: Window 5 */
612
    volatile unsigned long      pcmcia_por5;    /* PCMCIA Option Reg: Window 5 */
613
    volatile unsigned long      pcmcia_pbr6;    /* PCMCIA Base Reg: Window 6 */
614
    volatile unsigned long      pcmcia_por6;    /* PCMCIA Option Reg: Window 6 */
615
    volatile unsigned long      pcmcia_pbr7;    /* PCMCIA Base Reg: Window 7 */
616
    volatile unsigned long      pcmcia_por7;    /* PCMCIA Option Reg: Window 7 */
617
    volatile unsigned char      RSRVD2[0x20];
618
    volatile unsigned long      pcmcia_pgcra;   /* PCMCIA Slot A Control  Reg */
619
    volatile unsigned long      pcmcia_pgcrb;   /* PCMCIA Slot B Control  Reg */
620
    volatile unsigned long      pcmcia_pscr;    /* PCMCIA Status Reg */
621
    volatile unsigned char      RSRVD2a[0x4];
622
    volatile unsigned long      pcmcia_pipr;    /* PCMCIA Pins Value Reg */
623
    volatile unsigned char      RSRVD2b[0x4];
624
    volatile unsigned long      pcmcia_per;     /* PCMCIA Enable Reg */
625
    volatile unsigned char      RSRVD2c[0x4];
626
 
627
    /* MEMC */
628
    volatile unsigned long      memc_br0;       /* base register 0 */
629
    volatile unsigned long      memc_or0;       /* option register 0 */
630
    volatile unsigned long      memc_br1;       /* base register 1 */
631
    volatile unsigned long      memc_or1;       /* option register 1 */
632
    volatile unsigned long      memc_br2;       /* base register 2 */
633
    volatile unsigned long      memc_or2;       /* option register 2 */
634
    volatile unsigned long      memc_br3;       /* base register 3 */
635
    volatile unsigned long      memc_or3;       /* option register 3 */
636
    volatile unsigned long      memc_br4;       /* base register 3 */
637
    volatile unsigned long      memc_or4;       /* option register 3 */
638
    volatile unsigned long      memc_br5;       /* base register 3 */
639
    volatile unsigned long      memc_or5;       /* option register 3 */
640
    volatile unsigned long      memc_br6;       /* base register 3 */
641
    volatile unsigned long      memc_or6;       /* option register 3 */
642
    volatile unsigned long      memc_br7;       /* base register 3 */
643
    volatile unsigned long      memc_or7;       /* option register 3 */
644
    volatile unsigned char      RSRVD3[0x24];
645
    volatile unsigned long      memc_mar;       /* Memory address */
646
    volatile unsigned long      memc_mcr;       /* Memory command */
647
    volatile unsigned char      RSRVD4[0x4];
648
    volatile unsigned long      memc_mamr;      /* Machine A mode */
649
    volatile unsigned long      memc_mbmr;      /* Machine B mode */
650
    volatile unsigned short     memc_mstat;     /* Memory status */
651
    volatile unsigned short     memc_mptpr;     /* Memory preidic timer prescalar */
652
    volatile unsigned long      memc_mdr;       /* Memory data */
653
    volatile unsigned char      RSRVD5[0x80];
654
 
655
    /* SYSTEM INTEGRATION TIMERS */
656
    volatile unsigned short     simt_tbscr;     /* Time base stat&ctr */
657
    volatile unsigned char      RSRVD100[0x2];
658
    volatile unsigned long      simt_tbreff0;   /* Time base reference 0 */
659
    volatile unsigned long      simt_tbreff1;   /* Time base reference 1 */
660
    volatile unsigned char      RSRVD6[0x14];
661
    volatile unsigned short     simt_rtcsc;     /* Realtime clk stat&cntr 1 */
662
    volatile unsigned char      RSRVD110[0x2];
663
    volatile unsigned long      simt_rtc;       /* Realtime clock */
664
    volatile unsigned long      simt_rtsec;     /* Realtime alarm seconds */
665
    volatile unsigned long      simt_rtcal;     /* Realtime alarm */
666
    volatile unsigned char      RSRVD56[0x10];
667
    volatile unsigned long      simt_piscr;     /* PIT stat&ctrl */
668
    volatile unsigned long      simt_pitc;      /* PIT counter */
669
    volatile unsigned long      simt_pitr;      /* PIT */
670
    volatile unsigned char      RSRVD7[0x34];
671
 
672
    /* CLOCKS, RESET */
673
    volatile unsigned long      clkr_sccr;      /* System clk cntrl */
674
    volatile unsigned long      clkr_plprcr;    /* PLL reset&ctrl */
675
    volatile unsigned long      clkr_rsr;       /* reset status */
676
    volatile unsigned char      RSRVD66a[0x74];
677
 
678
    /* System Integration Timers Keys */
679
    volatile unsigned long      simt_tbscrk;    /* Timebase Status&Ctrl Key */
680
    volatile unsigned long      simt_tbreff0k;  /* Timebase Reference 0 Key */
681
    volatile unsigned long      simt_tbreff1k;  /* Timebase Reference 1 Key */
682
    volatile unsigned long      simt_tbk;       /* Timebase and Decrementer Key */
683
    volatile unsigned char      RSRVD66b[0x10];
684
    volatile unsigned long      simt_rtcsck;    /* Real-Time Clock Status&Ctrl Key */
685
    volatile unsigned long      simt_rtck;      /* Real-Time Clock Key */
686
    volatile unsigned long      simt_rtseck;    /* Real-Time Alarm Seconds Key */
687
    volatile unsigned long      simt_rtcalk;    /* Real-Time Alarm Key */
688
    volatile unsigned char      RSRVD66c[0x10];
689
    volatile unsigned long      simt_piscrk;    /* Periodic Interrupt Status&Ctrl Key */
690
    volatile unsigned long      simt_pitck;     /* Periodic Interrupt Count Key */
691
    volatile unsigned char      RSRVD66d[0x38];
692
 
693
 
694
    /* Clock and Reset Keys */
695
    volatile unsigned long      clkr_sccrk;     /* System Clock Control Key */
696
    volatile unsigned long      clkr_plprcrk;   /* PLL, Low Power and Reset Control Key */
697
    volatile unsigned long      clkr_rsrk;      /* Reset Status Key */
698
    volatile unsigned char      RSRVD66e[0x4b4];
699
 
700
    volatile unsigned long      lcd_lccr;       /* configuration Reg */
701
    volatile unsigned long      lcd_lchcr;      /* Horizontal ctl Reg */
702
    volatile unsigned long      lcd_lcvcr;      /* Vertical ctl Reg */
703
    unsigned char               RSRVD67[4];
704
    volatile unsigned long      lcd_lcfaa;      /* Frame buffer A Address */
705
    volatile unsigned long      lcd_lcfba;      /* Frame buffer B Address */
706
    volatile unsigned char      lcd_lcsr;       /* Status Reg */
707
    volatile unsigned char      RSRVD9[0x7];
708
 
709
    /* I2C */
710
    volatile unsigned char      i2c_i2mod;      /* i2c mode */
711
    unsigned char               RSRVD59[3];
712
    volatile unsigned char      i2c_i2add;      /* i2c address */
713
    unsigned char               RSRVD60[3];
714
    volatile unsigned char      i2c_i2brg;      /* i2c brg */
715
    unsigned char               RSRVD61[3];
716
    volatile unsigned char      i2c_i2com;      /* i2c command */
717
    unsigned char               RSRVD62[3];
718
    volatile unsigned char      i2c_i2cer;      /* i2c event */
719
    unsigned char               RSRVD63[3];
720
    volatile unsigned char      i2c_i2cmr;      /* i2c mask */
721
    volatile unsigned char      RSRVD10[0x0b];
722
    volatile unsigned char      i2c_spare_pram[0x80];  /* Used by patched ucode */
723
 
724
    /* DMA */
725
    volatile unsigned char      RSRVD11[0x4];
726
    volatile unsigned long      dma_sdar;       /* SDMA address reg */
727
    volatile unsigned char      dma_sdsr;       /* SDMA status reg */
728
    volatile unsigned char      RSRVD12[0x3];
729
    volatile unsigned char      dma_sdmr;       /* SDMA mask reg */
730
    volatile unsigned char      RSRVD13[0x3];
731
    volatile unsigned char      dma_idsr1;      /* IDMA1 status reg */
732
    volatile unsigned char      RSRVD14[0x3];
733
    volatile unsigned char      dma_idmr1;      /* IDMA1 mask reg */
734
    volatile unsigned char      RSRVD15[0x3];
735
    volatile unsigned char      dma_idsr2;      /* IDMA2 status reg */
736
    volatile unsigned char      RSRVD16[0x3];
737
    volatile unsigned char      dma_idmr2;      /* IDMA2 mask reg */
738
    volatile unsigned char      RSRVD17[0x13];
739
 
740
    /* CPM Interrupt Controller */
741
    volatile unsigned short     cpmi_civr;      /* CP interrupt vector reg */
742
    volatile unsigned char      RSRVD19[0xe];
743
    volatile unsigned long      cpmi_cicr;      /* CP interrupt configuration reg */
744
    volatile unsigned long      cpmi_cipr;      /* CP interrupt pending reg */
745
    volatile unsigned long      cpmi_cimr;      /* CP interrupt mask reg */
746
    volatile unsigned long      cpmi_cisr;      /* CP interrupt in-service reg */
747
 
748
    /* I/O port */
749
    volatile unsigned short     pio_padir;      /* port A data direction reg */
750
    volatile unsigned short     pio_papar;      /* port A pin assignment reg */
751
    volatile unsigned short     pio_paodr;      /* port A open drain reg */
752
    volatile unsigned short     pio_padat;      /* port A data register */
753
    volatile unsigned char      RSRVD20[0x8];
754
    volatile unsigned short     pio_pcdir;      /* port C data direction reg */
755
    volatile unsigned short     pio_pcpar;      /* port C pin assignment reg */
756
    volatile unsigned short     pio_pcso;       /* port C special options */
757
    volatile unsigned short     pio_pcdat;      /* port C data register */
758
    volatile unsigned short     pio_pcint;      /* port C interrupt cntrl reg */
759
    unsigned char               RSRVD64[6];
760
    volatile unsigned short     pio_pddir;      /* port D Data Direction reg */
761
    volatile unsigned short     pio_pdpar;      /* port D pin assignment reg */
762
    unsigned char               RSRVD65[2];
763
    volatile unsigned short     pio_pddat;      /* port D data reg */
764
    volatile unsigned char      RSRVD21[0x8];
765
 
766
    /* CPM Timer */
767
    volatile unsigned short     timer_tgcr;     /* timer global configuration  reg */
768
    volatile unsigned char      RSRVD22[0xe];
769
    volatile unsigned short     timer_tmr1;     /* timer 1 mode reg */
770
    volatile unsigned short     timer_tmr2;     /* timer 2 mode reg */
771
    volatile unsigned short     timer_trr1;     /* timer 1 referance reg */
772
    volatile unsigned short     timer_trr2;     /* timer 2 referance reg */
773
    volatile unsigned short     timer_tcr1;     /* timer 1 capture reg */
774
    volatile unsigned short     timer_tcr2;     /* timer 2 capture reg */
775
    volatile unsigned short     timer_tcn1;     /* timer 1 counter reg */
776
    volatile unsigned short     timer_tcn2;     /* timer 2 counter reg */
777
    volatile unsigned short     timer_tmr3;     /* timer 3 mode reg */
778
    volatile unsigned short     timer_tmr4;     /* timer 4 mode reg */
779
    volatile unsigned short     timer_trr3;     /* timer 3 referance reg */
780
    volatile unsigned short     timer_trr4;     /* timer 4 referance reg */
781
    volatile unsigned short     timer_tcr3;     /* timer 3 capture reg */
782
    volatile unsigned short     timer_tcr4;     /* timer 4 capture reg */
783
    volatile unsigned short     timer_tcn3;     /* timer 3 counter reg */
784
    volatile unsigned short     timer_tcn4;     /* timer 4 counter reg */
785
    volatile unsigned short     timer_ter1;     /* timer 1 event reg */
786
    volatile unsigned short     timer_ter2;     /* timer 2 event reg */
787
    volatile unsigned short     timer_ter3;     /* timer 3 event reg */
788
    volatile unsigned short     timer_ter4;     /* timer 4 event reg */
789
    volatile unsigned char      RSRVD23[0x8];
790
 
791
    /* CP */
792
    volatile unsigned short     cp_cr;          /* command register */
793
    volatile unsigned char      RSRVD24[0x2];
794
    volatile unsigned short     cp_rccr;        /* main configuration reg */
795
    volatile unsigned char      RSRVD25;
796
    volatile unsigned char      cp_resv1;       /* RSRVD reg */
797
    volatile unsigned long      cp_resv2;       /* RSRVD reg */
798
    volatile unsigned short     cp_rctr1;       /* ram break register 1 */
799
    volatile unsigned short     cp_rctr2;       /* ram break register 2 */
800
    volatile unsigned short     cp_rctr3;       /* ram break register 3 */
801
    volatile unsigned short     cp_rctr4;       /* ram break register 4 */
802
    volatile unsigned char      RSRVD26[0x2];
803
    volatile unsigned short     cp_rter;        /* RISC timers event reg */
804
    volatile unsigned char      RSRVD27[0x2];
805
    volatile unsigned short     cp_rtmr;        /* RISC timers mask reg */
806
    volatile unsigned char      RSRVD28[0x14];
807
 
808
    /* BRG */
809
    volatile unsigned long      brgc1;          /* BRG1 configuration reg */
810
    volatile unsigned long      brgc2;          /* BRG2 configuration reg */
811
    volatile unsigned long      brgc3;          /* BRG3 configuration reg */
812
    volatile unsigned long      brgc4;          /* BRG4 configuration reg */
813
 
814
    /* SCC registers */
815
    struct scc_regs {
816
        volatile unsigned long  scc_gsmr_l;     /* SCC Gen mode (LOW) */
817
        volatile unsigned long  scc_gsmr_h;     /* SCC Gen mode (HIGH) */
818
        volatile unsigned short scc_psmr;       /* protocol specific mode register */
819
        volatile unsigned char  RSRVD29[0x2];
820
        volatile unsigned short scc_todr;       /* SCC transmit on demand */
821
        volatile unsigned short scc_dsr;        /* SCC data sync reg */
822
        volatile unsigned short scc_scce;       /* SCC event reg */
823
        volatile unsigned char  RSRVD30[0x2];
824
        volatile unsigned short scc_sccm;       /* SCC mask reg */
825
        volatile unsigned char  RSRVD31[0x1];
826
        volatile unsigned char  scc_sccs;       /* SCC status reg */
827
        volatile unsigned char  RSRVD32[0x8];
828
    } scc_regs[4];
829
 
830
    /* SMC */
831
    struct smc_regs {
832
        volatile unsigned char  RSRVD34[0x2];
833
        volatile unsigned short smc_smcmr;      /* SMC mode reg */
834
        volatile unsigned char  RSRVD35[0x2];
835
        volatile unsigned char  smc_smce;       /* SMC event reg */
836
        volatile unsigned char  RSRVD36[0x3];
837
        volatile unsigned char  smc_smcm;       /* SMC mask reg */
838
        volatile unsigned char  RSRVD37[0x5];
839
    } smc_regs[2];
840
 
841
    /* SPI */
842
    volatile unsigned short     spi_spmode;     /* SPI mode reg */
843
    volatile unsigned char      RSRVD38[0x4];
844
    volatile unsigned char      spi_spie;       /* SPI event reg */
845
    volatile unsigned char      RSRVD39[0x3];
846
    volatile unsigned char      spi_spim;       /* SPI mask reg */
847
    volatile unsigned char      RSRVD40[0x2];
848
    volatile unsigned char      spi_spcom;      /* SPI command reg */
849
    volatile unsigned char      RSRVD41[0x4];
850
 
851
    /* PIP */
852
    volatile unsigned short     pip_pipc;       /* pip configuration reg */
853
    volatile unsigned char      RSRVD42[0x2];
854
    volatile unsigned short     pip_ptpr;       /* pip timing parameters reg */
855
    volatile unsigned long      pip_pbdir;      /* port b data direction reg */
856
    volatile unsigned long      pip_pbpar;      /* port b pin assignment reg */
857
    volatile unsigned char      RSRVD43[0x2];
858
    volatile unsigned short     pip_pbodr;      /* port b open drain reg */
859
    volatile unsigned long      pip_pbdat;      /* port b data reg */
860
    volatile unsigned char      RSRVD44[0x18];
861
 
862
    /* Serial Interface */
863
    volatile unsigned long      si_simode;      /* SI mode register */
864
    volatile unsigned char      si_sigmr;       /* SI global mode register */
865
    volatile unsigned char      RSRVD45;
866
    volatile unsigned char      si_sistr;       /* SI status register */
867
    volatile unsigned char      si_sicmr;       /* SI command register */
868
    volatile unsigned char      RSRVD46[0x4];
869
    volatile unsigned long      si_sicr;        /* SI clock routing */
870
    volatile unsigned long      si_sirp;        /* SI ram pointers */
871
    volatile unsigned char      RSRVD47[0x10c];
872
    volatile unsigned char      si_siram[0x200];/* SI routing ram */
873
    volatile unsigned short     lcd_lcolr[256]; /* LCD Color RAM -- REV A.x */
874
    volatile unsigned char      RSRVD48[0x1000];
875
 
876
    /* BASE + 0x2000: user data memory */
877
    volatile unsigned char      udata_ucode[0x800];     /* user data bd's Ucode*/
878
    volatile unsigned char      bd[0x700];              /* buffer descriptors, data */
879
    volatile unsigned char      udata_ext[0x100];       /* extension area for downloaded ucode */
880
    volatile unsigned char      RSRVD49[0x0C00];
881
 
882
    /* BASE + 0x3c00: PARAMETER RAM */
883
    union {
884
        struct scc_pram {
885
            union {
886
                struct hdlc_pram        h;
887
                struct uart_pram        u;
888
                struct bisync_pram      b;
889
                struct transparent_pram t;
890
                struct async_hdlc_pram  a;
891
                unsigned char           RSRVD50[0x80];
892
            } pscc;             /* scc parameter area (protocol dependent) */
893
 
894
            union {
895
                struct {
896
                    struct i2c_pram     i2c;
897
                    unsigned char       RSRVD56[0x10];
898
                    struct idma_pram    idma1;
899
                } i2c_idma;
900
                struct {
901
                    struct spi_pram     spi;
902
                    unsigned char       RSRVD57[0x8];
903
                    struct timer_pram   timer;
904
                    struct idma_pram    idma2;
905
                } spi_timer_idma;
906
                struct {
907
                    union {
908
                        struct smc_uart_pram    u;
909
                        struct smc_trnsp_pram   t;
910
                        struct centronics_pram  c;
911
                    } psmc;
912
                    unsigned char       modem_param[0x40];
913
                } smc_modem;
914
                struct {
915
                    unsigned char       RSRVD54[0x40];
916
                    struct ucode_pram   ucode;
917
                } pucode;
918
            } pothers;
919
        } scc;
920
        struct ethernet_pram    enet_scc;
921
        unsigned char           pr[0x100];
922
    } pram[4];
923
} EPPC;
924
 
925
 
926
static inline EPPC *eppc_base(void)
927
{
928
    EPPC    *retval;
929
 
930
    asm volatile (
931
        "mfspr   %0,638 \n\t"
932
        "andis.  %0,%0,65535 \n\t"
933
        : "=r" (retval)
934
        : /* no inputs */  );
935
 
936
    return retval;
937
}
938
 
939
 
940
// Function used to allocate space in shared memory area
941
// typically used for buffer descriptors, etc.
942
__externC void _mpc8xx_reset_cpm(void);
943
__externC unsigned short _mpc8xx_allocBd(int len);
944
 
945
#define QUICC_BD_BASE               0x2000  // Start of shared memory
946
#define QUICC_BD_END                0x3000  // End of shared memory
947
 
948
 
949
#endif /* __ASSEMBLER__ */
950
 
951
/* Memory Periodic Timer Prescaler Register values */
952
#define PTP_DIV2        0x2000
953
#define PTP_DIV4        0x1000
954
#define PTP_DIV8        0x0800
955
#define PTP_DIV16       0x0400
956
#define PTP_DIV32       0x0200
957
#define PTP_DIV64       0x0100
958
 
959
// Command Processor Module (CPM) 
960
 
961
// Buffer descriptor control bits
962
#define QUICC_BD_CTL_Ready          0x8000  // Buffer contains data (tx) or is empty (rx)
963
#define QUICC_BD_CTL_Wrap           0x2000  // Last buffer in list
964
#define QUICC_BD_CTL_Int            0x1000  // Generate interrupt when empty (tx) or full (rx)
965
#define QUICC_BD_CTL_Last           0x0800  // Last buffer in a sequence
966
#define QUICC_BD_CTL_MASK           0xB000  // User settable bits
967
 
968
// Command register
969
#define QUICC_CPM_CR_INIT_TXRX      0x0000  // Initialize both Tx and Rx chains
970
#define QUICC_CPM_CR_INIT_RX        0x0100  // Initialize Rx chains
971
#define QUICC_CPM_CR_INIT_TX        0x0200  // Initialize Tx chains
972
#define QUICC_CPM_CR_HUNT_MODE      0x0300  // Start "hunt" mode
973
#define QUICC_CPM_CR_STOP_TX        0x0400  // Stop transmitter
974
#define QUICC_CPM_CR_RESTART_TX     0x0600  // Restart transmitter
975
#define QUICC_CPM_CR_RESET          0x8000  // Reset CPM
976
#define QUICC_CPM_CR_BUSY           0x0001  // Kick CPM - busy indicator
977
 
978
// CPM channels
979
#define QUICC_CPM_SCC1              0x0000
980
#define QUICC_CPM_I2C               0x0010
981
#define QUICC_CPM_SCC2              0x0040
982
#define QUICC_CPM_SCC3              0x0080
983
#define QUICC_CPM_SMC1              0x0090
984
#define QUICC_CPM_SCC4              0x00C0
985
#define QUICC_CPM_SMC2              0x00D0
986
 
987
#endif // ifndef CYGONCE_HAL_PPC_QUICC_PPC8XX_H

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.