Hello Stefan, I never have tapped into the DLL Hell trap. That's maybe I never did C++ development or I started with VB .NET / C# as .NET solved major parts of the DLL Hell :). That doesn't mean my new beloved language Python doesn't have a similar problem ... Thinking about DLL Hell is a thinking in big version numbers like 1.0, 2.0 oder even 2.1, 2.2, ... We are here talking about revisions in the build numbers which need to be synchronized between the parent repository and the sub modules (IP cores). Both sides are under heavy development and interfaces evolving from day to day because hardware design can't be planned as easy as software design. So by using Git submodules a developer - responsible for a submodule / IP core - can after he finished interface level 1 now go on and implement interface level 2. The parent project can finish it's integration and testing of the level 1 interface before proceeding with level 2. More over if the same IP core is used multiple time in different sub IP cores, it's possible to update one usage place to interface level 2 by a second developer so he can finish his IP core at level 2, which other usage places can still use the level 1 interface. Start situation: -------------------------------------- TOPLEVEL (developer A) o- IP_1 @level1 (developer B) o- IP_2 @level1 (developer C) o- IP_3 @level1 (developer D) o- IP_2 @level1 Developer C creates interface level 2, but all instances use level1 of IP_2: -------------------------------------- TOPLEVEL (developer A) o- IP_1 @level1 (developer B) o- IP_2 @level1 (developer C) o- IP_3 @level1 (developer D) o- IP_2 @level1 Developer D updates instance of IP_2 to level 2 and completes level 2 of IP_3: -------------------------------------- TOPLEVEL (developer A) o- IP_1 @level1 (developer B) o- IP_2 @level1 (developer C) o- IP_3 @level1 (developer D) o- IP_2 @level2 Developer A updates instance of IP_3 to level 2: -------------------------------------- TOPLEVEL (developer A) o- IP_1 @level1 (developer B) o- IP_2 @level1 (developer C) o- IP_3 @level2 (developer D) o- IP_2 @level2 Developer B has finished his testing for IP_1 and can now update the instance if IP_2: -------------------------------------- TOPLEVEL (developer A) o- IP_1 @level1 (developer B) o- IP_2 @level2 (developer C) o- IP_3 @level2 (developer D) o- IP_2 @level2 So now imaging 8 developers, whereof 6 are working remote on the project. There is one responsible developer per IP core (maintainer) and an overall maintainer overseeing all integration merges and test results (CI). Kind regards Patrick ________________________________________ Von: Stefan Beller [sbeller@xxxxxxxxxx] Gesendet: Montag, 19. Juni 2017 21:21 Bis: Patrick Lehmann Cc: Lars Schneider; Git Mailinglist Betreff: Re: Restoring detached HEADs after Git operations On Mon, Jun 19, 2017 at 11:09 AM, Patrick Lehmann <Patrick.Lehmann@xxxxxxx> wrote: > Hello Stefan, > > the use case is as follows: > > The projects consists of circa 18 IP cores. Each IP core is represented by a Git repository. Think of an IP core as of a lonestanding DLL or SO file project. Each IP core references 2 submodules, which bring the verification environments for testing the IP core standalone. So phrased differently: You are using submodules to avoid "DLL hell" (sharing a lib, with ease of versioning as the submodules in the different IP cores may be pointing at different versions). > > These 18 IP cores are grouped to bigger IP cores, referencing the low-level IP cores and each again the 2 verification submodules. Finally, the main project references the bigger IP cores and again the 2 verification cores. > > TOPLEVEL > o- IP1 > o- UVVM > o- VUnit > o- IP2 > o- UVVM > o- VUnit > o- IP3 > o- UVVM > o- VUnit > o- IP4 > o- UVVM > o- VUnit > o- IP5 > o- UVVM > o- VUnit > o- IP6 > o- UVVM > o- VUnit > o- IP7 > o- UVVM > o- VUnit > o- IP8 > o- UVVM > o- VUnit > o- IP9 > o- UVVM > o- VUnit > o- IP10 > o- UVVM > o- VUnit > o- IP11 > o- UVVM > o- VUnit > o- IP9 > o- UVVM > o- VUnit > o- IP12 > o- UVVM > o- VUnit > o- UVVM > o- VUnit > > That's the simplified structure. I can't write more, because it's a closed source project. You can find other usecases e.g. in my other open source projects. E.g. The PoC-Library or The PicoBlaze-Library and the corresponding PoC-Examples repository. > > Example: PoC > Pile of Cores includes 4 Git submodules and is itself an IP core library. > So PoC-Examples again references PoC. This looks like this tree: > > PoC-Examples > |- lib/ > o- PoC > |- lib > o- Cocotb > o- OSVVM > o- VUnit > o- .... OSVVM > o- UVVM > > The library VUnit itself already includes OSVVM as a library. > > ---------------------- > Forcast: > I'll write a new question / idea about multiple equal submodules and the memory footprint soon... > Here is my original question posted on StackOverflow: https://stackoverflow.com/questions/44585425/how-to-reduce-the-memory-footprint-for-multiple-submodules-of-the-same-source > ---------------------- > > Do you need more use cases? > Well this use case points out a different issue than I hoped for. ;) >From the stackoverflow post and from looking at the layout here, one of the major questions is how to deduplicate the submodule object store for example. By use case I rather meant a sales pitch for your initial email: I use this bash script because it fits in my workflow because I need branches instead of detached HEADS, because $REASONS and I'd be interested in these $REASONS, which I assumed to be * easier to work with branches than detached HEADS (it aids the workflow) * we're not challenging the underlying mental model of tracking sha1s in the superproject rather than branches. At least I gave these reasons in the "reattach HEAD" stuff that I wrote, but maybe there are others? (I know the code base of submodules very well, but I do not work with submodules on a day-to-day basis myself...)