[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH v2 20/35] xen/console: introduce console_owner_domid()



On Thursday, January 9th, 2025 at 12:27 AM, Jan Beulich <jbeulich@xxxxxxxx> 
wrote:

>
>
> On 08.01.2025 23:15, Denis Mukhin wrote:
>
> > On Wednesday, January 8th, 2025 at 12:35 AM, Roger Pau Monné 
> > roger.pau@xxxxxxxxxx wrote:
> >
> > > On Wed, Jan 08, 2025 at 09:13:02AM +0100, Jan Beulich wrote:
> > >
> > > > On 08.01.2025 09:04, Roger Pau Monné wrote:
> > > >
> > > > > On Wed, Jan 08, 2025 at 08:28:32AM +0100, Jan Beulich wrote:
> > > > >
> > > > > > On 08.01.2025 00:40, Stefano Stabellini wrote:
> > > > > >
> > > > > > > On Tue, 7 Jan 2025, Jan Beulich wrote:
> > > > > > >
> > > > > > > > On 06.01.2025 19:48, Stefano Stabellini wrote:
> > > > > > > >
> > > > > > > > > On Mon, 6 Jan 2025, Jan Beulich wrote:
> > > > > > > > >
> > > > > > > > > > On 04.01.2025 05:15, Denis Mukhin wrote:
> > > > > > > > > >
> > > > > > > > > > > On Tuesday, December 10th, 2024 at 11:28 PM, Jan Beulich 
> > > > > > > > > > > jbeulich@xxxxxxxx wrote:
> > > > > > > > > > >
> > > > > > > > > > > > On 06.12.2024 05:41, Denis Mukhin via B4 Relay wrote:
> > > > > > > > > > > >
> > > > > > > > > > > > > From: Denis Mukhin dmukhin@xxxxxxxx
> > > > > > > > > > > > >
> > > > > > > > > > > > > console_owner_domid() is introduced to obtain the 
> > > > > > > > > > > > > "console owner" domain ID.
> > > > > > > > > > > > >
> > > > > > > > > > > > > The call is used in NS8250 emulator to identify the 
> > > > > > > > > > > > > case when physical xen
> > > > > > > > > > > > > console focus is owned by the domain w/ NS8250 
> > > > > > > > > > > > > emulator, in which case,
> > > > > > > > > > > > > messages from guest OS are formatted w/o '(XEN)' 
> > > > > > > > > > > > > prefix.
> > > > > > > > > > > >
> > > > > > > > > > > > Such messages ought to be processed through 
> > > > > > > > > > > > guest_printk(), which wants a
> > > > > > > > > > > > domain pointer, not a domid_t anyway. Plus isn't that 
> > > > > > > > > > > > going to be
> > > > > > > > > > > > current->domain anyway at the callsite, eliminating the 
> > > > > > > > > > > > need for such a
> > > > > > > > > > > >
> > > > > > > > > > > > helper altogether?
> > > > > > > > > > >
> > > > > > > > > > > If the current domain is owning the physical console and 
> > > > > > > > > > > printing, say, Linux
> > > > > > > > > > > login prompt, there's no need to add "(XEN)" for every 
> > > > > > > > > > > printout; adding timestamps
> > > > > > > > > > > can be disabled from Xen command line.
> > > > > > > > > >
> > > > > > > > > > Surely there shouldn't be (XEN), but without (d<N>) it'll 
> > > > > > > > > > be ambiguous in a log
> > > > > > > > > > which domain a message came from. As long as only Dom0 
> > > > > > > > > > messages are left un-
> > > > > > > > > > prefixed, that's likely fine. Yet as soon as multiple 
> > > > > > > > > > domains can issue such
> > > > > > > > > > messages (and have console "focus") I think the prefix 
> > > > > > > > > > needs to be there.
> > > > > > > > >
> > > > > > > > > It looks like we are aligned on the desired behavior,
> > > > > > > >
> > > > > > > > Hmm, no, I don't think we are. I don't ...
> > > > > > > >
> > > > > > > > > but for clarity,
> > > > > > > > > see https://marc.info/?l=xen-devel&m=173405161613716, also 
> > > > > > > > > copy/pasted
> > > > > > > > > here:
> > > > > > > > >
> > > > > > > > > I think we should provide a consistent behavior across 
> > > > > > > > > architectures.
> > > > > > > > > The current behavior with vpl011 and dom0less on ARM is the 
> > > > > > > > > following:
> > > > > > > > >
> > > > > > > > > - no prefix for Dom0 output
> > > > > > > > > - DOM$NUM for DomUs when not in focus, otherwise no prefix
> > > > > > > >
> > > > > > > > ... view this model as a desirable one. It leaves room for 
> > > > > > > > ambiguity.
> > > > > > >
> > > > > > > Adding a few more people in CC for feedback.
> > > > > > >
> > > > > > > My priority is to keep the architectures aligned. It might be OK 
> > > > > > > to
> > > > > > > change output format, but then let's do it uniformly on ARM as 
> > > > > > > well.
> > > > > > >
> > > > > > > Jan, please clarify what you think would be better than the 
> > > > > > > above. Is it
> > > > > > > the following? I don't think I understood your preference.
> > > > > > >
> > > > > > > - DOM$NUM for Dom0 and DomUs when not in focus, otherwise no 
> > > > > > > prefix
> > > > > >
> > > > > > No, I mean like we have it with guest_printk() today. (XEN) for 
> > > > > > Xen's
> > > > > > own messages, (d<N>) for ordinary domains' ones, and no prefix
> > > > > > exclusively for the hardware/control domain. What is best to do when
> > > > > > hardware and control domains are distinct I'm uncertain - I'd be
> > > > > > inclined to suggest that the hardware domain then stay the one 
> > > > > > without
> > > > > > any prefix.
> > > > >
> > > > > One concern I have with this approach is whether the addition of the
> > > > > (d<N>) prefixes will skew output of interactive applications. So far
> > > > > the prefix is added to output from all domains different than dom0
> > > > > because the console is not interactive for them, and hence no input
> > > > > can be consumed.
> > > >
> > > > Hmm, that's an aspect I have to admit I didn't think of.
> > > >
> > > > > If that changes however, and domains different than dom0 can get input
> > > > > from the Xen console then I wonder how much the added prefix will skew
> > > > > output. Another possible option would be to not print the prefix for
> > > > > the domain that has the console input assigned (current target), and
> > > > > print it for all other domains (even for dom0 when not in focus).
> > > >
> > > > That's largely what aiui was proposed. My extra requirement there would
> > > > then be that we make sure a log message is always emitted when console
> > > > focus shifts, so it's possible to identify the owner for any part of
> > > > the log.
> > >
> > > Indeed, printing console input shifting should be a requirement
> > > regardless of how we decide to print the prefix.
> >
> > Console input focus switch is indicated after pressing Crtl+aaa, e.g.:
> > [[
> > ...
> > (XEN) [15359.353038] *** Serial input to Xen (type 'CTRL-aaa' to switch 
> > input)
> > (XEN) [15361.176754] *** Serial input to DOM0 (type 'CTRL-aaa' to switch 
> > input)
> > (XEN) [15711.297202] *** Serial input to DOM1 (type 'CTRL-aaa' to switch 
> > input)
> > ...
> > ]]
>
>
> And just to double check: These messages aren't affected by "loglvl=" 
> settings,
> i.e. they're always there (as asked for earlier; see context above)?

`loglvl=none` disables console switch indication (even w/o my patches).
I will fix that.

Thanks!

>
> Jan



 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.