On a Wednesday in 2025, Kirill Shchetiniuk wrote:
Thanks Jan,
Didn’t noticed the issue with the white symbols when submitted a patch, next time will
keep it in mind and be careful. Btw, do we have some tools to check and warn such possible
issues?
For the extra/removed lines, git diff/git show.
For the translatable error message?
I'm afraid we cannot do that automatically - there are places like
--help output where we use multiple spaces to align columns in the
output.
If you left the error message untouched, I assume eventually some
translator would show up and report it / send a fix.
Jano
Kirill
> 2. 4. 2025 v 18:36, Ján Tomko <jtomko(a)redhat.com>:
>
> On a Tuesday in 2025, Kirill Shchetiniuk via Devel wrote:
>> When the new CH monitor was started, it ran as a non-daemonized
>> process and was a child of the CH driver process. This led to a
>> situation where if the CH driver died, the monitor process were
>> killed too, terminating the running VM under the monitor. This
>> led to termination of all VM started under the libvirt.
>>
>> Make new monitor running daemonized to avoid VMs shutdown when
>> driver dies. Also added a pidfile its preparetion to be able
>> to aquire daemon's PID.
>>
>> Signed-off-by: Kirill Shchetiniuk <kshcheti(a)redhat.com>
>> ---
>> src/ch/ch_domain.c | 1 +
>> src/ch/ch_domain.h | 1 +
>> src/ch/ch_monitor.c | 24 ++++++++++++++++++++++--
>> src/ch/ch_process.c | 16 ++++++++++++++++
>> 4 files changed, 40 insertions(+), 2 deletions(-)
>>
>> diff --git a/src/ch/ch_monitor.c b/src/ch/ch_monitor.c
>> index 0ba927a194..1dc085a755 100644
>> --- a/src/ch/ch_monitor.c
>> +++ b/src/ch/ch_monitor.c
>> @@ -644,6 +648,7 @@ virCHMonitorNew(virDomainObj *vm, virCHDriverConfig *cfg, int
logfile)
>> virCommandSetErrorFD(cmd, &logfile);
>> virCommandNonblockingFDs(cmd);
>> virCommandSetUmask(cmd, 0x002);
>> +
>
> Nitpick: unrelated whitespace change. In some projects, these should be
> squashed together with the patch changing the function as you've done here,
> but in libvirt we separate them from the functional changes
> (it's easier to review a patch that changes just whitespace, then the
> actual functional changes are smaller)
>
>> socket_fd = chMonitorCreateSocket(mon->socketpath);
>> if (socket_fd < 0) {
>> virReportSystemError(errno,
>> @@ -655,13 +660,28 @@ virCHMonitorNew(virDomainObj *vm, virCHDriverConfig *cfg,
int logfile)
>> virCommandAddArg(cmd, "--api-socket");
>> virCommandAddArgFormat(cmd, "fd=%d", socket_fd);
>> virCommandPassFD(cmd, socket_fd, VIR_COMMAND_PASS_FD_CLOSE_PARENT);
>> -
>
> This newline could have stayed - it seprated the arguments.
>
>> virCommandAddArg(cmd, "--event-monitor");
>> virCommandAddArgFormat(cmd, "path=%s", mon->eventmonitorpath);
>> + virCommandSetPidFile(cmd, priv->pidfile);
>> + virCommandDaemonize(cmd);
>>
>> /* launch Cloud-Hypervisor socket */
>> - if (virCommandRunAsync(cmd, &mon->pid) < 0)
>> + rv = virCommandRun(cmd, NULL);
>> +
>> + if (rv == 0) {
>> + if ((rv = virPidFileReadPath(priv->pidfile, &mon->pid)) <
0) {
>> + virReportSystemError(-rv,
>> + _("Domain %1$s didn't show
up"),
>
> Not a nitpick - double spaces in the error message. This is
> user-visible.
>
> Jano
>
>> + vm->def->name);
>> + return NULL;
>> + }
>> + VIR_DEBUG("CH vm=%p name=%s running with pid=%lld",
>> + vm, vm->def->name, (long long)vm->pid);
>> + } else {
>> + VIR_DEBUG("CH vm=%p name=%s failed to spawn",
>> + vm, vm->def->name);
>> return NULL;
>> + }
>>
>> /* open the reader end of fifo before start Event Handler */
>> while ((event_monitor_fd = open(mon->eventmonitorpath, O_RDONLY)) < 0)
{
> <signature.asc>