Skip to content

Commit 12d638f

Browse files
committed
scripts/dtc: Update to upstream version v1.7.0-93-g1df7b047fe43
This adds the following commits from upstream: 1df7b047fe43 pylibfdt/Makefile.pylibfdt: use project's flags to compile the extension 61e88fdcec52 libfdt: overlay: Fix phandle overwrite check for new subtrees 49d30894466e meson: fix installation with meson-python d54aaf93673c pylibfdt: clean up python build directory ab86f1e9fda8 pylibfdt: add VERSION.txt to Python sdist 7b8a30eceabe pylibfdt: fix Python version ff4f17eb5865 pylibfdt/Makefile.pylibfdt: fix Python library being rebuild during install 9e313b14e684 pylibfdt/meson.build: fix Python library being rebuilt during install d598fc3648ec tests/run_tests.sh: fix Meson library path being dropped b98239da2f18 tests/meson.build: fix python and yaml tests not running c17d76ab5e84 checks: Check the overall length of "interrupt-map" ae26223a056e libfdt: overlay: Refactor overlay_fixup_phandle 4dd831affd01 libfdt: tests: Update test case for overlay_bad_fixup e6d294200837 tests: Remove two_roots and named_root from LIBTREE_TESTS_L and add all dtb filenames generated by dumptrees to TESTS_TREES_L in Makefile.tests 855c934e26ae tests: fix tests broken under Meson 4fd3f4f0a95d github: enforce testing pylibfdt and yaml support 9ca7d62dbf0b meson: split run-tests by type bb51223083a4 meson: fix dependencies of tests e81900635c95 meson: fix pylibfdt missing dependency on libfdt 822123856980 pylibfdt: fix get_mem_rsv for newer Python versions 1fad065080e6 libfdt: overlay: ensure that existing phandles are not overwritten b0aacd0a7735 github: add windows/msys CI build ae97d9745862 github: Don't accidentally suppress test errors 057a7dbbb777 github: Display meson test logs on failure 92b5d4e91678 pylibfdt: Remove some apparently deprecated options from setup.py 417e3299dbd1 github: Update to newer checkout action 5e6cefa17e2d fix MinGW format attribute 24f60011fd43 libfdt: Simplify adjustment of values for local fixups da39ee0e68b6 libfdt: rework shared/static libraries a669223f7a60 Makefile: do not hardcode the `install` program path 3fbfdd08afd2 libfdt: fix duplicate meson target dcef5f834ea3 tests: use correct pkg-config when cross compiling 0b8026ff254f meson: allow building from shallow clones 95c74d71f090 treesource: Restore string list output when no type markers 2283dd78eff5 libfdt: fdt_path_offset_namelen: Reject empty path 79b9e326a162 libfdt: fdt_get_alias_namelen: Validate aliases 52157f13ef3d pylibfdt: Support boolean properties d77433727566 dtc: fix missing string in usage_opts_help ad8bf9f9aa39 libfdt: Fix fdt_appendprop_addrrange documentation 6c5e189fb952 github: add workflow for Meson builds a3dc9f006a78 libfdt: rename libfdt-X.Y.Z.so to libfdt.so.X.Y.Z 35019949c4c7 workflows: build: remove setuptools_scm hack cd3e2304f4a9 pylibfdt: use fallback version in tarballs 0f5864567745 move release version into VERSION.txt 38165954c13b libfdt: add missing version symbols 5e98b5979354 editorconfig: use tab indentation for version.lds d030a893be25 tests: generate dtbs in Meson build directory 8d8372b13706 tests: fix use of deprecated meson methods 761114effaf7 pylibtfdt: fix use of deprecated meson method bf6377a98d97 meson: set minimum Meson version to 0.56.0 4c68e4b16b22 libfdt: fix library version to match project version bdc5c8793a13 meson: allow disabling tests f088e381f29e Makefile: allow to install libfdt without building executables 6df5328a902c Fix use of <ctype.h> functions ccf1f62d59ad libfdt: Fix a typo in libfdt.h 71a8b8ef0adf libfdt: meson: Fix linking on macOS linker 589d8c7653c7 dtc: Add an option to generate __local_fixups__ and __fixups__ e8364666d5ac CI: Add build matrix with multiple Linux distributions 3b02a94b486f dtc: Correct invalid dts output with mixed phandles and integers d4888958d64b tests: Add additional tests for device graph checks ea3b9a1d2c5a checks: Fix crash in graph_child_address if 'reg' cell size != 1 b2b9671583e9 livetree: fix off-by-one in propval_cell_n() bounds check ab481e483061 Add definition for a GitHub Actions CI job c88038c9b8ca Drop obsolete/broken CI definitions 0ac8b30ba5a1 yaml: Depend on libyaml >= 0.2.3 f1657b2fb5be tests: Add test cases for bad endpoint node and remote-endpoint prop checks 44bb89cafd3d checks: Fix segmentation fault in check_graph_node 60bcf1cde1a8 improve documentation for fdt_path_offset() a6f997bc77d4 add fdt_get_symbol() and fdt_get_symbol_namelen() functions 18f5ec12a10e use fdt_path_getprop_namelen() in fdt_get_alias_namelen() df093279282c add fdt_path_getprop_namelen() helper 129bb4b78bc6 doc: dt-object-internal: Fix a typo 390f481521c3 fdtoverlay: Drop a a repeated article 9f8b382ed45e manual: Fix and improve documentation about -@ 2cdf93a6d402 fdtoverlay: Fix usage string to not mention "<type>" 72fc810c3025 build-sys: add -Wwrite-strings 083ab26da83b tests: fix leaks spotted by ASAN 6f8b28f49609 livetree: fix leak spotted by ASAN fd68bb8c5658 Make name_node() xstrdup its name argument 4718189c4ca8 Delay xstrdup() of node and property names coming from a flat tree 0b842c3c8199 Make build_property() xstrdup its name argument 9cceabea1ee0 checks: correct I2C 10-bit address check 0d56145938fe yamltree.c: fix -Werror=discarded-qualifiers & -Werror=cast-qual 61fa22b05f69 checks: make check.data const 7a1d72a788e0 checks.c: fix check_msg() leak ee5799938697 checks.c: fix heap-buffer-overflow 44c9b73801c1 tests: fix -Wwrite-strings 5b60f5104fcc srcpos.c: fix -Wwrite-strings 32174a66efa4 meson: Fix cell overflow tests when running from meson 64a907f08b9b meson.build: bump version to 1.7.0 e3cde0613bfd Add -Wsuggest-attribute=format warning, correct warnings thus generated 41821821101a Use #ifdef NO_VALGRIND 71c19f20b3ef Do not redefine _GNU_SOURCE if already set 039a99414e77 Bump version to v1.7.0 9b62ec84bb2d Merge remote-tracking branch 'gitlab/main' 3f29d6d85c24 pylibfdt: add size_hint parameter for get_path 2022bb10879d checks: Update #{size,address}-cells check for 'dma-ranges' Signed-off-by: Rob Herring (Arm) <[email protected]>
1 parent 9ca5a7d commit 12d638f

File tree

15 files changed

+539
-158
lines changed

15 files changed

+539
-158
lines changed

scripts/dtc/checks.c

Lines changed: 48 additions & 37 deletions
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,7 @@ typedef void (*check_fn)(struct check *c, struct dt_info *dti, struct node *node
3131
struct check {
3232
const char *name;
3333
check_fn fn;
34-
void *data;
34+
const void *data;
3535
bool warn, error;
3636
enum checkstatus status;
3737
bool inprogress;
@@ -114,6 +114,7 @@ static inline void PRINTF(5, 6) check_msg(struct check *c, struct dt_info *dti,
114114
}
115115

116116
fputs(str, stderr);
117+
free(str);
117118
}
118119

119120
#define FAIL(c, dti, node, ...) \
@@ -207,7 +208,7 @@ static void check_is_string(struct check *c, struct dt_info *dti,
207208
struct node *node)
208209
{
209210
struct property *prop;
210-
char *propname = c->data;
211+
const char *propname = c->data;
211212

212213
prop = get_property(node, propname);
213214
if (!prop)
@@ -226,7 +227,7 @@ static void check_is_string_list(struct check *c, struct dt_info *dti,
226227
{
227228
int rem, l;
228229
struct property *prop;
229-
char *propname = c->data;
230+
const char *propname = c->data;
230231
char *str;
231232

232233
prop = get_property(node, propname);
@@ -254,7 +255,7 @@ static void check_is_cell(struct check *c, struct dt_info *dti,
254255
struct node *node)
255256
{
256257
struct property *prop;
257-
char *propname = c->data;
258+
const char *propname = c->data;
258259

259260
prop = get_property(node, propname);
260261
if (!prop)
@@ -1078,10 +1079,11 @@ static void check_i2c_bus_reg(struct check *c, struct dt_info *dti, struct node
10781079
/* Ignore I2C_OWN_SLAVE_ADDRESS */
10791080
reg &= ~I2C_OWN_SLAVE_ADDRESS;
10801081

1081-
if ((reg & I2C_TEN_BIT_ADDRESS) && ((reg & ~I2C_TEN_BIT_ADDRESS) > 0x3ff))
1082-
FAIL_PROP(c, dti, node, prop, "I2C address must be less than 10-bits, got \"0x%x\"",
1082+
if (reg & I2C_TEN_BIT_ADDRESS) {
1083+
if ((reg & ~I2C_TEN_BIT_ADDRESS) > 0x3ff)
1084+
FAIL_PROP(c, dti, node, prop, "I2C address must be less than 10-bits, got \"0x%x\"",
10831085
reg);
1084-
else if (reg > 0x7f)
1086+
} else if (reg > 0x7f)
10851087
FAIL_PROP(c, dti, node, prop, "I2C address must be less than 7-bits, got \"0x%x\". Set I2C_TEN_BIT_ADDRESS for 10 bit addresses or fix the property",
10861088
reg);
10871089
}
@@ -1108,7 +1110,7 @@ static void check_spi_bus_bridge(struct check *c, struct dt_info *dti, struct no
11081110
for_each_child(node, child) {
11091111
struct property *prop;
11101112
for_each_property(child, prop) {
1111-
if (strprefixeq(prop->name, 4, "spi-")) {
1113+
if (strstarts(prop->name, "spi-")) {
11121114
node->bus = &spi_bus;
11131115
break;
11141116
}
@@ -1180,7 +1182,7 @@ static void check_unit_address_format(struct check *c, struct dt_info *dti,
11801182
/* skip over 0x for next test */
11811183
unitname += 2;
11821184
}
1183-
if (unitname[0] == '0' && isxdigit(unitname[1]))
1185+
if (unitname[0] == '0' && isxdigit((unsigned char)unitname[1]))
11841186
FAIL(c, dti, node, "unit name should not have leading 0s");
11851187
}
11861188
WARNING(unit_address_format, check_unit_address_format, NULL,
@@ -1222,7 +1224,7 @@ static void check_avoid_unnecessary_addr_size(struct check *c, struct dt_info *d
12221224
if (!node->parent || node->addr_cells < 0 || node->size_cells < 0)
12231225
return;
12241226

1225-
if (get_property(node, "ranges") || !node->children)
1227+
if (get_property(node, "ranges") || get_property(node, "dma-ranges") || !node->children)
12261228
return;
12271229

12281230
for_each_child(node, child) {
@@ -1232,7 +1234,7 @@ static void check_avoid_unnecessary_addr_size(struct check *c, struct dt_info *d
12321234
}
12331235

12341236
if (!has_reg)
1235-
FAIL(c, dti, node, "unnecessary #address-cells/#size-cells without \"ranges\" or child \"reg\" property");
1237+
FAIL(c, dti, node, "unnecessary #address-cells/#size-cells without \"ranges\", \"dma-ranges\" or child \"reg\" property");
12361238
}
12371239
WARNING(avoid_unnecessary_addr_size, check_avoid_unnecessary_addr_size, NULL, &avoid_default_addr_size);
12381240

@@ -1465,7 +1467,7 @@ static void check_provider_cells_property(struct check *c,
14651467
struct dt_info *dti,
14661468
struct node *node)
14671469
{
1468-
struct provider *provider = c->data;
1470+
const struct provider *provider = c->data;
14691471
struct property *prop;
14701472

14711473
prop = get_property(node, provider->prop_name);
@@ -1673,6 +1675,10 @@ static void check_interrupt_map(struct check *c,
16731675
parent_cellsize += propval_cell(cellprop);
16741676

16751677
cell += 1 + parent_cellsize;
1678+
if (cell > map_cells)
1679+
FAIL_PROP(c, dti, node, irq_map_prop,
1680+
"property size (%d) mismatch, expected %zu",
1681+
irq_map_prop->val.len, cell * sizeof(cell_t));
16761682
}
16771683
}
16781684
WARNING(interrupt_map, check_interrupt_map, NULL, &phandle_references, &addr_size_cells, &interrupt_provider);
@@ -1765,6 +1771,11 @@ static void check_graph_nodes(struct check *c, struct dt_info *dti,
17651771
get_property(child, "remote-endpoint")))
17661772
continue;
17671773

1774+
/* The root node cannot be a port */
1775+
if (!node->parent) {
1776+
FAIL(c, dti, node, "root node contains endpoint node '%s', potentially misplaced remote-endpoint property", child->name);
1777+
continue;
1778+
}
17681779
node->bus = &graph_port_bus;
17691780

17701781
/* The parent of 'port' nodes can be either 'ports' or a device */
@@ -1778,31 +1789,6 @@ static void check_graph_nodes(struct check *c, struct dt_info *dti,
17781789
}
17791790
WARNING(graph_nodes, check_graph_nodes, NULL);
17801791

1781-
static void check_graph_child_address(struct check *c, struct dt_info *dti,
1782-
struct node *node)
1783-
{
1784-
int cnt = 0;
1785-
struct node *child;
1786-
1787-
if (node->bus != &graph_ports_bus && node->bus != &graph_port_bus)
1788-
return;
1789-
1790-
for_each_child(node, child) {
1791-
struct property *prop = get_property(child, "reg");
1792-
1793-
/* No error if we have any non-zero unit address */
1794-
if (prop && propval_cell(prop) != 0)
1795-
return;
1796-
1797-
cnt++;
1798-
}
1799-
1800-
if (cnt == 1 && node->addr_cells != -1)
1801-
FAIL(c, dti, node, "graph node has single child node '%s', #address-cells/#size-cells are not necessary",
1802-
node->children->name);
1803-
}
1804-
WARNING(graph_child_address, check_graph_child_address, NULL, &graph_nodes);
1805-
18061792
static void check_graph_reg(struct check *c, struct dt_info *dti,
18071793
struct node *node)
18081794
{
@@ -1893,6 +1879,31 @@ static void check_graph_endpoint(struct check *c, struct dt_info *dti,
18931879
}
18941880
WARNING(graph_endpoint, check_graph_endpoint, NULL, &graph_nodes);
18951881

1882+
static void check_graph_child_address(struct check *c, struct dt_info *dti,
1883+
struct node *node)
1884+
{
1885+
int cnt = 0;
1886+
struct node *child;
1887+
1888+
if (node->bus != &graph_ports_bus && node->bus != &graph_port_bus)
1889+
return;
1890+
1891+
for_each_child(node, child) {
1892+
struct property *prop = get_property(child, "reg");
1893+
1894+
/* No error if we have any non-zero unit address */
1895+
if (prop && propval_cell(prop) != 0 )
1896+
return;
1897+
1898+
cnt++;
1899+
}
1900+
1901+
if (cnt == 1 && node->addr_cells != -1)
1902+
FAIL(c, dti, node, "graph node has single child node '%s', #address-cells/#size-cells are not necessary",
1903+
node->children->name);
1904+
}
1905+
WARNING(graph_child_address, check_graph_child_address, NULL, &graph_nodes, &graph_port, &graph_endpoint);
1906+
18961907
static struct check *check_table[] = {
18971908
&duplicate_node_names, &duplicate_property_names,
18981909
&node_name_chars, &node_name_format, &property_name_chars,

scripts/dtc/dtc-parser.y

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -284,14 +284,17 @@ propdef:
284284
DT_PROPNODENAME '=' propdata ';'
285285
{
286286
$$ = build_property($1, $3, &@$);
287+
free($1);
287288
}
288289
| DT_PROPNODENAME ';'
289290
{
290291
$$ = build_property($1, empty_data, &@$);
292+
free($1);
291293
}
292294
| DT_DEL_PROP DT_PROPNODENAME ';'
293295
{
294296
$$ = build_property_delete($2);
297+
free($2);
295298
}
296299
| DT_LABEL propdef
297300
{
@@ -570,10 +573,12 @@ subnode:
570573
DT_PROPNODENAME nodedef
571574
{
572575
$$ = name_node($2, $1);
576+
free($1);
573577
}
574578
| DT_DEL_NODE DT_PROPNODENAME ';'
575579
{
576580
$$ = name_node(build_node_delete(&@$), $2);
581+
free($2);
577582
}
578583
| DT_OMIT_NO_REF subnode
579584
{

scripts/dtc/dtc.c

Lines changed: 8 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -47,7 +47,7 @@ static void fill_fullpaths(struct node *tree, const char *prefix)
4747

4848
/* Usage related data. */
4949
static const char usage_synopsis[] = "dtc [options] <input file>";
50-
static const char usage_short_opts[] = "qI:O:o:V:d:R:S:p:a:fb:i:H:sW:E:@AThv";
50+
static const char usage_short_opts[] = "qI:O:o:V:d:R:S:p:a:fb:i:H:sW:E:@LAThv";
5151
static struct option const usage_long_opts[] = {
5252
{"quiet", no_argument, NULL, 'q'},
5353
{"in-format", a_argument, NULL, 'I'},
@@ -67,6 +67,7 @@ static struct option const usage_long_opts[] = {
6767
{"warning", a_argument, NULL, 'W'},
6868
{"error", a_argument, NULL, 'E'},
6969
{"symbols", no_argument, NULL, '@'},
70+
{"local-fixups", no_argument, NULL, 'L'},
7071
{"auto-alias", no_argument, NULL, 'A'},
7172
{"annotate", no_argument, NULL, 'T'},
7273
{"help", no_argument, NULL, 'h'},
@@ -104,6 +105,7 @@ static const char * const usage_opts_help[] = {
104105
"\n\tEnable/disable warnings (prefix with \"no-\")",
105106
"\n\tEnable/disable errors (prefix with \"no-\")",
106107
"\n\tEnable generation of symbols",
108+
"\n\tPossibly generates a __local_fixups__ and a __fixups__ node at the root node",
107109
"\n\tEnable auto-alias of labels",
108110
"\n\tAnnotate output .dts with input source file and line (-T -T for more details)",
109111
"\n\tPrint this help and exit",
@@ -252,6 +254,11 @@ int main(int argc, char *argv[])
252254
case '@':
253255
generate_symbols = 1;
254256
break;
257+
258+
case 'L':
259+
generate_fixups = 1;
260+
break;
261+
255262
case 'A':
256263
auto_label_aliases = 1;
257264
break;

scripts/dtc/dtc.h

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -260,16 +260,16 @@ struct node {
260260
void add_label(struct label **labels, char *label);
261261
void delete_labels(struct label **labels);
262262

263-
struct property *build_property(char *name, struct data val,
263+
struct property *build_property(const char *name, struct data val,
264264
struct srcpos *srcpos);
265-
struct property *build_property_delete(char *name);
265+
struct property *build_property_delete(const char *name);
266266
struct property *chain_property(struct property *first, struct property *list);
267267
struct property *reverse_properties(struct property *first);
268268

269269
struct node *build_node(struct property *proplist, struct node *children,
270270
struct srcpos *srcpos);
271271
struct node *build_node_delete(struct srcpos *srcpos);
272-
struct node *name_node(struct node *node, char *name);
272+
struct node *name_node(struct node *node, const char *name);
273273
struct node *omit_node_if_unused(struct node *node);
274274
struct node *reference_node(struct node *node);
275275
struct node *chain_node(struct node *first, struct node *list);
@@ -336,9 +336,9 @@ struct dt_info *build_dt_info(unsigned int dtsflags,
336336
struct reserve_info *reservelist,
337337
struct node *tree, uint32_t boot_cpuid_phys);
338338
void sort_tree(struct dt_info *dti);
339-
void generate_label_tree(struct dt_info *dti, char *name, bool allocph);
340-
void generate_fixups_tree(struct dt_info *dti, char *name);
341-
void generate_local_fixups_tree(struct dt_info *dti, char *name);
339+
void generate_label_tree(struct dt_info *dti, const char *name, bool allocph);
340+
void generate_fixups_tree(struct dt_info *dti, const char *name);
341+
void generate_local_fixups_tree(struct dt_info *dti, const char *name);
342342

343343
/* Checks */
344344

scripts/dtc/fdtoverlay.c

Lines changed: 2 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -23,9 +23,7 @@
2323
/* Usage related data. */
2424
static const char usage_synopsis[] =
2525
"apply a number of overlays to a base blob\n"
26-
" fdtoverlay <options> [<overlay.dtbo> [<overlay.dtbo>]]\n"
27-
"\n"
28-
USAGE_TYPE_MSG;
26+
" fdtoverlay <options> [<overlay.dtbo> [<overlay.dtbo>]]";
2927
static const char usage_short_opts[] = "i:o:v" USAGE_COMMON_SHORT_OPTS;
3028
static struct option const usage_long_opts[] = {
3129
{"input", required_argument, NULL, 'i'},
@@ -50,7 +48,7 @@ static void *apply_one(char *base, const char *overlay, size_t *buf_len,
5048
int ret;
5149

5250
/*
53-
* We take a copies first, because a a failed apply can trash
51+
* We take a copies first, because a failed apply can trash
5452
* both the base blob and the overlay
5553
*/
5654
tmpo = xmalloc(fdt_totalsize(overlay));

scripts/dtc/flattree.c

Lines changed: 9 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -604,19 +604,19 @@ static void flat_realign(struct inbuf *inb, int align)
604604
die("Premature end of data parsing flat device tree\n");
605605
}
606606

607-
static char *flat_read_string(struct inbuf *inb)
607+
static const char *flat_read_string(struct inbuf *inb)
608608
{
609609
int len = 0;
610610
const char *p = inb->ptr;
611-
char *str;
611+
const char *str;
612612

613613
do {
614614
if (p >= inb->limit)
615615
die("Premature end of data parsing flat device tree\n");
616616
len++;
617617
} while ((*p++) != '\0');
618618

619-
str = xstrdup(inb->ptr);
619+
str = inb->ptr;
620620

621621
inb->ptr += len;
622622

@@ -711,7 +711,7 @@ static struct reserve_info *flat_read_mem_reserve(struct inbuf *inb)
711711
}
712712

713713

714-
static char *nodename_from_path(const char *ppath, const char *cpath)
714+
static const char *nodename_from_path(const char *ppath, const char *cpath)
715715
{
716716
int plen;
717717

@@ -725,25 +725,26 @@ static char *nodename_from_path(const char *ppath, const char *cpath)
725725
if (!streq(ppath, "/"))
726726
plen++;
727727

728-
return xstrdup(cpath + plen);
728+
return cpath + plen;
729729
}
730730

731731
static struct node *unflatten_tree(struct inbuf *dtbuf,
732732
struct inbuf *strbuf,
733733
const char *parent_flatname, int flags)
734734
{
735735
struct node *node;
736-
char *flatname;
736+
const char *flatname;
737737
uint32_t val;
738738

739739
node = build_node(NULL, NULL, NULL);
740740

741741
flatname = flat_read_string(dtbuf);
742742

743743
if (flags & FTF_FULLPATH)
744-
node->name = nodename_from_path(parent_flatname, flatname);
744+
node->name = xstrdup(nodename_from_path(parent_flatname,
745+
flatname));
745746
else
746-
node->name = flatname;
747+
node->name = xstrdup(flatname);
747748

748749
do {
749750
struct property *prop;
@@ -785,10 +786,6 @@ static struct node *unflatten_tree(struct inbuf *dtbuf,
785786
}
786787
} while (val != FDT_END_NODE);
787788

788-
if (node->name != flatname) {
789-
free(flatname);
790-
}
791-
792789
return node;
793790
}
794791

scripts/dtc/fstree.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -43,7 +43,7 @@ static struct node *read_fstree(const char *dirname)
4343
"WARNING: Cannot open %s: %s\n",
4444
tmpname, strerror(errno));
4545
} else {
46-
prop = build_property(xstrdup(de->d_name),
46+
prop = build_property(de->d_name,
4747
data_copy_file(pfile,
4848
st.st_size),
4949
NULL);

0 commit comments

Comments
 (0)