All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jose Fonseca <jfonseca@vmware.com>
To: Rob Clark <robdclark@gmail.com>, Jonathan Gray <jsg@jsg.id.au>
Cc: "mesa-dev@lists.freedesktop.org" <mesa-dev@lists.freedesktop.org>,
	Maling list - DRI developers <dri-devel@lists.freedesktop.org>
Subject: Re: [RFC libdrm 0/2] Replace the build system with meson
Date: Fri, 24 Mar 2017 13:42:18 +0000	[thread overview]
Message-ID: <0fec7a9a-9def-76f1-dacb-4dbf0c341bac@vmware.com> (raw)
In-Reply-To: <CAF6AEGufKpKTup_NT8DKJC5MYWzj55dOYB_Rzsz57HEkdMBezg@mail.gmail.com>

On 23/03/17 01:38, Rob Clark wrote:
> On Wed, Mar 22, 2017 at 9:18 PM, Jonathan Gray <jsg@jsg.id.au> wrote:
>> On Wed, Mar 22, 2017 at 01:10:14PM -0700, Dylan Baker wrote:
>>> On Wed, Mar 22, 2017 at 12:40 PM, Alex Deucher <alexdeucher@gmail.com> wrote:
>>>> I guess I'm a little late to the party here, but I haven't had time to
>>>> really let all of this sink in and actually look at meson.  It doesn't
>>>> seem so bad with a quick look and I think I could probably sort it out
>>>> when the time came, but there would still be a bit of a learning
>>>> curve.  While that may not be a big deal at the micro level, I have
>>>> concerns at the macro level.
>>>>
>>>> First, I'm concerned it may discourage casual developers and
>>>> packagers.  autotools isn't great, but most people are familiar enough
>>>> with it that they can get by.  Most people have enough knowledge of
>>>> autotools that they can pretty easily diagnose a configuration based
>>>> failure. There are a lot of resources for autotools.  I'm not sure
>>>> that would be the case for meson.  Do we as a community feel we have
>>>> enough meson experience to get people over the hump?  Anything that
>>>> makes it harder for someone to try a new build or do a bisect is a big
>>>> problem in my opinion.
>>>
>>> One of the things that's prompted this on our side (I've talked this over with
>>> other people at Intel before starting), was that clearly we *don't* know
>>> autotools well enough to get it right. Emil almost always finds cases were we've
>>> done things *almost*, but not quite right.
>>>
>>> For my part, it took me about 3 or 4 days of reading through the docs and
>>> writing the libdrm port to get it right, and a lot of that is just the
>>> boilerplate of having ~8 drivers that all need basically the same logic.
>>>
>>>> Next, my bigger concern is for distro and casual packagers and people
>>>> that maintain large build systems with lots of existing custom
>>>> configurations.  Changing from autotools would basically require many
>>>> of these existing tools and systems to be rewritten and then deal with
>>>> the debugging and fall out from that.  The potential decreased build
>>>> time is a nice bonus, but frankly a lot of people/companies have years
>>>> of investment in existing tools.
>>>
>>> Sure, but we're also not the only ones investigating meson. Gnome is using it
>>> already, libepoxy is using it, gstreamer is using it. There are patches for
>>> weston (written by Daniel Stone) and libinput (written by Peter Hutterer), there
>>> are some other projects in the graphics sphere that people are working on. So
>>> even if we as a community decide that meson isn't for us, it's not going away.
>>
>> It is worth pointing out that it is currently required by no component
>> of an x.org stack.  In the case of libepoxy it was added by a new maintainer
>> on a new release and even then autoconf remains.
>>
>> And as far as I can tell nothing in the entire OpenBSD ports tree
>> currently requires meson to build including gnome and gstreamer.
>>
>
> but I guess that is conflating two completely different topics..
> addition of meson and removal of autotools.  It is probably better
> that we treat the topics separately.  I don't see any way that the two
> can happen at the same time.
>
> The autotools build probably needs to remain for at least a couple
> releases, and I certainly wouldn't mind if some of the other desktop
> projects took the leap of dropping autotools first (at least then
> various different "distro" consumers will have already dealt with how
> to build meson packages)
>
> None of that blocks addition of a meson build system (or what various
> developers use day to day)
>
> BR,
> -R

I tend to disagree.  While we can't avoid a transitory period, when we 
embark on another build system (Meson or something else) I think we 
should aim at 1) ensure such tool can indeed _completely_ replace at 
least _one_ existing build system, 2) and aim at migration quickly.

Otherwise we'll just end up with yet another build system, yet another 
way builds can fail, with some developers stuck on old build systems 
because it works, or because the new build system quite doesn't work.

And this is from (painful) experience.



So I think we should identify stake holders soon, collect requirements 
(OSes platforms, etc), make sure the prospective tool meets them, have 
all stakeholders collaborate on a prototype, them embark on mass migration.

That is, if this fails, let it fail early.  If it succeeds, may it 
succeed early.  Anything but a slow death / zombie life.




BTW, how about migrating mesademos to Meson?  It currently has autotools 
and cmake.  I was hoping that cmake would replace autotools, but I 
couldn't run fast enough, so I couldn't practice what preached above, 
hence cmake doing almost but not all what autotools does.

And is not a crucial project for Linux distros -- few distros package it 
-- and even if they do, no other package would depend on it.  And is one 
of those sort of projects that should be easy to port to any build too.

Even if we ignore everything else, just replacing autotools + cmake with 
just one thing would be a net win.


Jose
_______________________________________________
mesa-dev mailing list
mesa-dev@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/mesa-dev

  reply	other threads:[~2017-03-24 13:42 UTC|newest]

Thread overview: 94+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-03-16 21:25 [RFC libdrm 0/2] Replace the build system with meson Dylan Baker
2017-03-16 21:25 ` [RFC libdrm 1/2] Port build system to meson Dylan Baker
2017-03-16 21:25 ` [RFC libdrm 2/2] remove autotools build Dylan Baker
2017-03-16 21:32 ` [RFC libdrm 0/2] Replace the build system with meson Ilia Mirkin
2017-03-16 21:57   ` Dylan Baker
2017-03-17 10:05     ` Neil Armstrong
2017-03-16 22:36 ` Marek Olšák
2017-03-16 23:11   ` Dylan Baker
2017-03-17  1:53     ` Marek Olšák
2017-03-17  4:15       ` Dylan Baker
2017-03-17 21:18         ` Marek Olšák
2017-03-22 17:26   ` Jose Fonseca
2017-03-22 17:50     ` [Mesa-dev] " Marek Olšák
2017-03-16 23:35 ` Emil Velikov
2017-03-17  0:21   ` Dylan Baker
2017-03-17  0:41     ` Emil Velikov
2017-03-17  2:03       ` Jason Ekstrand
2017-03-17  2:28         ` Brian Paul
2017-03-22 17:59           ` Jose Fonseca
2017-03-22 20:57             ` [Mesa-dev] " Dylan Baker
2017-03-22 22:02               ` Rob Clark
2017-03-22 22:15                 ` Eric Anholt
2017-03-22 22:33                   ` Dylan Baker
2017-03-24 14:03               ` Jose Fonseca
2017-03-24 14:22                 ` [Mesa-dev] " Daniel Stone
2017-03-24 15:47                   ` Jose Fonseca
2017-03-25 20:15                     ` [Mesa-dev] " Rob Clark
2017-03-24 16:23                 ` Bas Nieuwenhuizen
2017-03-17  4:12         ` Dylan Baker
2017-03-17  6:02           ` Jonathan Gray
2017-03-20 13:55         ` [Mesa-dev] " Emil Velikov
2017-03-20 18:30           ` Matt Turner
2017-03-20 19:39             ` [Mesa-dev] " Emil Velikov
2017-03-20 21:28               ` Timothy Arceri
2017-03-20 21:38                 ` Jason Ekstrand
2017-03-21  5:00                 ` Jonathan Gray
2017-03-21 16:00                   ` Matt Turner
2017-03-23 12:23                   ` Jonathan Gray
2017-03-23 18:31                   ` Emil Velikov
2017-03-21 15:57               ` [Mesa-dev] " Matt Turner
2017-03-21 17:16                 ` Emil Velikov
2017-03-21 18:06                   ` Matt Turner
2017-03-21 18:56                     ` [Mesa-dev] " Emil Velikov
2017-03-21 19:08                       ` Jason Ekstrand
2017-03-21 19:10                       ` [Mesa-dev] " Matt Turner
2017-03-22 17:16                         ` Emil Velikov
2017-03-24 20:59                     ` Chad Versace
2017-03-24 20:44                 ` [Mesa-dev] " Chad Versace
2017-03-28 16:59                   ` Emil Velikov
2017-03-28 23:19                     ` Timothy Arceri
2017-03-21  5:10             ` Jonathan Gray
2017-03-21 16:11               ` [Mesa-dev] " Matt Turner
2017-03-24 16:58             ` randyf
2017-03-20 19:29           ` Rob Clark
2017-03-21 14:44 ` Jani Nikula
2017-03-21 15:13   ` Grazvydas Ignotas
2017-03-21 15:15     ` Ilia Mirkin
2017-03-21 16:16     ` Dylan Baker
2017-03-21 16:22   ` Dylan Baker
2017-03-22  4:23     ` [Mesa-dev] " Jonathan Gray
2017-03-22  8:24     ` Jani Nikula
2017-03-22 21:05       ` Dylan Baker
2017-03-23  8:13         ` Jani Nikula
2017-03-21 16:50 ` Kai Wasserbäch
2017-03-21 17:34   ` Dylan Baker
2017-03-21 18:36     ` [Mesa-dev] " Kai Wasserbäch
2017-03-21 21:16       ` Dylan Baker
2017-03-22 16:40 ` Alex Deucher
2017-03-22 17:07   ` Rob Clark
2017-03-22 20:10     ` [Mesa-dev] " Dylan Baker
2017-03-22 21:48       ` Rob Clark
2017-03-23 21:56         ` Greg Hackmann
2017-03-23 22:14           ` Colin Cross
2017-03-23 23:56             ` Dylan Baker
2017-03-24  0:03               ` [Mesa-dev] " Colin Cross
2017-03-24 16:54                 ` Dylan Baker
2017-03-23  1:18       ` [Mesa-dev] " Jonathan Gray
2017-03-23  1:38         ` Rob Clark
2017-03-24 13:42           ` Jose Fonseca [this message]
2017-03-24 17:13             ` Dylan Baker
2017-03-24 17:51               ` Eric Anholt
2017-03-24 18:34                 ` [Mesa-dev] " Daniel Stone
2017-03-24 19:10             ` Kristian Høgsberg
2017-03-24 19:44               ` Jose Fonseca
2017-03-24 20:08                 ` Kristian Høgsberg
2017-03-24 21:16                   ` Jose Fonseca
2017-03-24 21:20                     ` Jason Ekstrand
2017-03-24 21:34                     ` [Mesa-dev] " Rob Clark
2017-03-25  1:25                     ` Dylan Baker
2017-03-24 21:09               ` [Mesa-dev] " Rob Clark
2017-03-23 11:39       ` Emil Velikov
2017-03-23 17:54         ` Dylan Baker
2017-03-25  1:06         ` Kenneth Graunke
2017-03-22 22:30   ` [Mesa-dev] " Eric Anholt

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=0fec7a9a-9def-76f1-dacb-4dbf0c341bac@vmware.com \
    --to=jfonseca@vmware.com \
    --cc=dri-devel@lists.freedesktop.org \
    --cc=jsg@jsg.id.au \
    --cc=mesa-dev@lists.freedesktop.org \
    --cc=robdclark@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.