diff options
author | Michael Tretter <m.tretter@pengutronix.de> | 2020-09-01 15:29:00 +0200 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2020-09-02 16:00:46 +0100 |
commit | fdc6ef9673c5b65e82267220ac38d60f43c213ed (patch) | |
tree | 3c6f8dd865208cd2d750d135f78b03b5a872bb44 /scripts/lib/devtool | |
parent | 0033cc5c10cbdb7850c96f42e02ef12f55dbc575 (diff) | |
download | poky-fdc6ef9673c5b65e82267220ac38d60f43c213ed.tar.gz |
devtool: deploy-target: Fix size calculation for hard links
If a package contains hard links to a file, the file size is added for
each hard link instead of once for the file. Therefore, the calculated
size may be much larger than the actual package size.
For example, the mesa-megadriver package contains several hard links to
the same library.
Keep track of the inode numbers when listing the files that are
installed and use the actual size only for the first occurrence of an
inode. All further hard links to the same inode are added to the file
list, but accounted with size 0.
All file names need to be added to the file list, because the list is
used for preserving the files/hard links on the target.
(From OE-Core rev: 17e92572278980d1a7f06de9d72c68baf57698f1)
Signed-off-by: Michael Tretter <m.tretter@pengutronix.de>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'scripts/lib/devtool')
-rw-r--r-- | scripts/lib/devtool/deploy.py | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/scripts/lib/devtool/deploy.py b/scripts/lib/devtool/deploy.py index b1749ce672..e5af2c95ae 100644 --- a/scripts/lib/devtool/deploy.py +++ b/scripts/lib/devtool/deploy.py | |||
@@ -177,13 +177,19 @@ def deploy(args, config, basepath, workspace): | |||
177 | rd.getVar('base_libdir'), rd) | 177 | rd.getVar('base_libdir'), rd) |
178 | 178 | ||
179 | filelist = [] | 179 | filelist = [] |
180 | inodes = set({}) | ||
180 | ftotalsize = 0 | 181 | ftotalsize = 0 |
181 | for root, _, files in os.walk(recipe_outdir): | 182 | for root, _, files in os.walk(recipe_outdir): |
182 | for fn in files: | 183 | for fn in files: |
184 | fstat = os.lstat(os.path.join(root, fn)) | ||
183 | # Get the size in kiB (since we'll be comparing it to the output of du -k) | 185 | # Get the size in kiB (since we'll be comparing it to the output of du -k) |
184 | # MUST use lstat() here not stat() or getfilesize() since we don't want to | 186 | # MUST use lstat() here not stat() or getfilesize() since we don't want to |
185 | # dereference symlinks | 187 | # dereference symlinks |
186 | fsize = int(math.ceil(float(os.lstat(os.path.join(root, fn)).st_size)/1024)) | 188 | if fstat.st_ino in inodes: |
189 | fsize = 0 | ||
190 | else: | ||
191 | fsize = int(math.ceil(float(fstat.st_size)/1024)) | ||
192 | inodes.add(fstat.st_ino) | ||
187 | ftotalsize += fsize | 193 | ftotalsize += fsize |
188 | # The path as it would appear on the target | 194 | # The path as it would appear on the target |
189 | fpath = os.path.join(destdir, os.path.relpath(root, recipe_outdir), fn) | 195 | fpath = os.path.join(destdir, os.path.relpath(root, recipe_outdir), fn) |