Message ID | 20230426145932.3340-1-alejandro.vallejo@cloud.com (mailing list archive) |
---|---|
Headers | show |
Series | Rationalize usage of xc_domain_getinfo{,list}() | expand |
On 26/04/2023 3:59 pm, Alejandro Vallejo wrote: > xc_domain_getinfo() returns the list of domains with domid >= first_domid. > It does so by repeatedly invoking XEN_DOMCTL_getdomaininfo, which leads to > unintuitive behaviour (asking for domid=1 might succeed returning domid=2). > Furthermore, N hypercalls are required whereas the equivalent functionality > can be achieved using with XEN_SYSCTL_getdomaininfo. > > Ideally, we want a DOMCTL interface that operates over a single precisely > specified domain and a SYSCTL interface that can be used for bulk queries. > > All callers of xc_domain_getinfo() that are better off using SYSCTL are > migrated to use that instead. That includes callers performing domain > discovery and those requesting info for more than 1 domain per hypercall. > > A new xc_domain_getinfo_single() is introduced with stricter semantics than > xc_domain_getinfo() (failing if domid isn't found) to migrate the rest to. > > With no callers left the xc_dominfo_t structure and the xc_domain_getinfo() > call itself can be cleanly removed, and the DOMCTL interface simplified to > only use its fastpath. > > With the DOMCTL ammended, the new xc_domain_getinfo_single() drops its > stricter check, becoming a simple wrapper to invoke the hypercall itself. > > Alejandro Vallejo (7): > tools: Make some callers of xc_domain_getinfo use > xc_domain_getinfolist > tools: Create xc_domain_getinfo_single() > tools: Refactor the console/io.c to avoid using xc_domain_getinfo() > tools: Make init-xenstore-domain use xc_domain_getinfolist() > tools: Modify single-domid callers of xc_domain_getinfolist > tools: Use new xc function for some xc_domain_getinfo calls > domctl: Modify getdomaininfo to fail if domid is not found The patchew run found one single failure, https://gitlab.com/xen-project/patchew/xen/-/jobs/4183881202 This part looks reasonably fatal: * Starting local ... * Executing "/etc/local.d/xen.start" ...Starting /usr/local/sbin/xenstored... /etc/xen/scripts/launch-xenstore: line 90: echo: write error: Invalid argument Setting domain 0 name, domid and JSON config... Done setting up Dom0 Starting xenconsoled... except it was only the part trying to set the OOM score after starting xenstored, and the only way that plausibly fails is if the pidfile was bad. And then the other print messages are clearly out of order. I've rerun the pipeline a second time, https://gitlab.com/xen-project/patchew/xen/-/pipelines/850230144, to see if gitlab thinks it is a reliable or unreliable failure. But, there's a plenty of other stuff in this log which is concerning. Stefano, Michal: * Starting networking ...awk: /etc/network/interfaces: No such file or directory * ERROR: networking failed to start The domains ought to have a interfaces file with "auto eth0", or even nothing. Alpine clearly isn't expecting the absence of the file at all. The fact the ping test passes usually means that this error isn't as fatal as it makes out. Next, * Executing: /lib/rc/sh/openrc-run.sh /lib/rc/sh/openrc-run.sh /etc/init.d/modloop start * Mounting modloop ... [ !! ] * ERROR: modloop failed to start Not sure what modloop is, but this doesn't look healthy. Next, * Loading modules ... * Processing /etc/modules modprobe: can't change directory to '/lib/modules': No such file or directory This probably just wants an empty dir in the filesystem. I could go on, but I wont. One thing that we do need however is /var/log/xen/* pulled into the artefacts of the job, because if there really is a real xenstored problem hiding in this series, there's no way to debug it with the current artefacts collected. ~Andrew
On 26/04/2023 11:30 pm, Andrew Cooper wrote: > I've rerun the pipeline a second time, > https://gitlab.com/xen-project/patchew/xen/-/pipelines/850230144, to see > if gitlab thinks it is a reliable or unreliable failure. It passed the second time, so I'm pretty confident this is a buggy test with a rare race condition, rather than a bug in the series under test. ~Andrew