View previous topic :: View next topic |
Author |
Message |
maxux n00b
Joined: 25 Jul 2010 Posts: 10
|
Posted: Fri Feb 09, 2018 9:03 pm Post subject: Using portage as custom build system |
|
|
Hello,
I'm working on a project which builds a custom hand-made root filesystem by compiling needed software (like embedded things, but not for embedded devices).
For now, it a set of custom shell scripts which takes cares to build each parts/software (like ebuild), but in a really more easy/less extendable way.
I'm using Gentoo everyday, on each device I have (laptop, workstation, raspberry pi, ...), I think I'm experienced with emerge/portage.
I was wondering if it could be doable to use portage and emerge as build system for my project.
I imagine something like a clean repository, with couple of ebuilds for the different software to install, and use the power of portage to resolve dependencies and the compilation order.
At the end, it could end of a custom set which would install everything needed to a custom root prefix.
More specifically, is it possible to use emerge/portage by assuming compiler, etc. is already present and should not be handled by portage.
I would like to use emerge and portage to only works my small custom repository, not a full system and make an overlay next to it.
Is that a use case possible for emerge and portage ?
Thanks ! |
|
Back to top |
|
|
pjp Administrator
Joined: 16 Apr 2002 Posts: 20499
|
Posted: Fri Feb 09, 2018 10:27 pm Post subject: |
|
|
Moved from Documentation, Tips & Tricks (since it was none of those things) to Portage & Programming. Question seems more related to the capabilities of Portage. _________________ Quis separabit? Quo animo? |
|
Back to top |
|
|
ct85711 Veteran
Joined: 27 Sep 2005 Posts: 1791
|
Posted: Sat Feb 10, 2018 12:24 am Post subject: |
|
|
I don't see why portage can't be used for what you are wanting to do; you'll have to create your own ebuilds for the packages; but a lot of that I'd link is covered with your build script. For the most part, everything in your @system, is your base toolkit to build/run the base system. After that, you can tell portage to install which ebuilds you want.
The ebuilds are designed to, to identify dependencies (so the packages are built in the correct order). USE flags, could possibly be ignored in your custom ebuilds if you are not interested in customizing specific capabilities. |
|
Back to top |
|
|
szatox Advocate
Joined: 27 Aug 2013 Posts: 3467
|
Posted: Sat Feb 10, 2018 12:28 am Post subject: |
|
|
Not quite sure if I get you right, but it seems that the thing you're looking for is called "portage overlay".
So, you create ebuilds for your software, put them in your overlay (either local one or public if you want to use it from several machines), and then you emerge them just like anything else.
Ebuilds contain information regarding sources, dependencies, use flags (both, supported by your program and required from dependencies - if any).
Since an overlay need some base, you make it relay on gentoo repository. All dependencies absent in your overlay will be pulled in from the regular portage tree instead.
On top of that, you may consider integrating it with catalyst to automate your builds. I don't like it (because reasons) but you may find it handy. This is where downloadable gentoo stage tarballs come from.
You can download standard recipes from catalyst project's homepage. Use stage1 and 2 directly, and either expand stage3 if you can make it use overlay or create stage 4 based on that (or inject your ebuilds to portage snapshot used by catalyst, this may be an option too)
Bonus: you can speed subsequent builds up by building and reusing binary packages. Some stuff, like gcc doesn't change very often, there is little point in trashing it and building from scratch every night. |
|
Back to top |
|
|
maxux n00b
Joined: 25 Jul 2010 Posts: 10
|
Posted: Sun Feb 11, 2018 8:02 am Post subject: |
|
|
Thanks for your replies !
Quote: | you'll have to create your own ebuilds for the packages |
Yep, that was obvious, I know.
Quote: | The ebuilds are designed to, to identify dependencies (so the packages are built in the correct order). USE flags, could possibly be ignored in your custom ebuilds if you are not interested in customizing specific capabilities. |
I know, that's exactly why I want to use portage, and it's the main purpose of my post :p
Quote: | Not quite sure if I get you right, but it seems that the thing you're looking for is called "portage overlay" [...] Since an overlay need some base, you make it relay on gentoo repository. |
Yes and no, I know what is an overlay and it's not exactly what I want, that's why I talked about clean repository. I don't want to overlay the default gentoo repository, I want mine, completly from scratch.
The main question/purpose of this post was: can portage works with a light repository, without anything related to the compiler, etc. (because this will be handled by a upper layer)
The idea behind is to have a local working system with toolchain installed, and a dedicated portage which will compiles and build the target full system. This target won't include any headers, compiles, etc. (I know this can be done using some --root tricks)
All the others tips, I was aware of it, all the bonus are, exactly, why I want to use portage for this system |
|
Back to top |
|
|
NeddySeagoon Administrator
Joined: 05 Jul 2003 Posts: 54596 Location: 56N 3W
|
Posted: Sun Feb 11, 2018 10:02 am Post subject: |
|
|
maxux,
You can set an alternate ROOT for portage to install into. There are several different *ROOT settings. you can play with.
crossdev does this when you install a cross compiler.
For arm64 I have /usr/aarch64-unknown-linux-gnu/ which is full of arm64 code, on my amd64 build system.
It has its own /etc/portage which applies when cross compiling. At the outset, there are no binary packages installed in /usr/aarch64-unknown-linux-gnu/
It sounds like that's close to what you want. The tool chain and all the repos are outside of /usr/aarch64-unknown-linux-gnu/
You cannot set up a cross environment for your host architecture but the *ROOT settings still work.
Portage uses the ebuild environment it finds on the build host to install things into your designated *ROOT.
I know it works as I'm a crossdev user but I don't know the detail. _________________ Regards,
NeddySeagoon
Computer users fall into two groups:-
those that do backups
those that have never had a hard drive fail. |
|
Back to top |
|
|
szatox Advocate
Joined: 27 Aug 2013 Posts: 3467
|
Posted: Sun Feb 11, 2018 12:02 pm Post subject: |
|
|
Well, let's try going the other way, AKA define the actual goal first:
What software do you want to find in the final image?
Optionally; what software you don't want to find there? |
|
Back to top |
|
|
maxux n00b
Joined: 25 Jul 2010 Posts: 10
|
Posted: Mon Feb 12, 2018 8:26 am Post subject: |
|
|
Thanks NeddySeagoon, I already used crossdev to build stuff for my raspberry pi, but I need to admit I couldn't handle it correctly to achieve the goal I wanted.
And it's true, what I needs is quite the same.
The resulting root should only contains binaries and needed files to makes software runs, without sources, includes, documentation, etc.
If the build-time dependencies can be stripped from the root, it's perfect.
szatox: half of the system can be used from official Gentoo repository (busybox, glibc, nftables, etc.), the other half is some custom projects in c/go. I'll just need to write theses ebuild.
An overlay could maybe do the trick, if the resulting root can be full build-time dependencies less.
I tried multiple things with the root settings, but I usualy hit some issue like mixing dependencies between the host and the target, I never found a way to have a fully distinct root for the same CHOST.
Thanks for you time |
|
Back to top |
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
|