mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-20 21:04:40 +08:00
[PATCH] uml: prevent umid theft
Behavior when booting two UMLs with the same umid was broken. The second one would steal the umid. This fixes that, making the second UML take a random umid instead. Signed-off-by: Jeff Dike <jdike@addtoit.com> Cc: Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
98c18238f1
commit
1fbbd6844e
@ -143,8 +143,10 @@ static int not_dead_yet(char *dir)
|
|||||||
goto out_close;
|
goto out_close;
|
||||||
}
|
}
|
||||||
|
|
||||||
if((kill(p, 0) == 0) || (errno != ESRCH))
|
if((kill(p, 0) == 0) || (errno != ESRCH)){
|
||||||
|
printk("umid \"%s\" is already in use by pid %d\n", umid, p);
|
||||||
return 1;
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
err = actually_do_remove(dir);
|
err = actually_do_remove(dir);
|
||||||
if(err)
|
if(err)
|
||||||
@ -234,33 +236,44 @@ int __init make_umid(void)
|
|||||||
err = mkdir(tmp, 0777);
|
err = mkdir(tmp, 0777);
|
||||||
if(err < 0){
|
if(err < 0){
|
||||||
err = -errno;
|
err = -errno;
|
||||||
if(errno != EEXIST)
|
if(err != -EEXIST)
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
if(not_dead_yet(tmp) < 0)
|
/* 1 -> this umid is already in use
|
||||||
|
* < 0 -> we couldn't remove the umid directory
|
||||||
|
* In either case, we can't use this umid, so return -EEXIST.
|
||||||
|
*/
|
||||||
|
if(not_dead_yet(tmp) != 0)
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
err = mkdir(tmp, 0777);
|
err = mkdir(tmp, 0777);
|
||||||
}
|
}
|
||||||
if(err < 0){
|
if(err){
|
||||||
printk("Failed to create '%s' - err = %d\n", umid, err);
|
err = -errno;
|
||||||
goto err_rmdir;
|
printk("Failed to create '%s' - err = %d\n", umid, -errno);
|
||||||
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
umid_setup = 1;
|
umid_setup = 1;
|
||||||
|
|
||||||
create_pid_file();
|
create_pid_file();
|
||||||
|
|
||||||
return 0;
|
err = 0;
|
||||||
|
|
||||||
err_rmdir:
|
|
||||||
rmdir(tmp);
|
|
||||||
err:
|
err:
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __init make_umid_init(void)
|
static int __init make_umid_init(void)
|
||||||
{
|
{
|
||||||
|
if(!make_umid())
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/* If initializing with the given umid failed, then try again with
|
||||||
|
* a random one.
|
||||||
|
*/
|
||||||
|
printk("Failed to initialize umid \"%s\", trying with a random umid\n",
|
||||||
|
umid);
|
||||||
|
*umid = '\0';
|
||||||
make_umid();
|
make_umid();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user