[Mesa-dev] forking shared intel directory?
Chad Versace
chad.versace at linux.intel.com
Wed Jun 26 09:47:13 PDT 2013
On 06/21/2013 10:09 PM, Kenneth Graunke wrote:
> On 06/21/2013 11:29 AM, Eric Anholt wrote:
>> Long ago, when porting FBO and memory management support to i965, I
>> merged a bunch of code between the i915 and i965 drivers and put it in
>> the intel directory. I think it served us well for a long time, as both
>> drivers got improvements from shared work on that code. But since then,
>> we've talked several times about splitting things back apart (since we
>> break i915 much more often than we improve it), so I spent yesterday and
>> today looking at what the impact would be.
>>
>> LOC counts (wc -l):
>>
>> intel/ i915/ i965/ total
>> master: 14751 13458 61109 89318
>> fork-i915: 0 24322 74978 99300
>>
>> We duplicate ~10000 lines of code, but i915 drops ~4000 lines of code
>> From its build and i965 drops ~1000.
>>
>> context size:
>> i915 i965
>> master: 99512 101456
>> fork-i915: 99384 100824
>>
>> There's a bunch of cleanup I haven't done in the branch, like moving
>> brw_vtbl.c contents to sensible places, or nuking the intel vs brw split
>> that doesn't make any sense any more.
>>
>> I'm ambivalent about the change. If the code growth from splitting was
>> <7000 lines or so, I'd be happy, but this feels pretty big. On the
>> other hand, the cleanups feel good to me.
>
> I'm still in favor of this - you've already embarked on some good tidying, and there's much more that can be done. I
> think in the end, both drivers will be better off. I'd also feel better if it were < 7000, but at some point it makes
> sense anyway.
>
> I do think the duplicated code may diverge further in the future (say, due to new Gen4+ only acceleration paths or
> improved implementations of things), and that there's a bit more that could be cut/coalesced.
>
>> I don't know how other
>> developers feel. There's a branch up at fork-i915 of my tree. If
>> people are excited about doing this and I get a bunch of acks for the
>> two "copy the code to my directory" commits, I'll do those two then
>> start sending out the non-copying changes for review. If people don't
>> like it, I won't be hurt.
>
> That sounds like a good plan to me. I'd be happy to do some post-fork tidying, but I'd much rather get your code landed
> before embarking too far on that path.
>
> What do others think?
I'm in favor of the fork. I think that the resultant code will be easier to
work with and easier to understand.
Also, since I came into Mesa during the Sandybridge era, I'm completely
unfamiliar with the i915 code. I sometimes encounter codepaths in the intel
directory that smells like i915 code, but I'm unsure if it actually is, having
never worked on that driver. So I cautiously tiptoe around the code lest I
break i915. I look forward to eliminating that need to cautiously tiptoe.
More information about the mesa-dev
mailing list