From: Matthias Schiffer <mschiffer@universe-factory.net>
To: Mark Hatle <mark.hatle@windriver.com>
Cc: openembedded-core@lists.openembedded.org
Subject: Re: [PATCH 1/1] linux-firmware: remove hard-coded paths
Date: Tue, 5 Jan 2016 00:57:07 +0100 [thread overview]
Message-ID: <568B06D3.7030205@universe-factory.net> (raw)
In-Reply-To: <568AF894.1010405@windriver.com>
[-- Attachment #1: Type: text/plain, Size: 4381 bytes --]
On 01/04/2016 11:56 PM, Mark Hatle wrote:
> On 1/4/16 4:26 PM, Matthias Schiffer wrote:
>> On 01/04/2016 05:32 PM, Mark Hatle wrote:
>>> On 1/4/16 10:11 AM, Matthias Schiffer wrote:
>>>> On 01/04/2016 02:14 PM, Ian Ray wrote:
>>>>> The recipe uses hard-coded paths (specifically /lib) in do_install
>>>>> and in FILES, however on a merged /usr system this directory might
>>>>> not exist. Prefer base_libdir.
>>>>>
>>>>> Signed-off-by: Ian Ray <ian.ray@ge.com>
>>>>> ---
>>>>
>>>> This should use nonarch_base_libdir, base_libdir defaults to /lib64 on
>>>> ppc64, which is not where the firmware is expected.
>>>>
>>>
>>> At a minimum, I would agree nonarch_base_libdir, however..
>>>
>>> I believe that the kernel loader/modules/tools themselves actually have '/lib'
>>> hard coded into them. This is the reason why /lib/firmware was used and not one
>>> of the variables.
>>>
>>> This is one of the cases were /lib is actually correct, since that is what the
>>> system is expecting. We can make some kind of accommodation for systems where
>>> /lib -> /usr/lib... but that should be done inside of the filesystem setup
>>> processing and not the package itself. (I'm referring to the
>>> 'meta/files/fs-perms.txt' file.
>>>
>>> --Mark
>>>
>>
>> There seem to be some intresting ideas going around about what can or
>> should be done via fs-perms.txt... AFAICT, fs-perms.txt can't move
>> around files, so moving files form /lib to /usr/lib must be done in the
>> package recipes themselves. (In my opinion, fs-perms.txt is a bad hack
>> for broken recipes that shouldn't exist anyways, but that's another
>> discussion)
>
> Since I wrote fs-perms.txt, I'll explain the purpose. Individual packages don't
> know if something is a directory, symbolic link, or what owner/group/permissions
> a system level directory should be set to.
>
> The entire purpose of it is to declare a common set of -system- directories.
> (Packages/layers can amend and override this as necessary to add their own
> system directories.)
>
> FYI System directories are things like /usr/bin. Having every package in the
> system need to define /usr/bin as a directory with an owner/group of root:root
> and permission of 0755 is a REALLY bad practice.. but putting this knowledge
> into a single file that synchronizes everything is very practical.
>
> When the system level directories are mapped to symlinks.. the case where
> everyone is trying to folks /usr -> / or /bin -> /usr/bin.. then it can
> AUTOMATICALLY map and move the files in these places..
Thanks for the explanation, I asked a similar question a few weeks ago
and didn't get a satisfactory answer about what fs-perms can do. I'll
rethink my approach for the merged-usr patchset.
So the remaining issue is how to conditionalize this. I'd like to find a
solution which doesn't require distros to define their own fs-perms when
they just want to use a merged /usr dir.
>
>> I think if a distro config changes any of the base paths
>> ({nonarch_,}base_libdir, base_{,s}bindir), *all* packages should respect
>> this. It's the distro's reponsiblity to create symlinks so everything is
>> found again at the expected paths (other examples for such hardcoded
>> paths: /bin/sh; the dynamic linker). See also my patchset I submitted to
>> this mailing list, which introduces a distro feature to have such
>> symlinks created by base-files.
>
> When this was written it was heavily argued against this knowledge being in
> base-files or base-dirs (suggested at the time) packages.
Is that discussion archived somewhere? I'm interested in the
argumentation. Do any non-OE distros have a similar feature?
>
> Defining a base setup, and then using a synchronization pass using the
> fs-perms.txt was the way to go.
>
> Note, fs-perms process is absolutely supposed to move files around -if- a
> symlink is generated.. i.e.:
>
> /lib -> /usr/lib
>
> if you write to /lib/firmware, the code is supposed to see the directory of
> '/lib', create a new /usr/lib (set perms properly) and move the contents if /lib
> to /usr/lib, then replace the directory with a symbolic link.
>
> If it's NOT doing that, lets fix it.
I didn't try yet as I didn't now that it is supposed to to that.
>
> --Mark
>
>> Matthias
>>
>>
>>
>
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 836 bytes --]
next prev parent reply other threads:[~2016-01-04 23:57 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-01-04 13:14 [PATCH 0/1] More fixes for a distro with a merged /usr Ian Ray
2016-01-04 13:14 ` [PATCH 1/1] linux-firmware: remove hard-coded paths Ian Ray
2016-01-04 16:11 ` Matthias Schiffer
2016-01-04 16:32 ` Mark Hatle
2016-01-04 22:26 ` Matthias Schiffer
2016-01-04 22:56 ` Mark Hatle
2016-01-04 23:57 ` Matthias Schiffer [this message]
2016-01-05 0:28 ` Mark Hatle
2016-01-05 1:26 ` Matthias Schiffer
2016-01-05 14:03 ` Mark Hatle
2016-01-05 14:04 ` Ray, Ian (GE Healthcare)
2016-01-05 14:33 ` Mark Hatle
2016-01-05 14:41 ` Ray, Ian (GE Healthcare)
2016-01-05 17:06 ` Mark Hatle
2016-01-05 22:20 ` Phil Blundell
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=568B06D3.7030205@universe-factory.net \
--to=mschiffer@universe-factory.net \
--cc=mark.hatle@windriver.com \
--cc=openembedded-core@lists.openembedded.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox