Skip to content

Commit

Permalink
virtio_mmio: Remove unneeded use of libmetal device
Browse files Browse the repository at this point in the history
A virtual metal_device is created, then the needed IO regions are created
and added to this device. Immediately we extract these same regions back
out and make use of them. There is no reason to do this, instead simply
use the created IO regions.

This also removes the need to have struct metal_device defined to have
more than one IO region (METAL_MAX_DEVICE_REGIONS), which is not the
default and can change per-platform. If the libmetal library was built
with the default value for METAL_MAX_DEVICE_REGIONS, then this would
have led to runtime failures.

Signed-off-by: Andrew Davis <[email protected]>
  • Loading branch information
glneo authored and arnopo committed Jul 5, 2024
1 parent 856680e commit 6780dd2
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 40 deletions.
3 changes: 0 additions & 3 deletions lib/include/openamp/virtio_mmio.h
Original file line number Diff line number Diff line change
Expand Up @@ -148,9 +148,6 @@ struct virtio_mmio_device {
/** Pre-shared memory space metal_io_region */
struct metal_io_region *shm_io;

/** Shared memory device */
struct metal_device shm_device;

/** VIRTIO device configuration space */
struct virtio_mmio_dev_mem cfg_mem;

Expand Down
48 changes: 11 additions & 37 deletions lib/virtio_mmio/virtio_mmio_drv.c
Original file line number Diff line number Diff line change
Expand Up @@ -141,46 +141,20 @@ const struct virtio_dispatch virtio_mmio_dispatch = {
static int virtio_mmio_get_metal_io(struct virtio_device *vdev, uintptr_t virt_mem_ptr,
uintptr_t cfg_mem_ptr)
{
struct metal_device *device;
int32_t err;
struct virtio_mmio_device *vmdev = metal_container_of(vdev,
struct virtio_mmio_device, vdev);

/* Setup shared memory device */
vmdev->shm_device.regions[0].physmap = (metal_phys_addr_t *)&vmdev->shm_mem.base;
vmdev->shm_device.regions[0].virt = (void *)virt_mem_ptr;
vmdev->shm_device.regions[0].size = vmdev->shm_mem.size;

VIRTIO_ASSERT((METAL_MAX_DEVICE_REGIONS > 1),
"METAL_MAX_DEVICE_REGIONS must be greater that 1");

vmdev->shm_device.regions[1].physmap = (metal_phys_addr_t *)&vmdev->cfg_mem.base;
vmdev->shm_device.regions[1].virt = (void *)cfg_mem_ptr;
vmdev->shm_device.regions[1].size = vmdev->cfg_mem.size;

err = metal_register_generic_device(&vmdev->shm_device);
if (err) {
metal_log(METAL_LOG_ERROR, "Couldn't register shared memory device: %d\n", err);
return err;
}

err = metal_device_open("generic", vmdev->shm_device.name, &device);
if (err) {
metal_log(METAL_LOG_ERROR, "metal_device_open failed: %d", err);
return err;
}

vmdev->shm_io = metal_device_io_region(device, 0);
if (!vmdev->shm_io) {
metal_log(METAL_LOG_ERROR, "metal_device_io_region failed to get region 0");
return err;
}

vmdev->cfg_io = metal_device_io_region(device, 1);
if (!vmdev->cfg_io) {
metal_log(METAL_LOG_ERROR, "metal_device_io_region failed to get region 1");
return err;
}
/* Setup shared memory region */
vmdev->shm_io = metal_allocate_memory(sizeof(*vmdev->shm_io));
metal_io_init(vmdev->shm_io, (void *)virt_mem_ptr,
(metal_phys_addr_t *)&vmdev->shm_mem.base,
vmdev->shm_mem.size, -1, 0, NULL);

/* Setup configuration region */
vmdev->cfg_io = metal_allocate_memory(sizeof(*vmdev->cfg_io));
metal_io_init(vmdev->cfg_io, (void *)cfg_mem_ptr,
(metal_phys_addr_t *)&vmdev->cfg_mem.base,
vmdev->cfg_mem.size, -1, 0, NULL);

return 0;
}
Expand Down

0 comments on commit 6780dd2

Please sign in to comment.