xref: /haiku/src/add-ons/kernel/drivers/graphics/radeon_hd/radeon_hd_private.h (revision f73f5d4c42a01ece688cbb57b5d332cc0f68b2c6)
1 /*
2  * Copyright 2006-2010, Haiku, Inc. All Rights Reserved.
3  * Distributed under the terms of the MIT License.
4  *
5  * Authors:
6  *		Axel Dörfler, axeld@pinc-software.de
7  *		Clemens Zeidler, haiku@clemens-zeidler.de
8  */
9 #ifndef RADEON_RD_PRIVATE_H
10 #define RADEON_RD_PRIVATE_H
11 
12 
13 #include <AGP.h>
14 #include <KernelExport.h>
15 #include <PCI.h>
16 
17 
18 #include "radeon_hd.h"
19 #include "lock.h"
20 
21 
22 // PCI Base Address Registers
23 #define PCI_BAR_FB      0
24 #define PCI_BAR_MMIO    2
25 
26 #define RADEON_BIOS8(adr, v) 	(adr[v])
27 #define RADEON_BIOS16(adr, v) 	((adr[v]) | (adr[(v) + 1] << 8))
28 #define RADEON_BIOS32(adr, v)	\
29 	((RADEON_BIOS16(adr, v) | RADEON_BIOS16(adr, v + 2) << 16))
30 
31 
32 struct radeon_info {
33 	int32			open_count;
34 	status_t		init_status;
35 	int32			id;
36 	pci_info*		pci;
37 	addr_t			registers;
38 
39 	uint8*			atom_buffer;	// buffer for atombios
40 
41 	area_id			registers_area;
42 	area_id			framebuffer_area;
43 	area_id			rom_area;
44 
45 	struct radeon_shared_info* shared_info;
46 	area_id			shared_area;
47 
48 	uint32			pciID;
49 	const char*		deviceName;
50 	uint16			chipsetID;
51 	const char*		chipsetName;
52 	uint32			chipsetFlags;
53 	uint8			dceMajor;
54 	uint8			dceMinor;
55 };
56 
57 
58 status_t mapAtomBIOS(radeon_info &info, uint32 romBase, uint32 romSize);
59 extern status_t radeon_hd_init(radeon_info& info);
60 extern void radeon_hd_uninit(radeon_info& info);
61 
62 
63 #endif  /* RADEON_RD_PRIVATE_H */
64