diff options
-rw-r--r-- | drivers/char/agp/intel-agp.c | 134 |
1 files changed, 66 insertions, 68 deletions
diff --git a/drivers/char/agp/intel-agp.c b/drivers/char/agp/intel-agp.c index b52988df2979..30aa01b738b4 100644 --- a/drivers/char/agp/intel-agp.c +++ b/drivers/char/agp/intel-agp.c | |||
@@ -1198,45 +1198,45 @@ static void intel_i965_get_gtt_range(int *gtt_offset, int *gtt_size) | |||
1198 | */ | 1198 | */ |
1199 | static int intel_i965_create_gatt_table(struct agp_bridge_data *bridge) | 1199 | static int intel_i965_create_gatt_table(struct agp_bridge_data *bridge) |
1200 | { | 1200 | { |
1201 | int page_order; | 1201 | int page_order; |
1202 | struct aper_size_info_fixed *size; | 1202 | struct aper_size_info_fixed *size; |
1203 | int num_entries; | 1203 | int num_entries; |
1204 | u32 temp; | 1204 | u32 temp; |
1205 | int gtt_offset, gtt_size; | 1205 | int gtt_offset, gtt_size; |
1206 | 1206 | ||
1207 | size = agp_bridge->current_size; | 1207 | size = agp_bridge->current_size; |
1208 | page_order = size->page_order; | 1208 | page_order = size->page_order; |
1209 | num_entries = size->num_entries; | 1209 | num_entries = size->num_entries; |
1210 | agp_bridge->gatt_table_real = NULL; | 1210 | agp_bridge->gatt_table_real = NULL; |
1211 | 1211 | ||
1212 | pci_read_config_dword(intel_private.pcidev, I915_MMADDR, &temp); | 1212 | pci_read_config_dword(intel_private.pcidev, I915_MMADDR, &temp); |
1213 | 1213 | ||
1214 | temp &= 0xfff00000; | 1214 | temp &= 0xfff00000; |
1215 | 1215 | ||
1216 | intel_i965_get_gtt_range(>t_offset, >t_size); | 1216 | intel_i965_get_gtt_range(>t_offset, >t_size); |
1217 | 1217 | ||
1218 | intel_private.gtt = ioremap((temp + gtt_offset) , gtt_size); | 1218 | intel_private.gtt = ioremap((temp + gtt_offset) , gtt_size); |
1219 | 1219 | ||
1220 | if (!intel_private.gtt) | 1220 | if (!intel_private.gtt) |
1221 | return -ENOMEM; | 1221 | return -ENOMEM; |
1222 | 1222 | ||
1223 | intel_private.registers = ioremap(temp, 128 * 4096); | 1223 | intel_private.registers = ioremap(temp, 128 * 4096); |
1224 | if (!intel_private.registers) { | 1224 | if (!intel_private.registers) { |
1225 | iounmap(intel_private.gtt); | 1225 | iounmap(intel_private.gtt); |
1226 | return -ENOMEM; | 1226 | return -ENOMEM; |
1227 | } | 1227 | } |
1228 | 1228 | ||
1229 | temp = readl(intel_private.registers+I810_PGETBL_CTL) & 0xfffff000; | 1229 | temp = readl(intel_private.registers+I810_PGETBL_CTL) & 0xfffff000; |
1230 | global_cache_flush(); /* FIXME: ? */ | 1230 | global_cache_flush(); /* FIXME: ? */ |
1231 | 1231 | ||
1232 | /* we have to call this as early as possible after the MMIO base address is known */ | 1232 | /* we have to call this as early as possible after the MMIO base address is known */ |
1233 | intel_i830_init_gtt_entries(); | 1233 | intel_i830_init_gtt_entries(); |
1234 | 1234 | ||
1235 | agp_bridge->gatt_table = NULL; | 1235 | agp_bridge->gatt_table = NULL; |
1236 | 1236 | ||
1237 | agp_bridge->gatt_bus_addr = temp; | 1237 | agp_bridge->gatt_bus_addr = temp; |
1238 | 1238 | ||
1239 | return 0; | 1239 | return 0; |
1240 | } | 1240 | } |
1241 | 1241 | ||
1242 | 1242 | ||
@@ -1753,7 +1753,7 @@ static const struct agp_bridge_driver intel_815_driver = { | |||
1753 | .free_by_type = agp_generic_free_by_type, | 1753 | .free_by_type = agp_generic_free_by_type, |
1754 | .agp_alloc_page = agp_generic_alloc_page, | 1754 | .agp_alloc_page = agp_generic_alloc_page, |
1755 | .agp_destroy_page = agp_generic_destroy_page, | 1755 | .agp_destroy_page = agp_generic_destroy_page, |
1756 | .agp_type_to_mask_type = agp_generic_type_to_mask_type, | 1756 | .agp_type_to_mask_type = agp_generic_type_to_mask_type, |
1757 | }; | 1757 | }; |
1758 | 1758 | ||
1759 | static const struct agp_bridge_driver intel_830_driver = { | 1759 | static const struct agp_bridge_driver intel_830_driver = { |
@@ -1954,28 +1954,26 @@ static const struct agp_bridge_driver intel_915_driver = { | |||
1954 | }; | 1954 | }; |
1955 | 1955 | ||
1956 | static const struct agp_bridge_driver intel_i965_driver = { | 1956 | static const struct agp_bridge_driver intel_i965_driver = { |
1957 | .owner = THIS_MODULE, | 1957 | .owner = THIS_MODULE, |
1958 | .aperture_sizes = intel_i830_sizes, | 1958 | .aperture_sizes = intel_i830_sizes, |
1959 | .size_type = FIXED_APER_SIZE, | 1959 | .size_type = FIXED_APER_SIZE, |
1960 | .num_aperture_sizes = 4, | 1960 | .num_aperture_sizes = 4, |
1961 | .needs_scratch_page = true, | 1961 | .needs_scratch_page = true, |
1962 | .configure = intel_i915_configure, | 1962 | .cleanup = intel_i915_cleanup, |
1963 | .fetch_size = intel_i9xx_fetch_size, | 1963 | .tlb_flush = intel_i810_tlbflush, |
1964 | .cleanup = intel_i915_cleanup, | 1964 | .mask_memory = intel_i965_mask_memory, |
1965 | .tlb_flush = intel_i810_tlbflush, | 1965 | .masks = intel_i810_masks, |
1966 | .mask_memory = intel_i965_mask_memory, | 1966 | .agp_enable = intel_i810_agp_enable, |
1967 | .masks = intel_i810_masks, | 1967 | .cache_flush = global_cache_flush, |
1968 | .agp_enable = intel_i810_agp_enable, | 1968 | .create_gatt_table = intel_i965_create_gatt_table, |
1969 | .cache_flush = global_cache_flush, | 1969 | .free_gatt_table = intel_i830_free_gatt_table, |
1970 | .create_gatt_table = intel_i965_create_gatt_table, | 1970 | .insert_memory = intel_i915_insert_entries, |
1971 | .free_gatt_table = intel_i830_free_gatt_table, | 1971 | .remove_memory = intel_i915_remove_entries, |
1972 | .insert_memory = intel_i915_insert_entries, | 1972 | .alloc_by_type = intel_i830_alloc_by_type, |
1973 | .remove_memory = intel_i915_remove_entries, | 1973 | .free_by_type = intel_i810_free_by_type, |
1974 | .alloc_by_type = intel_i830_alloc_by_type, | 1974 | .agp_alloc_page = agp_generic_alloc_page, |
1975 | .free_by_type = intel_i810_free_by_type, | 1975 | .agp_destroy_page = agp_generic_destroy_page, |
1976 | .agp_alloc_page = agp_generic_alloc_page, | 1976 | .agp_type_to_mask_type = intel_i830_type_to_mask_type, |
1977 | .agp_destroy_page = agp_generic_destroy_page, | ||
1978 | .agp_type_to_mask_type = intel_i830_type_to_mask_type, | ||
1979 | .chipset_flush = intel_i915_chipset_flush, | 1977 | .chipset_flush = intel_i915_chipset_flush, |
1980 | }; | 1978 | }; |
1981 | 1979 | ||
@@ -2004,28 +2002,28 @@ static const struct agp_bridge_driver intel_7505_driver = { | |||
2004 | }; | 2002 | }; |
2005 | 2003 | ||
2006 | static const struct agp_bridge_driver intel_g33_driver = { | 2004 | static const struct agp_bridge_driver intel_g33_driver = { |
2007 | .owner = THIS_MODULE, | 2005 | .owner = THIS_MODULE, |
2008 | .aperture_sizes = intel_i830_sizes, | 2006 | .aperture_sizes = intel_i830_sizes, |
2009 | .size_type = FIXED_APER_SIZE, | 2007 | .size_type = FIXED_APER_SIZE, |
2010 | .num_aperture_sizes = 4, | 2008 | .num_aperture_sizes = 4, |
2011 | .needs_scratch_page = true, | 2009 | .needs_scratch_page = true, |
2012 | .configure = intel_i915_configure, | 2010 | .configure = intel_i915_configure, |
2013 | .fetch_size = intel_i9xx_fetch_size, | 2011 | .fetch_size = intel_i9xx_fetch_size, |
2014 | .cleanup = intel_i915_cleanup, | 2012 | .cleanup = intel_i915_cleanup, |
2015 | .tlb_flush = intel_i810_tlbflush, | 2013 | .tlb_flush = intel_i810_tlbflush, |
2016 | .mask_memory = intel_i965_mask_memory, | 2014 | .mask_memory = intel_i965_mask_memory, |
2017 | .masks = intel_i810_masks, | 2015 | .masks = intel_i810_masks, |
2018 | .agp_enable = intel_i810_agp_enable, | 2016 | .agp_enable = intel_i810_agp_enable, |
2019 | .cache_flush = global_cache_flush, | 2017 | .cache_flush = global_cache_flush, |
2020 | .create_gatt_table = intel_i915_create_gatt_table, | 2018 | .create_gatt_table = intel_i915_create_gatt_table, |
2021 | .free_gatt_table = intel_i830_free_gatt_table, | 2019 | .free_gatt_table = intel_i830_free_gatt_table, |
2022 | .insert_memory = intel_i915_insert_entries, | 2020 | .insert_memory = intel_i915_insert_entries, |
2023 | .remove_memory = intel_i915_remove_entries, | 2021 | .remove_memory = intel_i915_remove_entries, |
2024 | .alloc_by_type = intel_i830_alloc_by_type, | 2022 | .alloc_by_type = intel_i830_alloc_by_type, |
2025 | .free_by_type = intel_i810_free_by_type, | 2023 | .free_by_type = intel_i810_free_by_type, |
2026 | .agp_alloc_page = agp_generic_alloc_page, | 2024 | .agp_alloc_page = agp_generic_alloc_page, |
2027 | .agp_destroy_page = agp_generic_destroy_page, | 2025 | .agp_destroy_page = agp_generic_destroy_page, |
2028 | .agp_type_to_mask_type = intel_i830_type_to_mask_type, | 2026 | .agp_type_to_mask_type = intel_i830_type_to_mask_type, |
2029 | .chipset_flush = intel_i915_chipset_flush, | 2027 | .chipset_flush = intel_i915_chipset_flush, |
2030 | }; | 2028 | }; |
2031 | 2029 | ||