Gentoo Forums
Gentoo Forums
Gentoo Forums
Quick Search: in
Error starting network 'default': Unable to create bridge vi
View unanswered posts
View posts from last 24 hours

 
Reply to topic    Gentoo Forums Forum Index Networking & Security
View previous topic :: View next topic  
Author Message
cwc
Veteran
Veteran


Joined: 20 Mar 2006
Posts: 1305
Location: Tri-Cities, WA USA

PostPosted: Wed May 01, 2024 7:33 pm    Post subject: Error starting network 'default': Unable to create bridge vi Reply with quote

From virt-manager
Error starting network 'default': Unable to create bridge virbr0: Package not installed

From terminal:

$ sudo virsh net-start default
error: Failed to start network default
error: Unable to create bridge virbr0: Package not installed

$ virsh net-start default
error: failed to get network 'default'
error: Network not found: no network with matching name 'default'


Please throw me a bone on how to approach this problem.


I am trying to get QEMU working with VIRT-MANAGER to run Linux VMS (Redhat, Centos)
_________________
Without diversity there can be no evolution:)
Back to top
View user's profile Send private message
grknight
Retired Dev
Retired Dev


Joined: 20 Feb 2015
Posts: 1693

PostPosted: Wed May 01, 2024 7:49 pm    Post subject: Reply with quote

What are the USE flags on app-emulation/libvirt? At minimum, the libvirtd and virt-network USE are required for the default network to exist.
In addition, ensure the libvirtd service is started at boot time (both OpenRC and systemd).
Back to top
View user's profile Send private message
cwc
Veteran
Veteran


Joined: 20 Mar 2006
Posts: 1305
Location: Tri-Cities, WA USA

PostPosted: Wed May 01, 2024 8:50 pm    Post subject: Reply with quote

grknight wrote:
What are the USE flags on app-emulation/libvirt? At minimum, the libvirtd and virt-network USE are required for the default network to exist.
In addition, ensure the libvirtd service is started at boot time (both OpenRC and systemd).


Thank you. I'm using openrc.
I restarted libvirtd and it is set to start on boot.
Is there a config file I need to edit?
I am also going to check to make sure I have the kernel flags set from this doc: https://wiki.gentoo.org/wiki/Libvirt

Code:

emerge -pv app-emulation/libvirt

These are the packages that would be merged, in order:

Calculating dependencies... done!
Dependency resolution took 7.79 s (backtrack: 0/20).

[ebuild   R    ] app-emulation/libvirt-9.8.0-r2:0/9.8.0::gentoo  USE="caps libvirtd nls policykit qemu udev virt-network -apparmor -audit -bash-completion -dtrace -firewalld -fuse -glusterfs -iscsi -iscsi-direct -libssh -libssh2 -lvm -lxc -nfs -numa (-openvz) -parted -pcap -rbd -sasl (-selinux) -test -verify-sig -virtualbox -wireshark-plugins -xen -zfs" 0 KiB




_________________
Without diversity there can be no evolution:)
Back to top
View user's profile Send private message
grknight
Retired Dev
Retired Dev


Joined: 20 Feb 2015
Posts: 1693

PostPosted: Wed May 01, 2024 11:04 pm    Post subject: Reply with quote

What is in /etc/libvirt/qemu/networks/ ? This should include a default.xml which should be valid xml and libvirt can start.
Back to top
View user's profile Send private message
cwc
Veteran
Veteran


Joined: 20 Mar 2006
Posts: 1305
Location: Tri-Cities, WA USA

PostPosted: Thu May 02, 2024 12:09 am    Post subject: Reply with quote

grknight wrote:
What is in /etc/libvirt/qemu/networks/ ? This should include a default.xml which should be valid xml and libvirt can start.


thank you . this would be a NAT. I'm 192.168.1.x
I'm recompiling my kernel right now.
Code:

pwd
/etc/libvirt/qemu/networks
cwc@yoda /etc/libvirt/qemu/networks $ sudo more default.xml
<!--
WARNING: THIS IS AN AUTO-GENERATED FILE. CHANGES TO IT ARE LIKELY TO BE
OVERWRITTEN AND LOST. Changes to this xml configuration should be made using:
  virsh net-edit default
or other application using the libvirt API.
-->

<network>
  <name>default</name>
  <uuid>23ac86af-2995-420d-9dad-da65db9a0646</uuid>
  <forward mode='nat'/>
  <bridge name='virbr0' stp='on' delay='0'/>
  <mac address='52:54:00:c1:de:1b'/>
  <ip address='192.168.122.1' netmask='255.255.255.0'>
    <dhcp>
      <range start='192.168.122.2' end='192.168.122.254'/>
    </dhcp>
  </ip>
</network>


_________________
Without diversity there can be no evolution:)
Back to top
View user's profile Send private message
cwc
Veteran
Veteran


Joined: 20 Mar 2006
Posts: 1305
Location: Tri-Cities, WA USA

PostPosted: Thu May 02, 2024 2:44 pm    Post subject: Reply with quote

recompiled kernel
reinstalled packages
Now I get a usb error from virt-manager

Unable to complete install: 'unsupported configuration: USB redirection is not supported by this version of QEMU'
_________________
Without diversity there can be no evolution:)
Back to top
View user's profile Send private message
Hu
Administrator
Administrator


Joined: 06 Mar 2007
Posts: 21741

PostPosted: Thu May 02, 2024 3:33 pm    Post subject: Reply with quote

Did you set the relevant USE flags on qemu? usb and usbredir look like good candidates.
Back to top
View user's profile Send private message
cwc
Veteran
Veteran


Joined: 20 Mar 2006
Posts: 1305
Location: Tri-Cities, WA USA

PostPosted: Thu May 02, 2024 5:40 pm    Post subject: Reply with quote

Hu wrote:
Did you set the relevant USE flags on qemu? usb and usbredir look like good candidates.


reinstalled qemu

still no luck .

Code:

yoda /etc/libvirt # virsh list
 Id   Name   State
--------------------

yoda /etc/libvirt # virsh net-list
 Name   State   Autostart   Persistent
----------------------------------------

yoda /etc/libvirt # virsh net-start default
error: Failed to start network default
error: Unable to create bridge virbr0: Package not installed



_________________
Without diversity there can be no evolution:)
Back to top
View user's profile Send private message
grknight
Retired Dev
Retired Dev


Joined: 20 Feb 2015
Posts: 1693

PostPosted: Thu May 02, 2024 5:50 pm    Post subject: Reply with quote

What does virsh net-list --all report?
Back to top
View user's profile Send private message
cwc
Veteran
Veteran


Joined: 20 Mar 2006
Posts: 1305
Location: Tri-Cities, WA USA

PostPosted: Thu May 02, 2024 7:26 pm    Post subject: Reply with quote

grknight wrote:
What does virsh net-list --all report?

thank you

# virsh net-list --all
Name State Autostart Persistent
----------------------------------------------
default inactive yes yes
_________________
Without diversity there can be no evolution:)
Back to top
View user's profile Send private message
pingtoo
l33t
l33t


Joined: 10 Sep 2021
Posts: 933
Location: Richmond Hill, Canada

PostPosted: Thu May 02, 2024 9:40 pm    Post subject: Reply with quote

cwc wrote:
Hu wrote:
Did you set the relevant USE flags on qemu? usb and usbredir look like good candidates.


reinstalled qemu

still no luck .

Code:

yoda /etc/libvirt # virsh list
 Id   Name   State
--------------------

yoda /etc/libvirt # virsh net-list
 Name   State   Autostart   Persistent
----------------------------------------

yoda /etc/libvirt # virsh net-start default
error: Failed to start network default
error: Unable to create bridge virbr0: Package not installed



The error was not relate to qemu, but libvirt. it is because the "bridge" kernel module is not avaliable. So you either need to load "bridge" module by "modprobe bridge" or rebuild kernel with "bridge" module compiled in (or as module) if not previously configured)
Back to top
View user's profile Send private message
cwc
Veteran
Veteran


Joined: 20 Mar 2006
Posts: 1305
Location: Tri-Cities, WA USA

PostPosted: Thu May 02, 2024 10:20 pm    Post subject: Reply with quote

pingtoo wrote:

The error was not relate to qemu, but libvirt. it is because the "bridge" kernel module is not avaliable. So you either need to load "bridge" module by "modprobe bridge" or rebuild kernel with "bridge" module compiled in (or as module) if not previously configured)


Thank you

I have <*> 802.1d Ethernet Bridging set in the kernel not as a module

Do I follow this doc: https://wiki.gentoo.org/wiki/Network_bridge ?


Code:
FILE /etc/conf.d/netAdd bridge device example

# Set up the initial layer 2 bridge interface
bridge_br0="enp1s0 enp2s0"

# Bridge static config
config_br0="192.168.26.199 netmask 255.255.255.0"
routes_br0="default via 192.168.26.254"

bridge_forward_delay_br0=0
bridge_hello_time_br0=1000

_________________
Without diversity there can be no evolution:)
Back to top
View user's profile Send private message
pingtoo
l33t
l33t


Joined: 10 Sep 2021
Posts: 933
Location: Richmond Hill, Canada

PostPosted: Fri May 03, 2024 2:44 pm    Post subject: Reply with quote

cwc,

Quote:
Do I follow this doc: https://wiki.gentoo.org/wiki/Network_bridge ?
Not yet. let's test some more before we go there.


From the execution path I learned from source code, it seems to unlikely you will get "Package not installed" if your running kernel actually have the "bridge" module loaded.

Here is the execution path I learned
https://github.com/libvirt/libvirt/blob/9804ded60f769b7875b689eecd73364b251c9beb/src/util/virnetdevbridge.c#L405:

#if defined(WITH_STRUCT_IFREQ) && defined(SIOCBRADDBR)
static int
virNetDevBridgeCreateWithIoctl(const char *brname,
                               const virMacAddr *mac)
{
    VIR_AUTOCLOSE fd = -1;

    if ((fd = virNetDevSetupControl(NULL, NULL)) < 0)
        return -1;

    if (ioctl(fd, SIOCBRADDBR, brname) < 0) {
        virReportSystemError(errno,
                             _("Unable to create bridge %1$s"), brname);
        return -1;
    }

    if (virNetDevSetMAC(brname, mac) < 0) {
        virErrorPtr savederr;

        virErrorPreserveLast(&savederr);
        ignore_value(ioctl(fd, SIOCBRDELBR, brname));
        virErrorRestore(&savederr);
        return -1;
    }

    return 0;
}

And the linux ioctl call
https://github.com/torvalds/linux/blob/f03359bca01bf4372cf2c118cd9a987a5951b1c8/net/socket.c#L1185:
int br_ioctl_call(struct net *net, struct net_bridge *br, unsigned int cmd,
        struct ifreq *ifr, void __user *uarg)
{
   int err = -ENOPKG;

   if (!br_ioctl_hook)
      request_module("bridge");

   mutex_lock(&br_ioctl_mutex);
   if (br_ioctl_hook)
      err = br_ioctl_hook(net, br, cmd, ifr, uarg);
   mutex_unlock(&br_ioctl_mutex);

   return err;
}
The "if (br_ioctl_hook) ... not true will lead to the err=-ENOPKG
That seems the only reason you will get the message "error: Unable to create bridge virbr0: Package not installed"

I think (I don't use libvirt) the errors you got is because libvirt is responsible create the bridge interface ahead of qemu execution, so lets try to focus on that first.

I would like to verify that bridge interface can actually be created from command line.
Code:
ip link add name virbr0 address 192.168.122.1 broadcast 192.168.122.255 type bridge
If this command successfully return ($? == 0)

Try command
Code:
ip link show type bridge
Please share output

If all these commands work, then I need to dig more into source to understand why virsh net-start default failed

To delete the command line test created virbr0 use command
Code:
ip link del virbr0


If the test bridge create failed, we need to see if the running kernel actually have the "bridge" module loaded by using
Code:
namei /sys/module/bridge
if the return is
Code:
f: /sys/module/bridge
 d /
 d sys
 d module
 d bridge
May be also examine dmesg to see if there is any messages related to the bridge module.

if the namei command did not give you the output above than your running kernel does not have the "bridge" module. so you need to examine what you need to do in order to get the right kernel.

If namei command come out OK, then most likely the libvirt package have something wrong, it could be the libvirt use dev-libs/libnl is buggy need to rebuild.

There are many thing need to examine if kernel is OK, so let's dig deep when we got confirmation that kernel is good.
Back to top
View user's profile Send private message
cwc
Veteran
Veteran


Joined: 20 Mar 2006
Posts: 1305
Location: Tri-Cities, WA USA

PostPosted: Fri May 03, 2024 4:11 pm    Post subject: Reply with quote

pingtoo,

Thank you so much. This will take me a while. Lots to test and read.
I am starting from scratch. I am recompiling my kernel with the .config prior to setting up KVM.
I'm going to read and research before I dive in.
_________________
Without diversity there can be no evolution:)
Back to top
View user's profile Send private message
pingtoo
l33t
l33t


Joined: 10 Sep 2021
Posts: 933
Location: Richmond Hill, Canada

PostPosted: Fri May 03, 2024 4:53 pm    Post subject: Reply with quote

cwc.

You are welcome.

Take as long as you want. Should you need more information I will be happy to check around to see if I can find them.
Back to top
View user's profile Send private message
Display posts from previous:   
Reply to topic    Gentoo Forums Forum Index Networking & Security All times are GMT
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum