gpu/intel: use read out gttm size

and don't assume 8M, which leads to Region_conflicts if size is >8M (X201).

Issue #4260
This commit is contained in:
Alexander Boettcher 2021-09-23 11:59:38 +02:00 committed by Norman Feske
parent 727fa86088
commit 0f72356570

View File

@ -94,13 +94,18 @@ class Igd::Resources : Genode::Noncopyable
{ {
using off_t = Genode::off_t; using off_t = Genode::off_t;
size_t const gttm_half_size = gttmmadr_size() / 2;
/* GTT starts at half of the mmio memory */
off_t const gtt_offset = gttm_half_size;
if (gttm_half_size < GTT_RESERVED) {
Genode::error("GTTM size too small");
return;
}
_gttmmadr_rm.construct(_rm_connection.create((gttmmadr_size()))); _gttmmadr_rm.construct(_rm_connection.create((gttmmadr_size())));
/* GTT starts at half of the mmio memory, assumed size is 8 MB */ /* attach actual iomem + reserved */
off_t const gtt_offset = gttmmadr_size() / 2;
size_t const gtt_size = 8ul << 20;
/* attach actual iomem + reserved = 8 MB */
_gttmmadr_rm->attach_at(_gttmmadr_ds, 0, gtt_offset); _gttmmadr_rm->attach_at(_gttmmadr_ds, 0, gtt_offset);
/* attach beginning of GTT */ /* attach beginning of GTT */
@ -108,13 +113,14 @@ class Igd::Resources : Genode::Noncopyable
/* attach the rest of the GTT as dummy RAM */ /* attach the rest of the GTT as dummy RAM */
Genode::Ram_dataspace_capability dummmy_gtt_ds { _env.ram().alloc(PAGE_SIZE) }; Genode::Ram_dataspace_capability dummmy_gtt_ds { _env.ram().alloc(PAGE_SIZE) };
size_t remainder = gtt_size - GTT_RESERVED; size_t remainder = gttm_half_size - GTT_RESERVED;
for (off_t offset = gtt_offset + GTT_RESERVED; for (off_t offset = gtt_offset + GTT_RESERVED;
remainder > 0; remainder > 0;
offset += PAGE_SIZE, remainder -= PAGE_SIZE) { offset += PAGE_SIZE, remainder -= PAGE_SIZE) {
_rm_connection.retry_with_upgrade(Genode::Ram_quota{4096}, _rm_connection.retry_with_upgrade(Genode::Ram_quota{4096},
Genode::Cap_quota{8}, [&]() { Genode::Cap_quota{8}, [&]() {
_gttmmadr_rm->attach_at(dummmy_gtt_ds, offset, PAGE_SIZE); }); _gttmmadr_rm->attach_at(dummmy_gtt_ds, offset, PAGE_SIZE);
});
} }
} }
@ -311,6 +317,9 @@ class Igd::Resources : Genode::Noncopyable
if (!_gttmmadr_rm.constructed()) if (!_gttmmadr_rm.constructed())
_create_gttmmadr_rm(); _create_gttmmadr_rm();
if (!_gttmmadr_rm.constructed())
return { };
return static_cap_cast<Io_mem_dataspace>(_gttmmadr_rm->dataspace()); return static_cap_cast<Io_mem_dataspace>(_gttmmadr_rm->dataspace());
} }