diff options
author | Owain Ainsworth <oga@cvs.openbsd.org> | 2009-02-15 20:14:39 +0000 |
---|---|---|
committer | Owain Ainsworth <oga@cvs.openbsd.org> | 2009-02-15 20:14:39 +0000 |
commit | 98b42a8d01550cfe373304b0c45d1bed8a30b731 (patch) | |
tree | 0b61cbc8189d426e92cef9d68518ba4cd6cfbe1f | |
parent | f1c8696d1a7698c0df74722c31470c1de0cb7551 (diff) |
Split out the switch statement that writes the pcigart table entry into
a separate function. Makes this code a lot easier to read.
-rw-r--r-- | sys/dev/pci/drm/ati_pcigart.c | 53 |
1 files changed, 31 insertions, 22 deletions
diff --git a/sys/dev/pci/drm/ati_pcigart.c b/sys/dev/pci/drm/ati_pcigart.c index de1a1f7eded..6a16a1654c3 100644 --- a/sys/dev/pci/drm/ati_pcigart.c +++ b/sys/dev/pci/drm/ati_pcigart.c @@ -39,6 +39,33 @@ #define ATI_PCIE_WRITE 0x4 #define ATI_PCIE_READ 0x8 +void pcigart_add_entry(struct drm_ati_pcigart_info *, u_int32_t *, + bus_addr_t); + +void +pcigart_add_entry(struct drm_ati_pcigart_info *gart_info, u_int32_t *pci_gart, + bus_addr_t entry_addr) +{ + u_int32_t page_base = (u_int32_t)entry_addr & + ATI_PCIGART_PAGE_MASK; + + switch(gart_info->gart_reg_if) { + case DRM_ATI_GART_IGP: + page_base |= (upper_32_bits(entry_addr) & 0xff) << 4; + page_base |= 0xc; + break; + case DRM_ATI_GART_PCIE: + page_base >>= 8; + page_base |= (upper_32_bits(entry_addr) & 0xff) << 24; + page_base |= ATI_PCIE_READ | ATI_PCIE_WRITE; + break; + default: + case DRM_ATI_GART_PCI: + break; + } + *pci_gart = htole32(page_base); +} + int drm_ati_pcigart_cleanup(struct drm_device *dev, struct drm_ati_pcigart_info *gart_info) @@ -67,7 +94,7 @@ drm_ati_pcigart_init(struct drm_device *dev, struct drm_ati_pcigart_info *gart_info) { - u_int32_t *pci_gart, page_base; + u_int32_t *pci_gart; bus_addr_t entry_addr; u_long pages, max_pages; int i, j, ret = 0; @@ -108,27 +135,9 @@ drm_ati_pcigart_init(struct drm_device *dev, for (i = 0; i < pages; i++) { entry_addr = dev->sg->mem->map->dm_segs[i].ds_addr; - for (j = 0; j < (PAGE_SIZE / ATI_PCIGART_PAGE_SIZE); j++) { - page_base = (u_int32_t)entry_addr & - ATI_PCIGART_PAGE_MASK; - switch(gart_info->gart_reg_if) { - case DRM_ATI_GART_IGP: - page_base |= (upper_32_bits(entry_addr) & 0xff) << 4; - page_base |= 0xc; - break; - case DRM_ATI_GART_PCIE: - page_base >>= 8; - page_base |= (upper_32_bits(entry_addr) & 0xff) << 24; - page_base |= ATI_PCIE_READ | ATI_PCIE_WRITE; - break; - default: - case DRM_ATI_GART_PCI: - break; - } - *pci_gart = htole32(page_base); - pci_gart++; - entry_addr += ATI_PCIGART_PAGE_SIZE; - } + for (j = 0; j < (PAGE_SIZE / ATI_PCIGART_PAGE_SIZE); + j++, entry_addr += ATI_PCIGART_PAGE_SIZE) + pcigart_add_entry(gart_info, pci_gart++, entry_addr); } DRM_MEMORYBARRIER(); |