|
|
1.1 root 1: /*
2: * Copyright (c) 1998-2000 Apple Computer, Inc. All rights reserved.
3: *
4: * @APPLE_LICENSE_HEADER_START@
5: *
6: * The contents of this file constitute Original Code as defined in and
7: * are subject to the Apple Public Source License Version 1.1 (the
8: * "License"). You may not use this file except in compliance with the
9: * License. Please obtain a copy of the License at
10: * http://www.apple.com/publicsource and read it before using this file.
11: *
12: * This Original Code and all software distributed under the License are
13: * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14: * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15: * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16: * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17: * License for the specific language governing rights and limitations
18: * under the License.
19: *
20: * @APPLE_LICENSE_HEADER_END@
21: */
22: /*
23: * Copyright (c) 1998 Apple Computer, Inc. All rights reserved.
24: *
25: * HISTORY
26: * 23 Nov 98 sdouglas created from objc version.
27: */
28:
29: #include <IOKit/system.h>
30:
31: #include <IOKit/pci/IOPCIBridge.h>
32: #include <IOKit/pci/IOPCIDevice.h>
33:
34: #include <IOKit/IOLib.h>
35: #include <IOKit/assert.h>
36:
37: #include <libkern/OSByteOrder.h>
38: #include <libkern/c++/OSContainers.h>
39:
40:
41: /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
42:
43: UInt32 IOPCIDevice::ioRead32( UInt16 offset, IOMemoryMap * map = 0 )
44: {
45: UInt32 value;
46:
47: if( 0 == map) {
48: map = ioMap;
49: if( 0 == map)
50: return( 0 );
51: }
52:
53: value = OSReadSwapInt32( (volatile void *)map->getVirtualAddress(), offset);
54: eieio();
55:
56: return( value );
57: }
58:
59: UInt16 IOPCIDevice::ioRead16( UInt16 offset, IOMemoryMap * map = 0 )
60: {
61: UInt16 value;
62:
63: if( 0 == map) {
64: map = ioMap;
65: if( 0 == map)
66: return( 0 );
67: }
68:
69: value = OSReadSwapInt16( (volatile void *)map->getVirtualAddress(), offset);
70: eieio();
71:
72: return( value );
73: }
74:
75: UInt8 IOPCIDevice::ioRead8( UInt16 offset, IOMemoryMap * map = 0 )
76: {
77: UInt32 value;
78:
79: if( 0 == map) {
80: map = ioMap;
81: if( 0 == map)
82: return( 0 );
83: }
84:
85: value = ((volatile UInt8 *) map->getVirtualAddress())[ offset ];
86: eieio();
87:
88: return( value );
89: }
90:
91: void IOPCIDevice::ioWrite32( UInt16 offset, UInt32 value,
92: IOMemoryMap * map = 0 )
93: {
94: if( 0 == map) {
95: map = ioMap;
96: if( 0 == map)
97: return;
98: }
99:
100: OSWriteSwapInt32( (volatile void *)map->getVirtualAddress(), offset, value);
101: eieio();
102: }
103:
104: void IOPCIDevice::ioWrite16( UInt16 offset, UInt16 value,
105: IOMemoryMap * map = 0 )
106: {
107: if( 0 == map) {
108: map = ioMap;
109: if( 0 == map)
110: return;
111: }
112:
113: OSWriteSwapInt16( (volatile void *)map->getVirtualAddress(), offset, value);
114: eieio();
115: }
116:
117: void IOPCIDevice::ioWrite8( UInt16 offset, UInt8 value,
118: IOMemoryMap * map = 0 )
119: {
120: if( 0 == map) {
121: map = ioMap;
122: if( 0 == map)
123: return;
124: }
125:
126: ((volatile UInt8 *) map->getVirtualAddress())[ offset ] = value;
127: eieio();
128:
129: }
130:
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.