1. 21 11月, 2019 2 次提交
  2. 15 11月, 2019 9 次提交
    • P
      vircgroup: introduce virCgroupV2DevicesGetKey · b18b0ce6
      Pavel Hrdina 提交于
      Device rules are stored in BPF map that is a hash type, this function
      will create a key based on major and minor id of device.
      Signed-off-by: NPavel Hrdina <phrdina@redhat.com>
      Reviewed-by: NJán Tomko <jtomko@redhat.com>
      b18b0ce6
    • P
      vircgroup: introduce virCgroupV2DeviceGetPerms · 63cfe7b8
      Pavel Hrdina 提交于
      Signed-off-by: NPavel Hrdina <phrdina@redhat.com>
      Reviewed-by: NJán Tomko <jtomko@redhat.com>
      63cfe7b8
    • P
      vircgroup: introduce virCgroupV2DevicesRemoveProg · 6a24bd75
      Pavel Hrdina 提交于
      We need to close our FD that we have for BPF program and map in order
      to let kernel remove all resources once the cgroup is removed as well.
      Signed-off-by: NPavel Hrdina <phrdina@redhat.com>
      Reviewed-by: NJán Tomko <jtomko@redhat.com>
      6a24bd75
    • P
      vircgroup: introduce virCgroupV2DevicesPrepareProg · ef747499
      Pavel Hrdina 提交于
      This function will be called for every virCgroup(Allow|Deny)* API in
      order to prepare BPF program for guest.  Since libvirtd can be restarted
      at any point we will first try to detect existing progam, if there is
      none we will create a new empty BPF program and lastly if we don't have
      any space left in the existing BPF map we will create a new copy of the
      BPF map with more space and attach a new program with that map into the
      guest cgroup.
      
      This solution allows us to start with reasonably small BPF map consuming
      only small amount of memory and if needed we can easily extend the BPF
      map if there is a lot of host devices used in guest or if user wants to
      hot-plug a lot of devices once the guest is running.
      
      Since there is no way how to reallocate existing BPF map we need to
      create a new copy if we run out of space in current BPF map.
      
      This overcomes all the limitations in BPF:
      
          - map used in program has to be created before the program is loaded
            into kernel
      
          - once map is created you cannot change its size
      
          - you cannot replace map in existing program
      
          - you cannot use an array of maps because it can store FD to maps
            of one specific size so we would not be able to use it to overcome
            the second issue
      Signed-off-by: NPavel Hrdina <phrdina@redhat.com>
      Reviewed-by: NJán Tomko <jtomko@redhat.com>
      ef747499
    • P
      vircgroup: introduce virCgroupV2DevicesCreateProg · afa27886
      Pavel Hrdina 提交于
      This function creates new BPF program with new empty BPF map with the
      default size and attaches it to the guest cgroup.
      Signed-off-by: NPavel Hrdina <phrdina@redhat.com>
      Reviewed-by: NJán Tomko <jtomko@redhat.com>
      afa27886
    • P
      vircgroup: introduce virCgroupV2DevicesDetectProg · ce11a5c5
      Pavel Hrdina 提交于
      This function will be called if libvirtd was restarted while some
      domains were running.  It will try to detect existing programs attached
      to the guest cgroup.
      Signed-off-by: NPavel Hrdina <phrdina@redhat.com>
      Reviewed-by: NJán Tomko <jtomko@redhat.com>
      ce11a5c5
    • P
      vircgroup: introduce virCgroupV2DevicesAttachProg · 48423a0b
      Pavel Hrdina 提交于
      This function loads the BPF prog with prepared map into kernel and
      attaches it into guest cgroup.  It can be also used to replace existing
      program in the cgroup if we need to resize BPF map to store more rules
      for devices. The old program will be closed and removed from kernel.
      
      There are two possible ways how to create BPF program:
      
          - One way is to write simple C-like code which can by compiled into
            BPF object file which can be loaded into kernel using elfutils.
      
          - The second way is to define macros which look like assembler
            instructions and can be used directly to create BPF program that
            can be directly loaded into kernel.
      
      Since the program is not too complex we can use the second option.
      
      If there is no program, all devices are allowed, if there is some
      program it is executed and based on the exit status the access is
      denied for 0 and allowed for 1.
      
      Our program will follow these rules:
      
          - first it will try to look for the specific key using major and
            minor to see if there is any rule for that specific device
      
          - if there is no specific rule it will try to look for any rule that
            matches only major of the device
      
          - if there is no match with major it will try the same but with
            minor of the device
      
          - as the last attempt it will try to look for rule for all devices
            and if there is no match it will return 0 to deny that access
      Signed-off-by: NPavel Hrdina <phrdina@redhat.com>
      Reviewed-by: NJán Tomko <jtomko@redhat.com>
      48423a0b
    • P
      vircgroup: introduce virCgroupV2DevicesAvailable · 30b6ddc4
      Pavel Hrdina 提交于
      There is no exact way how to figure out whether BPF devices support is
      compiled into kernel.  One way is to check kernel configure options but
      this is not reliable as it may not be available.  Let's try to do
      syscall to which will list BPF cgroup device programs.
      Signed-off-by: NPavel Hrdina <phrdina@redhat.com>
      Reviewed-by: NJán Tomko <jtomko@redhat.com>
      30b6ddc4
    • P
      util: introduce virbpf helpers · 07946d6e
      Pavel Hrdina 提交于
      In order to implement devices controller with cgroup v2 we need to
      add support for BPF programs, cgroup v2 doesn't have devices controller.
      
      This introduces required helpers wrapping linux syscalls.
      Signed-off-by: NPavel Hrdina <phrdina@redhat.com>
      Reviewed-by: NJán Tomko <jtomko@redhat.com>
      07946d6e
  3. 14 11月, 2019 2 次提交
  4. 13 11月, 2019 1 次提交
  5. 12 11月, 2019 3 次提交
  6. 25 10月, 2019 3 次提交
  7. 21 10月, 2019 7 次提交
  8. 19 10月, 2019 1 次提交
  9. 18 10月, 2019 1 次提交
  10. 16 10月, 2019 1 次提交
  11. 14 10月, 2019 1 次提交
  12. 12 10月, 2019 1 次提交
  13. 10 10月, 2019 1 次提交
  14. 08 10月, 2019 1 次提交
    • M
      driver: Introduce virDriverShouldAutostart() · ee16a195
      Michal Privoznik 提交于
      Some of objects we manage can be autostarted on libvirtd startup
      (e.g. domains, network, storage pools). The idea was that when
      the host is started up these objects are started too without need
      of user intervention. However, with the latest daemon split and
      switch to socket activated, short lived daemons (we put --timeout
      120 onto each daemon's command line) this doesn't do what we want
      it to. The problem is not new though, we already had the session
      daemon come and go and we circumvented this problem by
      documenting it (see v4.10.0-92-g61b4e8aa). But now that we meet
      the same problem at all fronts it's time to deal with it.
      
      The solution implemented in this commit is to have a file (one
      per each driver) that:
      
        1) if doesn't exist, is created and autostart is allowed for
           given driver,
      
        2) if it does exist, then autostart is suppressed for given
           driver.
      
      All the files live in a location that doesn't survive host
      reboots (/var/run/ for instance) and thus the file is
      automatically not there on fresh host boot.
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      Reviewed-by: NDaniel P. Berrangé <berrange@redhat.com>
      ee16a195
  15. 07 10月, 2019 1 次提交
  16. 27 9月, 2019 2 次提交
  17. 25 9月, 2019 2 次提交
    • P
      util: typedparam: Simplify handling of lists of typed parameters · 33773355
      Peter Krempa 提交于
      Introduce a new set of helpers including a new data structure which
      simplifies keeping and construction of lists of typed parameters.
      
      The use of VIR_RESIZE_N in the virTypedParamsAdd API has performance
      benefits but requires passing around 3 arguments. Use of them lead to a
      set of macros with embedded jumps used in the qemu statistics code.
      
      This patch introduces 'virTypedParamList' type which aggregates the
      necessary list-keeping variables and also a new set of functions to add
      new typed parameters to a list.
      
      These new helpers use printf-like format string and arguments to format
      the argument name as the stats code often uses indexed typed parameters.
      
      The accessor function then allows extracting the typed parameter list in
      the same format as virTypedParamsAdd* functions would do.
      
      One additional benefit is also that the list function can easily be used
      with VIR_AUTOPTR.
      Signed-off-by: NPeter Krempa <pkrempa@redhat.com>
      Reviewed-by: NJán Tomko <jtomko@redhat.com>
      33773355
    • P
      util: typedparam: Move and unexport virTypedParameterAssignFromStr · e532aa61
      Peter Krempa 提交于
      The function is only used as a helper in virTypedParamsAddFromString.
      Make it static and move it to virtypedparam-public.c.
      Signed-off-by: NPeter Krempa <pkrempa@redhat.com>
      Reviewed-by: NJán Tomko <jtomko@redhat.com>
      e532aa61
  18. 19 9月, 2019 1 次提交