Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
L
lxc
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Chen Yisong
lxc
Commits
9de31d5a
Unverified
Commit
9de31d5a
authored
May 11, 2018
by
Christian Brauner
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
tree-wide: s/strncpy()/strlcpy()/g
Signed-off-by:
Christian Brauner
<
christian.brauner@ubuntu.com
>
parent
91c272a5
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
98 additions
and
30 deletions
+98
-30
af_unix.c
src/lxc/af_unix.c
+10
-4
criu.c
src/lxc/criu.c
+7
-2
log.c
src/lxc/log.c
+6
-2
lxccontainer.c
src/lxc/lxccontainer.c
+9
-3
monitor.c
src/lxc/monitor.c
+6
-4
network.c
src/lxc/network.c
+16
-3
start.c
src/lxc/start.c
+8
-2
btrfs.c
src/lxc/storage/btrfs.c
+25
-9
storage_utils.c
src/lxc/storage/storage_utils.c
+11
-1
No files found.
src/lxc/af_unix.c
View file @
9de31d5a
...
@@ -36,6 +36,10 @@
...
@@ -36,6 +36,10 @@
#include "log.h"
#include "log.h"
#include "utils.h"
#include "utils.h"
#ifndef HAVE_STRLCPY
#include "include/strlcpy.h"
#endif
lxc_log_define
(
lxc_af_unix
,
lxc
);
lxc_log_define
(
lxc_af_unix
,
lxc
);
int
lxc_abstract_unix_open
(
const
char
*
path
,
int
type
,
int
flags
)
int
lxc_abstract_unix_open
(
const
char
*
path
,
int
type
,
int
flags
)
...
@@ -63,8 +67,9 @@ int lxc_abstract_unix_open(const char *path, int type, int flags)
...
@@ -63,8 +67,9 @@ int lxc_abstract_unix_open(const char *path, int type, int flags)
errno
=
ENAMETOOLONG
;
errno
=
ENAMETOOLONG
;
return
-
1
;
return
-
1
;
}
}
/* addr.sun_path[0] has already been set to 0 by memset() */
strncpy
(
&
addr
.
sun_path
[
1
],
&
path
[
1
],
len
);
/* do not enforce \0-termination */
memcpy
(
&
addr
.
sun_path
[
1
],
&
path
[
1
],
len
);
ret
=
bind
(
fd
,
(
struct
sockaddr
*
)
&
addr
,
ret
=
bind
(
fd
,
(
struct
sockaddr
*
)
&
addr
,
offsetof
(
struct
sockaddr_un
,
sun_path
)
+
len
+
1
);
offsetof
(
struct
sockaddr_un
,
sun_path
)
+
len
+
1
);
...
@@ -116,8 +121,9 @@ int lxc_abstract_unix_connect(const char *path)
...
@@ -116,8 +121,9 @@ int lxc_abstract_unix_connect(const char *path)
errno
=
ENAMETOOLONG
;
errno
=
ENAMETOOLONG
;
return
-
1
;
return
-
1
;
}
}
/* addr.sun_path[0] has already been set to 0 by memset() */
strncpy
(
&
addr
.
sun_path
[
1
],
&
path
[
1
],
strlen
(
&
path
[
1
]));
/* do not enforce \0-termination */
memcpy
(
&
addr
.
sun_path
[
1
],
&
path
[
1
],
len
);
ret
=
connect
(
fd
,
(
struct
sockaddr
*
)
&
addr
,
ret
=
connect
(
fd
,
(
struct
sockaddr
*
)
&
addr
,
offsetof
(
struct
sockaddr_un
,
sun_path
)
+
len
+
1
);
offsetof
(
struct
sockaddr_un
,
sun_path
)
+
len
+
1
);
...
...
src/lxc/criu.c
View file @
9de31d5a
...
@@ -51,6 +51,10 @@
...
@@ -51,6 +51,10 @@
#include <mntent.h>
#include <mntent.h>
#endif
#endif
#ifndef HAVE_STRLCPY
#include "include/strlcpy.h"
#endif
#define CRIU_VERSION "2.0"
#define CRIU_VERSION "2.0"
#define CRIU_GITID_VERSION "2.0"
#define CRIU_GITID_VERSION "2.0"
...
@@ -536,6 +540,7 @@ static void exec_criu(struct criu_opts *opts)
...
@@ -536,6 +540,7 @@ static void exec_criu(struct criu_opts *opts)
argv
=
m
;
argv
=
m
;
lxc_list_for_each
(
it
,
&
opts
->
c
->
lxc_conf
->
network
)
{
lxc_list_for_each
(
it
,
&
opts
->
c
->
lxc_conf
->
network
)
{
size_t
retlen
;
char
eth
[
128
],
*
veth
;
char
eth
[
128
],
*
veth
;
char
*
fmt
;
char
*
fmt
;
struct
lxc_netdev
*
n
=
it
->
elem
;
struct
lxc_netdev
*
n
=
it
->
elem
;
...
@@ -552,9 +557,9 @@ static void exec_criu(struct criu_opts *opts)
...
@@ -552,9 +557,9 @@ static void exec_criu(struct criu_opts *opts)
}
}
if
(
n
->
name
[
0
]
!=
'\0'
)
{
if
(
n
->
name
[
0
]
!=
'\0'
)
{
if
(
strlen
(
n
->
name
)
>=
sizeof
(
eth
))
retlen
=
strlcpy
(
eth
,
n
->
name
,
sizeof
(
eth
));
if
(
retlen
>=
sizeof
(
eth
))
goto
err
;
goto
err
;
strncpy
(
eth
,
n
->
name
,
sizeof
(
eth
));
}
else
{
}
else
{
ret
=
snprintf
(
eth
,
sizeof
(
eth
),
"eth%d"
,
netnr
);
ret
=
snprintf
(
eth
,
sizeof
(
eth
),
"eth%d"
,
netnr
);
if
(
ret
<
0
||
ret
>=
sizeof
(
eth
))
if
(
ret
<
0
||
ret
>=
sizeof
(
eth
))
...
...
src/lxc/log.c
View file @
9de31d5a
...
@@ -46,6 +46,10 @@
...
@@ -46,6 +46,10 @@
#include "utils.h"
#include "utils.h"
#include "lxccontainer.h"
#include "lxccontainer.h"
#ifndef HAVE_STRLCPY
#include "include/strlcpy.h"
#endif
/* We're logging in seconds and nanoseconds. Assuming that the underlying
/* We're logging in seconds and nanoseconds. Assuming that the underlying
* datatype is currently at maximum a 64bit integer, we have a date string that
* datatype is currently at maximum a 64bit integer, we have a date string that
* is of maximum length (2^64 - 1) * 2 = (21 + 21) = 42.
* is of maximum length (2^64 - 1) * 2 = (21 + 21) = 42.
...
@@ -690,8 +694,8 @@ extern const char *lxc_log_get_file(void)
...
@@ -690,8 +694,8 @@ extern const char *lxc_log_get_file(void)
extern
void
lxc_log_set_prefix
(
const
char
*
prefix
)
extern
void
lxc_log_set_prefix
(
const
char
*
prefix
)
{
{
strncpy
(
log_prefix
,
prefix
,
sizeof
(
log_prefix
));
/* We don't care if thte prefix is truncated. */
log_prefix
[
sizeof
(
log_prefix
)
-
1
]
=
0
;
(
void
)
strlcpy
(
log_prefix
,
prefix
,
sizeof
(
log_prefix
))
;
}
}
extern
const
char
*
lxc_log_get_prefix
(
void
)
extern
const
char
*
lxc_log_get_prefix
(
void
)
...
...
src/lxc/lxccontainer.c
View file @
9de31d5a
...
@@ -87,6 +87,10 @@
...
@@ -87,6 +87,10 @@
#include <mntent.h>
#include <mntent.h>
#endif
#endif
#ifndef HAVE_STRLCPY
#include "include/strlcpy.h"
#endif
/* Define faccessat() if missing from the C library */
/* Define faccessat() if missing from the C library */
#ifndef HAVE_FACCESSAT
#ifndef HAVE_FACCESSAT
static
int
faccessat
(
int
__fd
,
const
char
*
__file
,
int
__type
,
int
__flag
)
static
int
faccessat
(
int
__fd
,
const
char
*
__file
,
int
__type
,
int
__flag
)
...
@@ -728,7 +732,7 @@ static void push_arg(char ***argp, char *arg, int *nargs)
...
@@ -728,7 +732,7 @@ static void push_arg(char ***argp, char *arg, int *nargs)
static
char
**
split_init_cmd
(
const
char
*
incmd
)
static
char
**
split_init_cmd
(
const
char
*
incmd
)
{
{
size_t
len
;
size_t
len
,
retlen
;
char
*
copy
,
*
p
;
char
*
copy
,
*
p
;
char
**
argv
;
char
**
argv
;
int
nargs
=
0
;
int
nargs
=
0
;
...
@@ -739,8 +743,10 @@ static char **split_init_cmd(const char *incmd)
...
@@ -739,8 +743,10 @@ static char **split_init_cmd(const char *incmd)
len
=
strlen
(
incmd
)
+
1
;
len
=
strlen
(
incmd
)
+
1
;
copy
=
alloca
(
len
);
copy
=
alloca
(
len
);
strncpy
(
copy
,
incmd
,
len
);
retlen
=
strlcpy
(
copy
,
incmd
,
len
);
copy
[
len
-
1
]
=
'\0'
;
if
(
retlen
>=
len
)
{
return
NULL
;
}
do
{
do
{
argv
=
malloc
(
sizeof
(
char
*
));
argv
=
malloc
(
sizeof
(
char
*
));
...
...
src/lxc/monitor.c
View file @
9de31d5a
...
@@ -49,6 +49,10 @@
...
@@ -49,6 +49,10 @@
#include "state.h"
#include "state.h"
#include "utils.h"
#include "utils.h"
#ifndef HAVE_STRLCPY
#include "include/strlcpy.h"
#endif
lxc_log_define
(
lxc_monitor
,
lxc
);
lxc_log_define
(
lxc_monitor
,
lxc
);
/* routines used by monitor publishers (containers) */
/* routines used by monitor publishers (containers) */
...
@@ -131,9 +135,8 @@ void lxc_monitor_send_state(const char *name, lxc_state_t state,
...
@@ -131,9 +135,8 @@ void lxc_monitor_send_state(const char *name, lxc_state_t state,
const
char
*
lxcpath
)
const
char
*
lxcpath
)
{
{
struct
lxc_msg
msg
=
{.
type
=
lxc_msg_state
,
.
value
=
state
};
struct
lxc_msg
msg
=
{.
type
=
lxc_msg_state
,
.
value
=
state
};
strncpy
(
msg
.
name
,
name
,
sizeof
(
msg
.
name
));
msg
.
name
[
sizeof
(
msg
.
name
)
-
1
]
=
0
;
(
void
)
strlcpy
(
msg
.
name
,
name
,
sizeof
(
msg
.
name
));
lxc_monitor_fifo_send
(
&
msg
,
lxcpath
);
lxc_monitor_fifo_send
(
&
msg
,
lxcpath
);
}
}
...
@@ -141,9 +144,8 @@ void lxc_monitor_send_exit_code(const char *name, int exit_code,
...
@@ -141,9 +144,8 @@ void lxc_monitor_send_exit_code(const char *name, int exit_code,
const
char
*
lxcpath
)
const
char
*
lxcpath
)
{
{
struct
lxc_msg
msg
=
{.
type
=
lxc_msg_exit_code
,
.
value
=
exit_code
};
struct
lxc_msg
msg
=
{.
type
=
lxc_msg_exit_code
,
.
value
=
exit_code
};
strncpy
(
msg
.
name
,
name
,
sizeof
(
msg
.
name
));
msg
.
name
[
sizeof
(
msg
.
name
)
-
1
]
=
0
;
(
void
)
strlcpy
(
msg
.
name
,
name
,
sizeof
(
msg
.
name
));
lxc_monitor_fifo_send
(
&
msg
,
lxcpath
);
lxc_monitor_fifo_send
(
&
msg
,
lxcpath
);
}
}
...
...
src/lxc/network.c
View file @
9de31d5a
...
@@ -59,6 +59,10 @@
...
@@ -59,6 +59,10 @@
#include <../include/ifaddrs.h>
#include <../include/ifaddrs.h>
#endif
#endif
#ifndef HAVE_STRLCPY
#include "include/strlcpy.h"
#endif
#ifndef IFLA_LINKMODE
#ifndef IFLA_LINKMODE
#define IFLA_LINKMODE 17
#define IFLA_LINKMODE 17
#endif
#endif
...
@@ -1894,6 +1898,7 @@ static int lxc_ovs_attach_bridge(const char *bridge, const char *nic)
...
@@ -1894,6 +1898,7 @@ static int lxc_ovs_attach_bridge(const char *bridge, const char *nic)
int
lxc_bridge_attach
(
const
char
*
bridge
,
const
char
*
ifname
)
int
lxc_bridge_attach
(
const
char
*
bridge
,
const
char
*
ifname
)
{
{
int
err
,
fd
,
index
;
int
err
,
fd
,
index
;
size_t
retlen
;
struct
ifreq
ifr
;
struct
ifreq
ifr
;
if
(
strlen
(
ifname
)
>=
IFNAMSIZ
)
if
(
strlen
(
ifname
)
>=
IFNAMSIZ
)
...
@@ -1910,7 +1915,10 @@ int lxc_bridge_attach(const char *bridge, const char *ifname)
...
@@ -1910,7 +1915,10 @@ int lxc_bridge_attach(const char *bridge, const char *ifname)
if
(
fd
<
0
)
if
(
fd
<
0
)
return
-
errno
;
return
-
errno
;
strncpy
(
ifr
.
ifr_name
,
bridge
,
IFNAMSIZ
-
1
);
retlen
=
strlcpy
(
ifr
.
ifr_name
,
bridge
,
IFNAMSIZ
);
if
(
retlen
>=
IFNAMSIZ
)
return
-
E2BIG
;
ifr
.
ifr_name
[
IFNAMSIZ
-
1
]
=
'\0'
;
ifr
.
ifr_name
[
IFNAMSIZ
-
1
]
=
'\0'
;
ifr
.
ifr_ifindex
=
index
;
ifr
.
ifr_ifindex
=
index
;
err
=
ioctl
(
fd
,
SIOCBRADDIF
,
&
ifr
);
err
=
ioctl
(
fd
,
SIOCBRADDIF
,
&
ifr
);
...
@@ -2113,6 +2121,7 @@ static int lxc_create_network_unpriv_exec(const char *lxcpath, const char *lxcna
...
@@ -2113,6 +2121,7 @@ static int lxc_create_network_unpriv_exec(const char *lxcpath, const char *lxcna
if
(
child
==
0
)
{
if
(
child
==
0
)
{
int
ret
;
int
ret
;
size_t
retlen
;
char
pidstr
[
LXC_NUMSTRLEN64
];
char
pidstr
[
LXC_NUMSTRLEN64
];
close
(
pipefd
[
0
]);
close
(
pipefd
[
0
]);
...
@@ -2127,9 +2136,13 @@ static int lxc_create_network_unpriv_exec(const char *lxcpath, const char *lxcna
...
@@ -2127,9 +2136,13 @@ static int lxc_create_network_unpriv_exec(const char *lxcpath, const char *lxcna
}
}
if
(
netdev
->
link
[
0
]
!=
'\0'
)
if
(
netdev
->
link
[
0
]
!=
'\0'
)
strncpy
(
netdev_link
,
netdev
->
link
,
IFNAMSIZ
-
1
);
retlen
=
strlcpy
(
netdev_link
,
netdev
->
link
,
IFNAMSIZ
);
else
else
strncpy
(
netdev_link
,
"none"
,
IFNAMSIZ
-
1
);
retlen
=
strlcpy
(
netdev_link
,
"none"
,
IFNAMSIZ
);
if
(
retlen
>=
IFNAMSIZ
)
{
SYSERROR
(
"Invalid network device name"
);
_exit
(
EXIT_FAILURE
);
}
ret
=
snprintf
(
pidstr
,
LXC_NUMSTRLEN64
,
"%d"
,
pid
);
ret
=
snprintf
(
pidstr
,
LXC_NUMSTRLEN64
,
"%d"
,
pid
);
if
(
ret
<
0
||
ret
>=
LXC_NUMSTRLEN64
)
if
(
ret
<
0
||
ret
>=
LXC_NUMSTRLEN64
)
...
...
src/lxc/start.c
View file @
9de31d5a
...
@@ -89,6 +89,10 @@
...
@@ -89,6 +89,10 @@
#include "terminal.h"
#include "terminal.h"
#include "utils.h"
#include "utils.h"
#ifndef HAVE_STRLCPY
#include "include/strlcpy.h"
#endif
lxc_log_define
(
lxc_start
,
lxc
);
lxc_log_define
(
lxc_start
,
lxc
);
extern
void
mod_all_rdeps
(
struct
lxc_container
*
c
,
bool
inc
);
extern
void
mod_all_rdeps
(
struct
lxc_container
*
c
,
bool
inc
);
...
@@ -410,6 +414,7 @@ static int signal_handler(int fd, uint32_t events, void *data,
...
@@ -410,6 +414,7 @@ static int signal_handler(int fd, uint32_t events, void *data,
int
lxc_serve_state_clients
(
const
char
*
name
,
struct
lxc_handler
*
handler
,
int
lxc_serve_state_clients
(
const
char
*
name
,
struct
lxc_handler
*
handler
,
lxc_state_t
state
)
lxc_state_t
state
)
{
{
size_t
retlen
;
ssize_t
ret
;
ssize_t
ret
;
struct
lxc_list
*
cur
,
*
next
;
struct
lxc_list
*
cur
,
*
next
;
struct
lxc_state_client
*
client
;
struct
lxc_state_client
*
client
;
...
@@ -427,8 +432,9 @@ int lxc_serve_state_clients(const char *name, struct lxc_handler *handler,
...
@@ -427,8 +432,9 @@ int lxc_serve_state_clients(const char *name, struct lxc_handler *handler,
return
0
;
return
0
;
}
}
strncpy
(
msg
.
name
,
name
,
sizeof
(
msg
.
name
));
retlen
=
strlcpy
(
msg
.
name
,
name
,
sizeof
(
msg
.
name
));
msg
.
name
[
sizeof
(
msg
.
name
)
-
1
]
=
0
;
if
(
retlen
>=
sizeof
(
msg
.
name
))
return
-
E2BIG
;
lxc_list_for_each_safe
(
cur
,
&
handler
->
conf
->
state_clients
,
next
)
{
lxc_list_for_each_safe
(
cur
,
&
handler
->
conf
->
state_clients
,
next
)
{
client
=
cur
->
elem
;
client
=
cur
->
elem
;
...
...
src/lxc/storage/btrfs.c
View file @
9de31d5a
...
@@ -42,6 +42,10 @@
...
@@ -42,6 +42,10 @@
#include "storage.h"
#include "storage.h"
#include "utils.h"
#include "utils.h"
#ifndef HAVE_STRLCPY
#include "include/strlcpy.h"
#endif
lxc_log_define
(
btrfs
,
lxc
);
lxc_log_define
(
btrfs
,
lxc
);
/*
/*
...
@@ -223,6 +227,7 @@ int btrfs_umount(struct lxc_storage *bdev)
...
@@ -223,6 +227,7 @@ int btrfs_umount(struct lxc_storage *bdev)
static
int
btrfs_subvolume_create
(
const
char
*
path
)
static
int
btrfs_subvolume_create
(
const
char
*
path
)
{
{
int
ret
,
saved_errno
;
int
ret
,
saved_errno
;
size_t
retlen
;
struct
btrfs_ioctl_vol_args
args
;
struct
btrfs_ioctl_vol_args
args
;
char
*
p
,
*
newfull
;
char
*
p
,
*
newfull
;
int
fd
=
-
1
;
int
fd
=
-
1
;
...
@@ -248,8 +253,9 @@ static int btrfs_subvolume_create(const char *path)
...
@@ -248,8 +253,9 @@ static int btrfs_subvolume_create(const char *path)
}
}
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
strncpy
(
args
.
name
,
p
+
1
,
BTRFS_SUBVOL_NAME_MAX
);
retlen
=
strlcpy
(
args
.
name
,
p
+
1
,
BTRFS_SUBVOL_NAME_MAX
);
args
.
name
[
BTRFS_SUBVOL_NAME_MAX
-
1
]
=
0
;
if
(
retlen
>=
BTRFS_SUBVOL_NAME_MAX
)
return
-
E2BIG
;
ret
=
ioctl
(
fd
,
BTRFS_IOC_SUBVOL_CREATE
,
&
args
);
ret
=
ioctl
(
fd
,
BTRFS_IOC_SUBVOL_CREATE
,
&
args
);
saved_errno
=
errno
;
saved_errno
=
errno
;
...
@@ -303,6 +309,7 @@ out:
...
@@ -303,6 +309,7 @@ out:
int
btrfs_snapshot
(
const
char
*
orig
,
const
char
*
new
)
int
btrfs_snapshot
(
const
char
*
orig
,
const
char
*
new
)
{
{
size_t
retlen
;
struct
btrfs_ioctl_vol_args_v2
args
;
struct
btrfs_ioctl_vol_args_v2
args
;
char
*
newdir
,
*
newname
;
char
*
newdir
,
*
newname
;
char
*
newfull
=
NULL
;
char
*
newfull
=
NULL
;
...
@@ -328,9 +335,9 @@ int btrfs_snapshot(const char *orig, const char *new)
...
@@ -328,9 +335,9 @@ int btrfs_snapshot(const char *orig, const char *new)
goto
out
;
goto
out
;
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
fd
=
fd
;
retlen
=
strlcpy
(
args
.
name
,
newname
,
BTRFS_SUBVOL_NAME_MAX
)
;
strncpy
(
args
.
name
,
newname
,
BTRFS_SUBVOL_NAME_MAX
);
if
(
retlen
>=
BTRFS_SUBVOL_NAME_MAX
)
args
.
name
[
BTRFS_SUBVOL_NAME_MAX
-
1
]
=
0
;
goto
out
;
ret
=
ioctl
(
fddst
,
BTRFS_IOC_SNAP_CREATE_V2
,
&
args
);
ret
=
ioctl
(
fddst
,
BTRFS_IOC_SNAP_CREATE_V2
,
&
args
);
saved_errno
=
errno
;
saved_errno
=
errno
;
...
@@ -498,6 +505,7 @@ bool btrfs_create_snapshot(struct lxc_conf *conf, struct lxc_storage *orig,
...
@@ -498,6 +505,7 @@ bool btrfs_create_snapshot(struct lxc_conf *conf, struct lxc_storage *orig,
static
int
btrfs_do_destroy_subvol
(
const
char
*
path
)
static
int
btrfs_do_destroy_subvol
(
const
char
*
path
)
{
{
int
ret
,
fd
=
-
1
;
int
ret
,
fd
=
-
1
;
size_t
retlen
;
struct
btrfs_ioctl_vol_args
args
;
struct
btrfs_ioctl_vol_args
args
;
char
*
p
,
*
newfull
=
strdup
(
path
);
char
*
p
,
*
newfull
=
strdup
(
path
);
...
@@ -522,8 +530,12 @@ static int btrfs_do_destroy_subvol(const char *path)
...
@@ -522,8 +530,12 @@ static int btrfs_do_destroy_subvol(const char *path)
}
}
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
strncpy
(
args
.
name
,
p
+
1
,
BTRFS_SUBVOL_NAME_MAX
);
retlen
=
strlcpy
(
args
.
name
,
p
+
1
,
BTRFS_SUBVOL_NAME_MAX
);
args
.
name
[
BTRFS_SUBVOL_NAME_MAX
-
1
]
=
0
;
if
(
retlen
>=
BTRFS_SUBVOL_NAME_MAX
)
{
free
(
newfull
);
return
-
E2BIG
;
}
ret
=
ioctl
(
fd
,
BTRFS_IOC_SNAP_DESTROY
,
&
args
);
ret
=
ioctl
(
fd
,
BTRFS_IOC_SNAP_DESTROY
,
&
args
);
INFO
(
"btrfs: snapshot destroy ioctl returned %d for %s"
,
ret
,
path
);
INFO
(
"btrfs: snapshot destroy ioctl returned %d for %s"
,
ret
,
path
);
if
(
ret
<
0
&&
errno
==
EPERM
)
if
(
ret
<
0
&&
errno
==
EPERM
)
...
@@ -577,21 +589,25 @@ static bool update_tree_node(struct mytree_node *n, u64 id, u64 parent,
...
@@ -577,21 +589,25 @@ static bool update_tree_node(struct mytree_node *n, u64 id, u64 parent,
{
{
if
(
id
)
if
(
id
)
n
->
objid
=
id
;
n
->
objid
=
id
;
if
(
parent
)
if
(
parent
)
n
->
parentid
=
parent
;
n
->
parentid
=
parent
;
if
(
name
)
{
if
(
name
)
{
n
->
name
=
malloc
(
name_len
+
1
);
n
->
name
=
malloc
(
name_len
+
1
);
if
(
!
n
->
name
)
if
(
!
n
->
name
)
return
false
;
return
false
;
strncpy
(
n
->
name
,
name
,
name_len
);
n
->
name
[
name_len
]
=
'\0'
;
strcpy
(
n
->
name
,
name
)
;
}
}
if
(
dirname
)
{
if
(
dirname
)
{
n
->
dirname
=
malloc
(
strlen
(
dirname
)
+
1
);
n
->
dirname
=
malloc
(
strlen
(
dirname
)
+
1
);
if
(
!
n
->
dirname
)
{
if
(
!
n
->
dirname
)
{
free
(
n
->
name
);
free
(
n
->
name
);
return
false
;
return
false
;
}
}
strcpy
(
n
->
dirname
,
dirname
);
strcpy
(
n
->
dirname
,
dirname
);
}
}
return
true
;
return
true
;
...
...
src/lxc/storage/storage_utils.c
View file @
9de31d5a
...
@@ -46,6 +46,10 @@
...
@@ -46,6 +46,10 @@
#include "storage_utils.h"
#include "storage_utils.h"
#include "utils.h"
#include "utils.h"
#ifndef HAVE_STRLCPY
#include "include/strlcpy.h"
#endif
#ifndef BLKGETSIZE64
#ifndef BLKGETSIZE64
#define BLKGETSIZE64 _IOR(0x12, 114, size_t)
#define BLKGETSIZE64 _IOR(0x12, 114, size_t)
#endif
#endif
...
@@ -85,8 +89,13 @@ char *dir_new_path(char *src, const char *oldname, const char *name,
...
@@ -85,8 +89,13 @@ char *dir_new_path(char *src, const char *oldname, const char *name,
}
}
while
((
p2
=
strstr
(
src
,
oldname
))
!=
NULL
)
{
while
((
p2
=
strstr
(
src
,
oldname
))
!=
NULL
)
{
size_t
retlen
;
/* copy text up to oldname */
/* copy text up to oldname */
strncpy
(
p
,
src
,
p2
-
src
);
retlen
=
strlcpy
(
p
,
src
,
p2
-
src
);
if
(
retlen
>=
p2
-
src
)
return
NULL
;
/* move target pointer (p) */
/* move target pointer (p) */
p
+=
p2
-
src
;
p
+=
p2
-
src
;
/* print new name in place of oldname */
/* print new name in place of oldname */
...
@@ -94,6 +103,7 @@ char *dir_new_path(char *src, const char *oldname, const char *name,
...
@@ -94,6 +103,7 @@ char *dir_new_path(char *src, const char *oldname, const char *name,
/* move src to end of oldname */
/* move src to end of oldname */
src
=
p2
+
l2
;
src
=
p2
+
l2
;
}
}
/* copy the rest of src */
/* copy the rest of src */
sprintf
(
p
,
"%s"
,
src
);
sprintf
(
p
,
"%s"
,
src
);
return
ret
;
return
ret
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment