summaryrefslogtreecommitdiff
path: root/sys/dev/pci/drm
diff options
context:
space:
mode:
authorJonathan Gray <jsg@cvs.openbsd.org>2021-12-14 12:48:16 +0000
committerJonathan Gray <jsg@cvs.openbsd.org>2021-12-14 12:48:16 +0000
commit1421aec3eeb8f880da8d57be5424c733ce6f0f2b (patch)
treeaca0821d15cec238c7be4f5ddb67727b518b7fc7 /sys/dev/pci/drm
parent325b99dbc4f25688c286cd987610cb80cd965751 (diff)
use bus_space_read_region_1() when reading bios from pci rom
Avoids 'BIOS signature incorrect 0 0' warning seen on sparc64 (where pci is mapped little endian) reported by Ted Bullock.
Diffstat (limited to 'sys/dev/pci/drm')
-rw-r--r--sys/dev/pci/drm/amd/amdgpu/amdgpu_bios.c15
-rw-r--r--sys/dev/pci/drm/radeon/radeon_bios.c48
2 files changed, 19 insertions, 44 deletions
diff --git a/sys/dev/pci/drm/amd/amdgpu/amdgpu_bios.c b/sys/dev/pci/drm/amd/amdgpu/amdgpu_bios.c
index 91727d200e8..ab945875207 100644
--- a/sys/dev/pci/drm/amd/amdgpu/amdgpu_bios.c
+++ b/sys/dev/pci/drm/amd/amdgpu/amdgpu_bios.c
@@ -200,7 +200,6 @@ bool amdgpu_read_bios(struct amdgpu_device *adev)
#else
bool amdgpu_read_bios(struct amdgpu_device *adev)
{
- uint8_t __iomem *bios;
size_t size;
pcireg_t address, mask;
bus_space_handle_t romh;
@@ -218,25 +217,15 @@ bool amdgpu_read_bios(struct amdgpu_device *adev)
size = PCI_ROM_SIZE(mask);
if (size == 0)
return false;
- rc = bus_space_map(adev->memt, PCI_ROM_ADDR(address), size,
- BUS_SPACE_MAP_LINEAR, &romh);
+ rc = bus_space_map(adev->memt, PCI_ROM_ADDR(address), size, 0, &romh);
if (rc != 0) {
printf(": can't map PCI ROM (%d)\n", rc);
return false;
}
- bios = (uint8_t *)bus_space_vaddr(adev->memt, romh);
- if (!bios) {
- printf(": bus_space_vaddr failed\n");
- return false;
- }
adev->bios = kzalloc(size, GFP_KERNEL);
- if (adev->bios == NULL) {
- bus_space_unmap(adev->memt, romh, size);
- return false;
- }
adev->bios_size = size;
- memcpy_fromio(adev->bios, bios, size);
+ bus_space_read_region_1(adev->memt, romh, 0, adev->bios, size);
bus_space_unmap(adev->memt, romh, size);
if (!check_atom_bios(adev->bios, size)) {
diff --git a/sys/dev/pci/drm/radeon/radeon_bios.c b/sys/dev/pci/drm/radeon/radeon_bios.c
index f0282c83240..121b286991e 100644
--- a/sys/dev/pci/drm/radeon/radeon_bios.c
+++ b/sys/dev/pci/drm/radeon/radeon_bios.c
@@ -89,7 +89,6 @@ static bool igp_read_bios_from_vram(struct radeon_device *rdev)
#else
static bool igp_read_bios_from_vram(struct radeon_device *rdev)
{
- uint8_t __iomem *bios;
bus_size_t size = 256 * 1024; /* ??? */
bus_space_handle_t bsh;
bus_space_tag_t bst = rdev->memt;
@@ -100,26 +99,19 @@ static bool igp_read_bios_from_vram(struct radeon_device *rdev)
rdev->bios = NULL;
- if (bus_space_map(bst, rdev->fb_aper_offset, size, BUS_SPACE_MAP_LINEAR, &bsh) != 0)
- return false;
-
- bios = bus_space_vaddr(rdev->memt, bsh);
- if (bios == NULL) {
- bus_space_unmap(bst, bsh, size);
+ if (bus_space_map(bst, rdev->fb_aper_offset, size, 0, &bsh) != 0)
return false;
- }
- if (size == 0 || bios[0] != 0x55 || bios[1] != 0xaa) {
- bus_space_unmap(bst, bsh, size);
- return false;
- }
rdev->bios = kmalloc(size, GFP_KERNEL);
- if (rdev->bios == NULL) {
- bus_space_unmap(bst, bsh, size);
+ bus_space_read_region_1(rdev->memt, bsh, 0, rdev->bios, size);
+ bus_space_unmap(bst, bsh, size);
+
+ if (size == 0 || rdev->bios[0] != 0x55 || rdev->bios[1] != 0xaa) {
+ kfree(rdev->bios);
+ rdev->bios = NULL;
return false;
}
- memcpy_fromio(rdev->bios, bios, size);
- bus_space_unmap(bst, bsh, size);
+
return true;
}
#endif
@@ -156,7 +148,6 @@ static bool radeon_read_bios(struct radeon_device *rdev)
#else
static bool radeon_read_bios(struct radeon_device *rdev)
{
- uint8_t __iomem *bios;
bus_size_t size;
pcireg_t address, mask;
bus_space_handle_t romh;
@@ -174,27 +165,22 @@ static bool radeon_read_bios(struct radeon_device *rdev)
size = PCI_ROM_SIZE(mask);
if (size == 0)
return false;
- rc = bus_space_map(rdev->memt, PCI_ROM_ADDR(address), size,
- BUS_SPACE_MAP_LINEAR, &romh);
+ rc = bus_space_map(rdev->memt, PCI_ROM_ADDR(address), size, 0, &romh);
if (rc != 0) {
printf(": can't map PCI ROM (%d)\n", rc);
return false;
}
- bios = (uint8_t *)bus_space_vaddr(rdev->memt, romh);
- if (!bios) {
- printf(": bus_space_vaddr failed\n");
- return false;
- }
-
- if (size == 0 || bios[0] != 0x55 || bios[1] != 0xaa)
- goto fail;
+
rdev->bios = kmalloc(size, GFP_KERNEL);
- memcpy(rdev->bios, bios, size);
+ bus_space_read_region_1(rdev->memt, romh, 0, rdev->bios, size);
bus_space_unmap(rdev->memt, romh, size);
+
+ if (size == 0 || rdev->bios[0] != 0x55 || rdev->bios[1] != 0xaa) {
+ kfree(rdev->bios);
+ rdev->bios = NULL;
+ return false;
+ }
return true;
-fail:
- bus_space_unmap(rdev->memt, romh, size);
- return false;
}
#endif