diff mbox series

sanity.bbclass: Lower the length of TMPDIR limit to 400

Message ID 20241230073100.229869-1-changqing.li@windriver.com
State Accepted, archived
Commit da1c0998bdaf5def7ae94f44a33b9a505edc99c1
Headers show
Series sanity.bbclass: Lower the length of TMPDIR limit to 400 | expand

Commit Message

Changqing Li Dec. 30, 2024, 7:31 a.m. UTC
From: Changqing Li <changqing.li@windriver.com>

When TMPDIR has length 410,  bitbake uninative-tarball will fail at
do_populate_sdk with error: Failed to open backup database:
"TMPDIR/work/x86_64-nativesdk-pokysdk-linux/uninative-tarball/1.0/sdk/image/var/lib/dnf/history.sqlite"

sqlite3 has a hardcode max pathname limit 512, refer [1], and there is a
check, refer [2], pathname + 8 > max path name limit(512) is not
allowed.  So the pathname length need to <= 504.  While, length of
"TMPDIR/work/x86_64-nativesdk-pokysdk-linux/uninative-tarball/1.0/sdk/image/var/lib/dnf/history.sqlite"
is 505, so error happened.

We had met similar issue [3], and refer the comments, upstream reject
the change of the hardcode length, see [4][5].

This patch try to improve and workaround this issue by lower max TMPDIR
length to 400, at least for distro name length <=13, the build can
success.

[1] https://github.com/sqlite/sqlite/blob/master/src/os_unix.c#L180
[2] https://github.com/sqlite/sqlite/blob/master/src/pager.c#L4777
[3] https://bugzilla.yoctoproject.org/show_bug.cgi?id=12374
[4] https://sqlite.org/cgi/src/tktview/c060923a5422590b3734
[5] https://sqlite.org/forum/forumpost/0b1b8b5116

Signed-off-by: Changqing Li <changqing.li@windriver.com>
---
 meta/classes-global/sanity.bbclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

Comments

Alexander Kanavin Dec. 30, 2024, 11:51 a.m. UTC | #1
I don't object to the fix, I just want to point out that this seems to
deal with the unfortunate case of "C programmer's disease":

C Programmer's Disease: n.

The tendency of the undisciplined C programmer to set arbitrary but
supposedly generous static limits on table sizes (defined, if you're
lucky, by constants in header files) rather than taking the trouble to
do proper dynamic storage allocation. If an application user later
needs to put 68 elements into a table of size 50, the afflicted
programmer reasons that he or she can easily reset the table size to
68 (or even as much as 70, to allow for future expansion) and
recompile. This gives the programmer the comfortable feeling of having
made the effort to satisfy the user's (unreasonable) demands, and
often affords the user multiple opportunities to explore the marvelous
consequences of fandango on core. In severe cases of the disease, the
programmer cannot comprehend why each fix of this kind seems only to
further disgruntle the user.

http://www.catb.org/jargon/html/C/C-Programmers-Disease.html

Alex

On Mon, 30 Dec 2024 at 08:31, Changqing Li via lists.openembedded.org
<changqing.li=windriver.com@lists.openembedded.org> wrote:
>
> From: Changqing Li <changqing.li@windriver.com>
>
> When TMPDIR has length 410,  bitbake uninative-tarball will fail at
> do_populate_sdk with error: Failed to open backup database:
> "TMPDIR/work/x86_64-nativesdk-pokysdk-linux/uninative-tarball/1.0/sdk/image/var/lib/dnf/history.sqlite"
>
> sqlite3 has a hardcode max pathname limit 512, refer [1], and there is a
> check, refer [2], pathname + 8 > max path name limit(512) is not
> allowed.  So the pathname length need to <= 504.  While, length of
> "TMPDIR/work/x86_64-nativesdk-pokysdk-linux/uninative-tarball/1.0/sdk/image/var/lib/dnf/history.sqlite"
> is 505, so error happened.
>
> We had met similar issue [3], and refer the comments, upstream reject
> the change of the hardcode length, see [4][5].
>
> This patch try to improve and workaround this issue by lower max TMPDIR
> length to 400, at least for distro name length <=13, the build can
> success.
>
> [1] https://github.com/sqlite/sqlite/blob/master/src/os_unix.c#L180
> [2] https://github.com/sqlite/sqlite/blob/master/src/pager.c#L4777
> [3] https://bugzilla.yoctoproject.org/show_bug.cgi?id=12374
> [4] https://sqlite.org/cgi/src/tktview/c060923a5422590b3734
> [5] https://sqlite.org/forum/forumpost/0b1b8b5116
>
> Signed-off-by: Changqing Li <changqing.li@windriver.com>
> ---
>  meta/classes-global/sanity.bbclass | 4 ++--
>  1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/meta/classes-global/sanity.bbclass b/meta/classes-global/sanity.bbclass
> index a0b2508e11..7b8a497d5a 100644
> --- a/meta/classes-global/sanity.bbclass
> +++ b/meta/classes-global/sanity.bbclass
> @@ -760,8 +760,8 @@ def check_sanity_version_change(status, d):
>      if not oes_bb_conf:
>          status.addresult('You are not using the OpenEmbedded version of conf/bitbake.conf. This means your environment is misconfigured, in particular check BBPATH.\n')
>
> -    # The length of TMPDIR can't be longer than 410
> -    status.addresult(check_path_length(tmpdir, "TMPDIR", 410))
> +    # The length of TMPDIR can't be longer than 400
> +    status.addresult(check_path_length(tmpdir, "TMPDIR", 400))
>
>      # Check that TMPDIR isn't located on nfs
>      status.addresult(check_not_nfs(tmpdir, "TMPDIR"))
> --
> 2.25.1
>
>
> -=-=-=-=-=-=-=-=-=-=-=-
> Links: You receive all messages sent to this group.
> View/Reply Online (#209146): https://lists.openembedded.org/g/openembedded-core/message/209146
> Mute This Topic: https://lists.openembedded.org/mt/110339915/1686489
> Group Owner: openembedded-core+owner@lists.openembedded.org
> Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub [alex.kanavin@gmail.com]
> -=-=-=-=-=-=-=-=-=-=-=-
>
diff mbox series

Patch

diff --git a/meta/classes-global/sanity.bbclass b/meta/classes-global/sanity.bbclass
index a0b2508e11..7b8a497d5a 100644
--- a/meta/classes-global/sanity.bbclass
+++ b/meta/classes-global/sanity.bbclass
@@ -760,8 +760,8 @@  def check_sanity_version_change(status, d):
     if not oes_bb_conf:
         status.addresult('You are not using the OpenEmbedded version of conf/bitbake.conf. This means your environment is misconfigured, in particular check BBPATH.\n')
 
-    # The length of TMPDIR can't be longer than 410
-    status.addresult(check_path_length(tmpdir, "TMPDIR", 410))
+    # The length of TMPDIR can't be longer than 400
+    status.addresult(check_path_length(tmpdir, "TMPDIR", 400))
 
     # Check that TMPDIR isn't located on nfs
     status.addresult(check_not_nfs(tmpdir, "TMPDIR"))