mirror of
https://git.FreeBSD.org/src.git
synced 2024-12-31 12:13:10 +00:00
geom: don't write stack garbage in disk labels
Most consumers of g_metadata_store were passing in partially unallocated memory, resulting in stack garbage being written to disk labels. Fix them by zeroing the memory first. gvirstor repeated the same mistake, but in the kernel. Also, glabel's label contained a fixed-size string that wasn't initialized to zero. PR: 222077 Reported by: Maxim Khitrov <max@mxcrypt.com> Reviewed by: cem MFC after: 3 weeks X-MFC-With: 323314 X-MFC-With: 323338 Differential Revision: https://reviews.freebsd.org/D14164
This commit is contained in:
parent
aa3c83c3c6
commit
f5b4099e6b
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=328849
1
sbin/geom/class/cache/geom_cache.c
vendored
1
sbin/geom/class/cache/geom_cache.c
vendored
@ -137,6 +137,7 @@ cache_label(struct gctl_req *req)
|
|||||||
int error, nargs;
|
int error, nargs;
|
||||||
intmax_t val;
|
intmax_t val;
|
||||||
|
|
||||||
|
bzero(sector, sizeof(sector));
|
||||||
nargs = gctl_get_int(req, "nargs");
|
nargs = gctl_get_int(req, "nargs");
|
||||||
if (nargs != 2) {
|
if (nargs != 2) {
|
||||||
gctl_error(req, "Invalid number of arguments.");
|
gctl_error(req, "Invalid number of arguments.");
|
||||||
|
@ -119,6 +119,7 @@ concat_label(struct gctl_req *req)
|
|||||||
const char *name;
|
const char *name;
|
||||||
int error, i, hardcode, nargs;
|
int error, i, hardcode, nargs;
|
||||||
|
|
||||||
|
bzero(sector, sizeof(sector));
|
||||||
nargs = gctl_get_int(req, "nargs");
|
nargs = gctl_get_int(req, "nargs");
|
||||||
if (nargs < 2) {
|
if (nargs < 2) {
|
||||||
gctl_error(req, "Too few arguments.");
|
gctl_error(req, "Too few arguments.");
|
||||||
|
@ -144,6 +144,7 @@ journal_label(struct gctl_req *req)
|
|||||||
intmax_t jsize, msize, ssize;
|
intmax_t jsize, msize, ssize;
|
||||||
int error, force, i, nargs, checksum, hardcode;
|
int error, force, i, nargs, checksum, hardcode;
|
||||||
|
|
||||||
|
bzero(sector, sizeof(sector));
|
||||||
nargs = gctl_get_int(req, "nargs");
|
nargs = gctl_get_int(req, "nargs");
|
||||||
str = NULL; /* gcc */
|
str = NULL; /* gcc */
|
||||||
|
|
||||||
|
@ -125,6 +125,7 @@ label_label(struct gctl_req *req)
|
|||||||
u_char sector[512];
|
u_char sector[512];
|
||||||
int error, nargs;
|
int error, nargs;
|
||||||
|
|
||||||
|
bzero(sector, sizeof(sector));
|
||||||
nargs = gctl_get_int(req, "nargs");
|
nargs = gctl_get_int(req, "nargs");
|
||||||
if (nargs != 2) {
|
if (nargs != 2) {
|
||||||
gctl_error(req, "Invalid number of arguments.");
|
gctl_error(req, "Invalid number of arguments.");
|
||||||
@ -145,6 +146,7 @@ label_label(struct gctl_req *req)
|
|||||||
strlcpy(md.md_magic, G_LABEL_MAGIC, sizeof(md.md_magic));
|
strlcpy(md.md_magic, G_LABEL_MAGIC, sizeof(md.md_magic));
|
||||||
md.md_version = G_LABEL_VERSION;
|
md.md_version = G_LABEL_VERSION;
|
||||||
label = gctl_get_ascii(req, "arg0");
|
label = gctl_get_ascii(req, "arg0");
|
||||||
|
bzero(md.md_label, sizeof(md.md_label));
|
||||||
strlcpy(md.md_label, label, sizeof(md.md_label));
|
strlcpy(md.md_label, label, sizeof(md.md_label));
|
||||||
md.md_provsize = g_get_mediasize(name);
|
md.md_provsize = g_get_mediasize(name);
|
||||||
if (md.md_provsize == 0) {
|
if (md.md_provsize == 0) {
|
||||||
|
@ -188,6 +188,7 @@ mirror_label(struct gctl_req *req)
|
|||||||
intmax_t val;
|
intmax_t val;
|
||||||
int error, i, nargs, bal, hardcode;
|
int error, i, nargs, bal, hardcode;
|
||||||
|
|
||||||
|
bzero(sector, sizeof(sector));
|
||||||
nargs = gctl_get_int(req, "nargs");
|
nargs = gctl_get_int(req, "nargs");
|
||||||
if (nargs < 2) {
|
if (nargs < 2) {
|
||||||
gctl_error(req, "Too few arguments.");
|
gctl_error(req, "Too few arguments.");
|
||||||
|
@ -151,6 +151,7 @@ raid3_label(struct gctl_req *req)
|
|||||||
int hardcode, round_robin, verify;
|
int hardcode, round_robin, verify;
|
||||||
int error, i, nargs;
|
int error, i, nargs;
|
||||||
|
|
||||||
|
bzero(sector, sizeof(sector));
|
||||||
nargs = gctl_get_int(req, "nargs");
|
nargs = gctl_get_int(req, "nargs");
|
||||||
if (nargs < 4) {
|
if (nargs < 4) {
|
||||||
gctl_error(req, "Too few arguments.");
|
gctl_error(req, "Too few arguments.");
|
||||||
|
@ -112,6 +112,7 @@ shsec_label(struct gctl_req *req)
|
|||||||
const char *name;
|
const char *name;
|
||||||
int error, i, nargs, hardcode;
|
int error, i, nargs, hardcode;
|
||||||
|
|
||||||
|
bzero(sector, sizeof(sector));
|
||||||
nargs = gctl_get_int(req, "nargs");
|
nargs = gctl_get_int(req, "nargs");
|
||||||
if (nargs <= 2) {
|
if (nargs <= 2) {
|
||||||
gctl_error(req, "Too few arguments.");
|
gctl_error(req, "Too few arguments.");
|
||||||
|
@ -130,6 +130,7 @@ stripe_label(struct gctl_req *req)
|
|||||||
const char *name;
|
const char *name;
|
||||||
int error, i, nargs, hardcode;
|
int error, i, nargs, hardcode;
|
||||||
|
|
||||||
|
bzero(sector, sizeof(sector));
|
||||||
nargs = gctl_get_int(req, "nargs");
|
nargs = gctl_get_int(req, "nargs");
|
||||||
if (nargs < 3) {
|
if (nargs < 3) {
|
||||||
gctl_error(req, "Too few arguments.");
|
gctl_error(req, "Too few arguments.");
|
||||||
|
@ -273,6 +273,13 @@ g_metadata_read(const char *name, unsigned char *md, size_t size,
|
|||||||
return (error);
|
return (error);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Actually write the GEOM label to the provider
|
||||||
|
*
|
||||||
|
* @param name GEOM provider's name (ie "ada0")
|
||||||
|
* @param md Pointer to the label data to write
|
||||||
|
* @param size Size of the data pointed to by md
|
||||||
|
*/
|
||||||
int
|
int
|
||||||
g_metadata_store(const char *name, const unsigned char *md, size_t size)
|
g_metadata_store(const char *name, const unsigned char *md, size_t size)
|
||||||
{
|
{
|
||||||
|
@ -1042,6 +1042,7 @@ write_metadata(struct g_consumer *cp, struct g_virstor_metadata *md)
|
|||||||
pp = cp->provider;
|
pp = cp->provider;
|
||||||
|
|
||||||
buf = malloc(pp->sectorsize, M_GVIRSTOR, M_WAITOK);
|
buf = malloc(pp->sectorsize, M_GVIRSTOR, M_WAITOK);
|
||||||
|
bzero(buf, pp->sectorsize);
|
||||||
virstor_metadata_encode(md, buf);
|
virstor_metadata_encode(md, buf);
|
||||||
g_topology_unlock();
|
g_topology_unlock();
|
||||||
error = g_write_data(cp, pp->mediasize - pp->sectorsize, buf,
|
error = g_write_data(cp, pp->mediasize - pp->sectorsize, buf,
|
||||||
|
Loading…
Reference in New Issue
Block a user