Re: [RFC] Unify KVM kernel-space and user-space code into a single project

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

 



On Mon, Mar 22, 2010 at 05:32:15PM +0100, Ingo Molnar wrote:
> I dont know how you can find the situation of Alpha comparable, which is a 
> legacy architecture for which no new CPU was manufactored in the past ~10 
> years.
> 
> The negative effects of physical obscolescence cannot be overcome even by the 
> very best of development models ...

The maintainers of that architecture could at least continue to maintain
it. But that is not the case. Most newer syscalls are not available and
overall stability on alpha sucks (kernel crashed when I tried to start
Xorg for example) but nobody cares about it. Hardware is still around
and there are still some users of it.

> > > * Joerg Roedel <joro@xxxxxxxxxx> wrote:
> > No, the split-repository situation was the smallest problem after all. Its 
> > was a community thing. If the community doesn't work a single-repo project 
> > will also fail. [...]
> 
> So, what do you think creates code communities and keeps them alive? 
> Developers and code. And the wellbeing of developers are primarily influenced 
> by the repository structure and by the development/maintenance process - i.e. 
> by the 'fun' aspect. (i'm simplifying things there but that's the crux of it.)

Right. A living community needs developers that write new code. And the
repository structure is one important thing. But in my opinion it is not
the most important one. With my 3-4 years experience in the kernel
community I made the experience that the maintainers are the most
important factor. I find a maintainer not commiting or caring about
patches or not releasing new versions much worse than the wrong
repository structure.
oProfile has this problem with its userspace part. I partly made this
bad experience with x86-64 before the architecture merge. KVM does not
have this problem.

> So yes, i do claim that what stiffled and eventually killed off the Oprofile 
> community was the split repository. None of the other Oprofile shortcomings 
> were really unfixable, but this one was. It gave no way for the community to 
> grow in a healthy way, after the initial phase. Features were more difficult 
> and less fun to develop.

The biggest problem oProfile has is that it does not support per-process
measuring. This is indeed not unfixable but it also doesn't fit well in
the overall oProfile concept.

> I simply do not want to see KVM face the same fate, and yes i do see similar 
> warnings signs.

In fact, the development process in KVM has improved over time. In the
early beginnings everything was kept in svn. Avi switched to git some
day but at the time when we had these kvm-XX releases both kernel- and
user-space together were unbisectable. This has improved to a point
where the kernel-part could be bisected. The KVM maintainers and
community have shown in the past that they can address problems with the
development process if they come up.

> Oprofile certainly had good developers and maintainers as well. In the end it 
> wasnt enough ...
> 
> Also, a project can easily still be 'alive' but not reach its full potential. 
> 
> Why do you assume that my argument means that KVM isnt viable today? It can 
> very well still be viable and even healthy - just not _as healthy_ as it could 
> be ...

I am not aware that I made you say anything ;-)

> 
> > > The difference is that we dont have KVM with a decade of history and we 
> > > dont have a 'told you so' KVM reimplementation to show that proves the 
> > > point. I guess it's a matter of time before that happens, because Qemu 
> > > usability is so absymal today - so i guess we should suspend any 
> > > discussions until that happens, no need to waste time on arguing 
> > > hypoteticals.
> > 
> > We actually have lguest which is small. But it lacks functionality and the 
> > developer community KVM has attracted.
> 
> I suggested long ago to merge lguest into KVM to cover non-VMX/non-SVM 
> execution.

That would have been the best. Rusty already started this work and
presented it at the first KVM Forum. But I have never seen patches ...

> > > I think you are rationalizing the status quo.
> > 
> > I see that there are issues with KVM today in some areas. You pointed out 
> > the desktop usability already. I personally have trouble with the 
> > qem-kvm.git because it is unbisectable. But repository unification doesn't 
> > solve the problem here.
> 
> Why doesnt it solve the bisectability problem? The kernel repo is supposed to 
> be bisectable so that problem would be solved.

Because Marcelo and Avi try to keep as close to upstream qemu as
possible. So the qemu repo is regularly merged in qemu-kvm and if you
want to bisect you may end up somewhere in the middle of the qemu
repository which has only very minimal kvm-support.
The problem here is that two qemu repositorys exist. But the current
effort of Anthony is directed to create a single qemu repository. But
thats not done overnight.
Merging qemu into the kernel would make Linus in fact a qemu maintainer.
I am not sure he wants to be that ;-)
 
> In my judgement you'd have to do that more frequently, if KVM was properly 
> weighting its priorities. For example regarding this recent KVM commit of 
> yours:
> 
> | commit ec1ff79084fccdae0dca9b04b89dcdf3235bbfa1
> | Author: Joerg Roedel <joerg.roedel@xxxxxxx>
> | Date:   Fri Oct 9 16:08:31 2009 +0200
> |
> |     KVM: SVM: Add tracepoint for invlpga instruction
> |     
> |     This patch adds a tracepoint for the event that the guest
> |     executed the INVLPGA instruction.
> 
> With integrated KVM tooling i might have insisted for that new tracepoint to 
> be available to users as well via some more meaningful tooling than just a 
> pure tracepoint.
> 
> There's synergies like that all around the place.

True. Tools for better analyzing kvm traces is for sure something that
belongs to tools/kvm. I am not sure if anyone has such tools. If yes,
they should send it upstream.

> > > It's as if you argued in 1990 that the unification of East and West 
> > > Germany wouldnt make much sense because despite clear problems and 
> > > incompatibilites and different styles westerners were still allowed to 
> > > visit eastern relatives and they both spoke the same language after all 
> > > ;-)
> > 
> > Um, hmm. I don't think these situations have enough in common to compare 
> > them ;-)
> 
> Probably, but it's an interesting parallel nevertheless ;-)

That for sure ;-)

	Joerg

--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux