| 1 | /* SPDX-License-Identifier: GPL-2.0 */ | 
|---|
| 2 | #ifndef _ASM_X86_GART_H | 
|---|
| 3 | #define _ASM_X86_GART_H | 
|---|
| 4 |  | 
|---|
| 5 | #include <asm/e820/api.h> | 
|---|
| 6 |  | 
|---|
| 7 | extern void set_up_gart_resume(u32, u32); | 
|---|
| 8 |  | 
|---|
| 9 | extern int fallback_aper_order; | 
|---|
| 10 | extern int fallback_aper_force; | 
|---|
| 11 | extern int fix_aperture; | 
|---|
| 12 |  | 
|---|
| 13 | /* PTE bits. */ | 
|---|
| 14 | #define GPTE_VALID	1 | 
|---|
| 15 | #define GPTE_COHERENT	2 | 
|---|
| 16 |  | 
|---|
| 17 | /* Aperture control register bits. */ | 
|---|
| 18 | #define GARTEN		(1<<0) | 
|---|
| 19 | #define DISGARTCPU	(1<<4) | 
|---|
| 20 | #define DISGARTIO	(1<<5) | 
|---|
| 21 | #define DISTLBWALKPRB	(1<<6) | 
|---|
| 22 |  | 
|---|
| 23 | /* GART cache control register bits. */ | 
|---|
| 24 | #define INVGART		(1<<0) | 
|---|
| 25 | #define GARTPTEERR	(1<<1) | 
|---|
| 26 |  | 
|---|
| 27 | /* K8 On-cpu GART registers */ | 
|---|
| 28 | #define AMD64_GARTAPERTURECTL	0x90 | 
|---|
| 29 | #define AMD64_GARTAPERTUREBASE	0x94 | 
|---|
| 30 | #define AMD64_GARTTABLEBASE	0x98 | 
|---|
| 31 | #define AMD64_GARTCACHECTL	0x9c | 
|---|
| 32 |  | 
|---|
| 33 | #ifdef CONFIG_GART_IOMMU | 
|---|
| 34 | extern int gart_iommu_aperture; | 
|---|
| 35 | extern int gart_iommu_aperture_allowed; | 
|---|
| 36 | extern int gart_iommu_aperture_disabled; | 
|---|
| 37 |  | 
|---|
| 38 | extern void early_gart_iommu_check(void); | 
|---|
| 39 | extern int gart_iommu_init(void); | 
|---|
| 40 | extern void __init gart_parse_options(char *); | 
|---|
| 41 | void gart_iommu_hole_init(void); | 
|---|
| 42 |  | 
|---|
| 43 | #else | 
|---|
| 44 | #define gart_iommu_aperture            0 | 
|---|
| 45 | #define gart_iommu_aperture_allowed    0 | 
|---|
| 46 | #define gart_iommu_aperture_disabled   1 | 
|---|
| 47 |  | 
|---|
| 48 | static inline void early_gart_iommu_check(void) | 
|---|
| 49 | { | 
|---|
| 50 | } | 
|---|
| 51 | static inline void gart_parse_options(char *options) | 
|---|
| 52 | { | 
|---|
| 53 | } | 
|---|
| 54 | static inline void gart_iommu_hole_init(void) | 
|---|
| 55 | { | 
|---|
| 56 | } | 
|---|
| 57 | #endif | 
|---|
| 58 |  | 
|---|
| 59 | extern int agp_amd64_init(void); | 
|---|
| 60 |  | 
|---|
| 61 | static inline void gart_set_size_and_enable(struct pci_dev *dev, u32 order) | 
|---|
| 62 | { | 
|---|
| 63 | u32 ctl; | 
|---|
| 64 |  | 
|---|
| 65 | /* | 
|---|
| 66 | * Don't enable translation but enable GART IO and CPU accesses. | 
|---|
| 67 | * Also, set DISTLBWALKPRB since GART tables memory is UC. | 
|---|
| 68 | */ | 
|---|
| 69 | ctl = order << 1; | 
|---|
| 70 |  | 
|---|
| 71 | pci_write_config_dword(dev, AMD64_GARTAPERTURECTL, val: ctl); | 
|---|
| 72 | } | 
|---|
| 73 |  | 
|---|
| 74 | static inline void enable_gart_translation(struct pci_dev *dev, u64 addr) | 
|---|
| 75 | { | 
|---|
| 76 | u32 tmp, ctl; | 
|---|
| 77 |  | 
|---|
| 78 | /* address of the mappings table */ | 
|---|
| 79 | addr >>= 12; | 
|---|
| 80 | tmp = (u32) addr<<4; | 
|---|
| 81 | tmp &= ~0xf; | 
|---|
| 82 | pci_write_config_dword(dev, AMD64_GARTTABLEBASE, val: tmp); | 
|---|
| 83 |  | 
|---|
| 84 | /* Enable GART translation for this hammer. */ | 
|---|
| 85 | pci_read_config_dword(dev, AMD64_GARTAPERTURECTL, val: &ctl); | 
|---|
| 86 | ctl |= GARTEN | DISTLBWALKPRB; | 
|---|
| 87 | ctl &= ~(DISGARTCPU | DISGARTIO); | 
|---|
| 88 | pci_write_config_dword(dev, AMD64_GARTAPERTURECTL, val: ctl); | 
|---|
| 89 | } | 
|---|
| 90 |  | 
|---|
| 91 | static inline int aperture_valid(u64 aper_base, u32 aper_size, u32 min_size) | 
|---|
| 92 | { | 
|---|
| 93 | if (!aper_base) | 
|---|
| 94 | return 0; | 
|---|
| 95 |  | 
|---|
| 96 | if (aper_base + aper_size > 0x100000000ULL) { | 
|---|
| 97 | printk(KERN_INFO "Aperture beyond 4GB. Ignoring.\n"); | 
|---|
| 98 | return 0; | 
|---|
| 99 | } | 
|---|
| 100 | if (e820__mapped_any(start: aper_base, end: aper_base + aper_size, type: E820_TYPE_RAM)) { | 
|---|
| 101 | printk(KERN_INFO "Aperture pointing to e820 RAM. Ignoring.\n"); | 
|---|
| 102 | return 0; | 
|---|
| 103 | } | 
|---|
| 104 | if (aper_size < min_size) { | 
|---|
| 105 | printk(KERN_INFO "Aperture too small (%d MB) than (%d MB)\n", | 
|---|
| 106 | aper_size>>20, min_size>>20); | 
|---|
| 107 | return 0; | 
|---|
| 108 | } | 
|---|
| 109 |  | 
|---|
| 110 | return 1; | 
|---|
| 111 | } | 
|---|
| 112 |  | 
|---|
| 113 | #endif /* _ASM_X86_GART_H */ | 
|---|
| 114 |  | 
|---|