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

Subversion Repositories or1k

[/] [or1k/] [trunk/] [rtems/] [c/] [src/] [libchip/] [serial/] [mc68681_reg.c] - Blame information for rev 1765

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 158 chris
/*
2
 *  This file contains a typical set of register access routines which may be
3
 *  used with the mc68681 chip if accesses to the chip are as follows:
4
 *
5
 *    + registers are accessed as bytes
6
 *    + registers are only byte-aligned (no address gaps)
7
 *
8
 *  COPYRIGHT (c) 1989-1997.
9
 *  On-Line Applications Research Corporation (OAR).
10
 *  Copyright assigned to U.S. Government, 1994.
11
 *
12
 *  The license and distribution terms for this file may be
13
 *  found in the file LICENSE in this distribution or at
14
 *  http://www.OARcorp.com/rtems/license.html.
15
 *
16 208 chris
 *  $Id: mc68681_reg.c,v 1.2 2001-09-27 12:01:42 chris Exp $
17 158 chris
 */
18
 
19
#include <rtems.h>
20
 
21
#ifndef _MC68681_MULTIPLIER
22
#define _MC68681_MULTIPLIER 1
23
#define _MC68681_NAME(_X) _X
24
#define _MC68681_TYPE unsigned8
25
#endif
26
 
27
#define CALCULATE_REGISTER_ADDRESS( _base, _reg ) \
28
  (_MC68681_TYPE *)((_base) + ((_reg) * _MC68681_MULTIPLIER ))
29
 
30
/*
31
 *  MC68681 Get Register Routine
32
 */
33
 
34
unsigned8 _MC68681_NAME(mc68681_get_register)(
35
  unsigned32  ulCtrlPort,
36
  unsigned8   ucRegNum
37
)
38
{
39
  _MC68681_TYPE *port;
40
 
41
  port = CALCULATE_REGISTER_ADDRESS( ulCtrlPort, ucRegNum );
42
 
43
  return *port;
44
}
45
 
46
/*
47
 *  MC68681 Set Register Routine
48
 */
49
 
50
void  _MC68681_NAME(mc68681_set_register)(
51
  unsigned32  ulCtrlPort,
52
  unsigned8   ucRegNum,
53
  unsigned8   ucData
54
)
55
{
56
  _MC68681_TYPE *port;
57
 
58
  port = CALCULATE_REGISTER_ADDRESS( ulCtrlPort, ucRegNum );
59
 
60
  *port = ucData;
61
}

powered by: WebSVN 2.1.0

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