Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

collect configuration of mmio devices #968

Merged
merged 6 commits into from
Nov 9, 2023
Merged

Conversation

stlankes
Copy link
Contributor

@stlankes stlankes commented Oct 29, 2023

Firecracker pass the configuration of all mmio device by a Linux kernel parameter This parameter is defined as followd:

virtio_mmio.device=
[VMMIO] Memory mapped virtio (platform) device.

  <size>@<baseaddr>:<irq>[:<id>]

where:
:= size (can use standard suffixes like K, M and G)
:= physical base address
:= interrupt number (as passed to request_irq())
:= (optional) platform device id
example:
virtio_mmio.device=1K@0x100b0000:48:7
Can be used multiple times for multiple devices.

This patch parse the command line and store the string <size>@<baseaddr>:<irq>[:<id>] in a vector, which is part of CLI. The vector is used to find the network device on a microVM.

In addition, the network driver support devices, which doesn't support VIRTIO_NET_F_STATUS.

This PR based on preliminary work from @duanyu-yu

@stlankes stlankes requested a review from mkroening October 29, 2023 23:31
@stlankes stlankes marked this pull request as draft October 29, 2023 23:36
@stlankes stlankes requested a review from duanyu-yu November 3, 2023 09:08
@stlankes stlankes marked this pull request as ready for review November 3, 2023 21:04
@mkroening mkroening force-pushed the fc branch 3 times, most recently from 1b8fe72 to 7932411 Compare November 9, 2023 12:40
stlankes and others added 6 commits November 9, 2023 13:40
Firecracker pass the configuration of all mmio device by a Linux kernel parameter
This parameter is defined as followd:

virtio_mmio.device=
   [VMMIO] Memory mapped virtio (platform) device.

      <size>@<baseaddr>:<irq>[:<id>]
   where:
      <size>     := size (can use standard suffixes like K, M and G)
      <baseaddr> := physical base address
      <irq>      := interrupt number (as passed to request_irq())
      <id>       := (optional) platform device id
   example:
                 virtio_mmio.device=1K@0x100b0000:48:7
   Can be used multiple times for multiple devices.

This patch parse the command line and store the string
<size>@<baseaddr>:<irq>[:<id>] in a vector, which is part of CLI.

This PR based on preliminary work of @duanyu-yu

Co-authored-by: Yu Duan <yu_duan@yahoo.com>
Firecracker parse the linux argument virtio_mmio.device to the
kernel, which specifies the mmio addresses for VirtIO devices.
This patch uses these arguments to find the network interface.wq:
This feature is not required. If VIRTIO_NET_F_STATUS is not announce,
the driver assumes that the link is always active.

This behavior is conform to the VirtIO standard.
Copy link
Member

@mkroening mkroening left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me! 👍

Waiting on the CI on each commit before merging.

@mkroening mkroening added this pull request to the merge queue Nov 9, 2023
Merged via the queue into hermit-os:main with commit b512910 Nov 9, 2023
27 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants