| Home » Mailing lists » Devel » [PATCH 3/7] uts namespaces: use init_utsname when appropriate Goto Forum:
	| 
		
			| [PATCH 3/7] uts namespaces: use init_utsname when appropriate [message #2505] | Sat, 08 April 2006 04:52  |  
			| 
				
				
					|  serue Messages: 750
 Registered: February 2006
 | Senior Member |  |  |  
	| In some places, particularly drivers and __init code, the init utsns is the appropriate one to use.  This patch replaces those with a the init_utsname
 helper.
 
 Signed-off-by: Serge E. Hallyn <serue@us.ibm.com>
 
 ---
 
 arch/arm/kernel/setup.c                   |    2 +-
 arch/arm26/kernel/setup.c                 |    2 +-
 arch/cris/kernel/setup.c                  |    2 +-
 arch/i386/kernel/process.c                |    6 +++---
 arch/i386/kernel/traps.c                  |    6 +++---
 arch/powerpc/kernel/process.c             |    2 +-
 arch/powerpc/kernel/setup_64.c            |    2 +-
 arch/powerpc/platforms/pseries/setup.c    |    2 +-
 arch/sh/kernel/setup.c                    |    2 +-
 arch/um/kernel/um_arch.c                  |    6 +++---
 arch/um/sys-x86_64/sysrq.c                |    2 +-
 arch/x86_64/kernel/process.c              |    6 +++---
 drivers/infiniband/hw/ipath/ipath_verbs.c |    2 +-
 drivers/parisc/led.c                      |    2 +-
 drivers/scsi/lpfc/lpfc_ct.c               |    8 ++++----
 drivers/usb/core/hcd.c                    |    4 ++--
 drivers/usb/gadget/ether.c                |    2 +-
 drivers/usb/gadget/file_storage.c         |    2 +-
 drivers/usb/gadget/serial.c               |    2 +-
 drivers/usb/gadget/zero.c                 |    2 +-
 include/asm-i386/bugs.h                   |    2 +-
 include/asm-i386/elf.h                    |    2 +-
 include/asm-sh/bugs.h                     |    2 +-
 kernel/power/snapshot.c                   |   10 +++++-----
 net/ipv4/ipconfig.c                       |   16 ++++++++--------
 net/sunrpc/clnt.c                         |    4 ++--
 sound/core/info_oss.c                     |   10 +++++-----
 27 files changed, 55 insertions(+), 55 deletions(-)
 
 65af7f7767c4447ccb3fafa6580844f4a65bcfdc
 diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c
 index 4375284..a4dc8de 100644
 --- a/arch/arm/kernel/setup.c
 +++ b/arch/arm/kernel/setup.c
 @@ -319,7 +319,7 @@ static void __init setup_processor(void)
 cpu_name, processor_id, (int)processor_id & 15,
 proc_arch[cpu_architecture()]);
 
 -	sprintf(system_utsname.machine, "%s%c", list->arch_name, ENDIANNESS);
 +	sprintf(init_utsname()->machine, "%s%c", list->arch_name, ENDIANNESS);
 sprintf(elf_platform, "%s%c", list->elf_name, ENDIANNESS);
 elf_hwcap = list->elf_hwcap;
 
 diff --git a/arch/arm26/kernel/setup.c b/arch/arm26/kernel/setup.c
 index 4eb329e..8e6a441 100644
 --- a/arch/arm26/kernel/setup.c
 +++ b/arch/arm26/kernel/setup.c
 @@ -144,7 +144,7 @@ static void __init setup_processor(void)
 
 dump_cpu_info();
 
 -	sprintf(system_utsname.machine, "%s", list->arch_name);
 +	sprintf(init_utsname()->machine, "%s", list->arch_name);
 sprintf(elf_platform, "%s", list->elf_name);
 elf_hwcap = list->elf_hwcap;
 
 diff --git a/arch/cris/kernel/setup.c b/arch/cris/kernel/setup.c
 index 619a6ee..1974c01 100644
 --- a/arch/cris/kernel/setup.c
 +++ b/arch/cris/kernel/setup.c
 @@ -161,7 +161,7 @@ setup_arch(char **cmdline_p)
 show_etrax_copyright();
 
 /* Setup utsname */
 -	strcpy(system_utsname.machine, cris_machine_name);
 +	strcpy(init_utsname()->machine, cris_machine_name);
 }
 
 static void *c_start(struct seq_file *m, loff_t *pos)
 diff --git a/arch/i386/kernel/process.c b/arch/i386/kernel/process.c
 index 6259afe..da2e439 100644
 --- a/arch/i386/kernel/process.c
 +++ b/arch/i386/kernel/process.c
 @@ -297,9 +297,9 @@ void show_regs(struct pt_regs * regs)
 if (user_mode_vm(regs))
 printk(" ESP: %04x:%08lx",0xffff & regs->xss,regs->esp);
 printk(" EFLAGS: %08lx    %s  (%s %.*s)\n",
 -	       regs->eflags, print_tainted(), system_utsname.release,
 -	       (int)strcspn(system_utsname.version, " "),
 -	       system_utsname.version);
 +	       regs->eflags, print_tainted(), init_utsname()->release,
 +	       (int)strcspn(init_utsname()->version, " "),
 +	       init_utsname()->version);
 printk("EAX: %08lx EBX: %08lx ECX: %08lx EDX: %08lx\n",
 regs->eax,regs->ebx,regs->ecx,regs->edx);
 printk("ESI: %08lx EDI: %08lx EBP: %08lx",
 diff --git a/arch/i386/kernel/traps.c b/arch/i386/kernel/traps.c
 index e385279..dd62423 100644
 --- a/arch/i386/kernel/traps.c
 +++ b/arch/i386/kernel/traps.c
 @@ -260,9 +260,9 @@ void show_registers(struct pt_regs *regs
 printk(KERN_EMERG "CPU:    %d\nEIP:    %04x:[<%08lx>]    %s VLI\n"
 "EFLAGS: %08lx   (%s %.*s) \n",
 smp_processor_id(), 0xffff & regs->xcs, regs->eip,
 -		print_tainted(), regs->eflags, system_utsname.release,
 -		(int)strcspn(system_utsname.version, " "),
 -		system_utsname.version);
 +		print_tainted(), regs->eflags, init_utsname()->release,
 +		(int)strcspn(init_utsname()->version, " "),
 +		init_utsname()->version);
 print_symbol(KERN_EMERG "EIP is at %s\n", regs->eip);
 printk(KERN_EMERG "eax: %08lx   ebx: %08lx   ecx: %08lx   edx: %08lx\n",
 regs->eax, regs->ebx, regs->ecx, regs->edx);
 diff --git a/arch/powerpc/kernel/process.c b/arch/powerpc/kernel/process.c
 index 2dd47d2..6ce9e10 100644
 --- a/arch/powerpc/kernel/process.c
 +++ b/arch/powerpc/kernel/process.c
 @@ -425,7 +425,7 @@ void show_regs(struct pt_regs * regs)
 printk("NIP: "REG" LR: "REG" CTR: "REG"\n",
 regs->nip, regs->link, regs->ctr);
 printk("REGS: %p TRAP: %04lx   %s  (%s)\n",
 -	       regs, regs->trap, print_tainted(), system_utsname.release);
 +	       regs, regs->trap, print_tainted(), init_utsname()->release);
 printk("MSR: "REG" ", regs->msr);
 printbits(regs->msr, msr_bits);
 printk("  CR: %08lX  XER: %08lX\n", regs->ccr, regs->xer);
 diff --git a/arch/powerpc/kernel/setup_64.c b/arch/powerpc/kernel/setup_64.c
 index 13e91c4..1c6619f 100644
 --- a/arch/powerpc/kernel/setup_64.c
 +++ b/arch/powerpc/kernel/setup_64.c
 @@ -435,7 +435,7 @@ void __init setup_system(void)
 smp_release_cpus();
 #endif
 
 -	printk("Starting Linux PPC64 %s\n", system_utsname.version);
 +	printk("Starting Linux PPC64 %s\n", init_utsname()->version);
 
 printk("-----------------------------------------------------\n ");
 printk("ppc64_pft_size                = 0x%lx\n", ppc64_pft_size);
 diff --git a/arch/powerpc/platforms/pseries/setup.c b/arch/powerpc/platforms/pseries/setup.c
 index 5eb55ef..58b7a74 100644
 --- a/arch/powerpc/platforms/pseries/setup.c
 +++ b/arch/powerpc/platforms/pseries/setup.c
 @@ -255,7 +255,7 @@ static int __init pSeries_init_panel(voi
 {
 /* Manually leave the kernel version on the panel. */
 ppc_md.progress("Linux ppc64\n", 0);
 -	ppc_md.progress(system_utsname.version, 0);
 +	ppc_md.progress(init_utsname()->version, 0);
 
 return 0;
 }
 diff --git a/arch/sh/kernel/setup.c b/arch/sh/kernel/setup.c
 index bb229ef..024401e 100644
 --- a/arch/sh/kernel/setup.c
 +++ b/arch/sh/kernel/setup.c
 @@ -481,7 +481,7 @@ static int show_cpuinfo(struct seq_file
 seq_printf(m, "machine\t\t: %s\n", get_system_type());
 
 seq_printf(m, "processor\t: %d\n", cpu);
 -	seq_printf(m, "cpu family\t: %s\n", system_utsname.machine);
 +	seq_printf(m, "cpu family\t: %s\n", init_utsname()->machine);
 seq_printf(m, "cpu type\t: %s\n", get_cpu_subtype());
 
 show_cpuflags(m);
 diff --git a/arch/um/kernel/um_arch.c b/arch/um/kernel/um_arch.c
 index 7d51dd7..b49dd7d 100644
 --- a/arch/um/kernel/um_arch.c
 +++ b/arch/um/kernel/um_arch.c
 @@ -167,7 +167,7 @@ static char *usage_string =
 
 static int __init uml_version_setup(char *line, int *add)
 {
 -	printf("%s\n", system_utsname.release);
 +	printf("%s\n", init_utsname()->release);
 exit(0);
 
 return 0;
 @@ -278,7 +278,7 @@ static int __init Usage(char *line, int
 {
 const char **p;
 
 -	printf(usage_string, system_utsname.release);
 +	printf(usage_string, init_utsname()->release);
 p = &__uml_help_start;
 while (p < &__uml_help_end) {
 printf("%s", *p);
 @@ -400,7 +400,7 @@ int linux_main(int argc, char **argv)
 /* Reserve up to 4M after the current brk */
 uml_reserved = ROUND_4M(brk_start) + (1 << 22);
 
 -	setup_machinename(system_utsname.machine);
 +	setup_machinename(init_utsname()->machine);
 
 #ifdef CONFIG_CMDLINE_ON_HOST
 argv1_begin = argv[1];
 diff --git a/arch/um/sys-x86_64/sysrq.c b/arch/um/sys-x86_64/sysrq.c
 index d0a25af..ce3e07f 100644
 --- a/arch/um/sys-x86_64/sysrq.c
 +++ b/arch/um/sys-x86_64/sysrq.c
 @@ -16,7 +16,7 @@ void __show_regs(struct pt_regs * regs)
 printk("\n");
 print_modules();
 printk("Pid: %d, comm: %.20s %s %s\n",
 -	       current->pid, current->comm, print_tainted(), system_utsname.release);
 +	       current->pid, current->comm, print_tainted(), init_utsname()->release);
 printk("RIP: %04lx:[<%016lx>] ", PT_REGS_CS(regs) & 0xffff,
 PT_REGS_RIP(regs));
 printk("\nRSP: %016lx  EFLAGS: %08lx\n", PT_REGS_RSP(regs),
 diff --git a/arch/x86_64/kernel/process.c b/arch/x86_64/kernel/process.c
 index 70dd8e5..79f8174 100644
 --- a/arch/x86_64/kernel/process.c
 +++ b/arch/x86_64/kernel/process.c
 @@ -292,9 +292,9 @@ void __show_regs(struct pt_regs * regs)
 print_modules();
 printk("Pid: %d, comm: %.20s %s %s %.*s\n",
 current->pid, current->comm, print_tainted(),
 -		system_utsname.release,
 -		(int)strcspn(system_utsname.version, " "),
 -		system_utsname.version);
 +		init_utsname()->release,
 +		(int)strcspn(init_utsname()->version, " "),
 +		init_utsname()->version);
 printk("RIP: %04lx:[<%016lx>] ", regs->cs & 0xffff, regs->rip);
 printk_address(regs->rip);
 printk("\nRSP: %04lx:%016lx  EFLAGS: %08l
...
 
 
 |  
	|  |  |  
	| 
		
			| Re: [PATCH 3/7] uts namespaces: use init_utsname when appropriate [message #2513 is a reply to message #2505] | Sat, 08 April 2006 07:09   |  
			| 
				
				
					|  ebiederm Messages: 1354
 Registered: February 2006
 | Senior Member |  |  |  
	| "Serge E. Hallyn" <serue@us.ibm.com> writes: 
 > diff --git a/include/asm-i386/elf.h b/include/asm-i386/elf.h
 > index 4153d80..8d455e2 100644
 > --- a/include/asm-i386/elf.h
 > +++ b/include/asm-i386/elf.h
 > @@ -108,7 +108,7 @@ typedef struct user_fxsr_struct elf_fpxr
 >     For the moment, we have only optimizations for the Intel generations,
 >     but that could change... */
 >
 > -#define ELF_PLATFORM  (system_utsname.machine)
 > +#define ELF_PLATFORM  (init_utsname()->machine)
 >
 >  #ifdef __KERNEL__
 >  #define SET_PERSONALITY(ex, ibcs2) do { } while (0)
 
 I think this one needs to be utsname()->machine.
 
 Currently it doesn't matter.  But Herbert has expressed
 the desire to make a machine appear like an older one.
 
 
 
 > diff --git a/net/ipv4/ipconfig.c b/net/ipv4/ipconfig.c
 > index cb8a92f..81db372 100644
 > --- a/net/ipv4/ipconfig.c
 > +++ b/net/ipv4/ipconfig.c
 > @@ -367,7 +367,7 @@ static int __init ic_defaults(void)
 >  	 */
 >
 >  	if (!ic_host_name_set)
 > - sprintf(system_utsname.nodename, "%u.%u.%u.%u", NIPQUAD(ic_myaddr));
 > + sprintf(init_utsname()->nodename, "%u.%u.%u.%u", NIPQUAD(ic_myaddr));
 >
 >  	if (root_server_addr == INADDR_NONE)
 >  		root_server_addr = ic_servaddr;
 > @@ -806,7 +806,7 @@ static void __init ic_do_bootp_ext(u8 *e
 >  			}
 >  			break;
 >  		case 12:	/* Host name */
 > - ic_bootp_string(system_utsname.nodename, ext+1, *ext, __NEW_UTS_LEN);
 > + ic_bootp_string(init_utsname()->nodename, ext+1, *ext, __NEW_UTS_LEN);
 >  			ic_host_name_set = 1;
 >  			break;
 >  		case 15:	/* Domain name (DNS) */
 > @@ -817,7 +817,7 @@ static void __init ic_do_bootp_ext(u8 *e
 >  				ic_bootp_string(root_server_path, ext+1, *ext,
 > sizeof(root_server_path));
 >  			break;
 >  		case 40:	/* NIS Domain name (_not_ DNS) */
 > - ic_bootp_string(system_utsname.domainname, ext+1, *ext, __NEW_UTS_LEN);
 > + ic_bootp_string(init_utsname()->domainname, ext+1, *ext, __NEW_UTS_LEN);
 >  			break;
 >  	}
 >  }
 > @@ -1369,7 +1369,7 @@ static int __init ip_auto_config(void)
 >  	printk(", mask=%u.%u.%u.%u", NIPQUAD(ic_netmask));
 >  	printk(", gw=%u.%u.%u.%u", NIPQUAD(ic_gateway));
 >  	printk(",\n     host=%s, domain=%s, nis-domain=%s",
 > -	       system_utsname.nodename, ic_domain, system_utsname.domainname);
 > + init_utsname()->nodename, ic_domain, init_utsname()->domainname);
 >  	printk(",\n     bootserver=%u.%u.%u.%u", NIPQUAD(ic_servaddr));
 >  	printk(", rootserver=%u.%u.%u.%u", NIPQUAD(root_server_addr));
 >  	printk(", rootpath=%s", root_server_path);
 > @@ -1479,11 +1479,11 @@ static int __init ip_auto_config_setup(c
 >  			case 4:
 >  				if ((dp = strchr(ip, '.'))) {
 >  					*dp++ = '\0';
 > -					strlcpy(system_utsname.domainname, dp,
 > - sizeof(system_utsname.domainname));
 > +					strlcpy(init_utsname()->domainname, dp,
 > + sizeof(init_utsname()->domainname));
 >  				}
 > -				strlcpy(system_utsname.nodename, ip,
 > -					sizeof(system_utsname.nodename));
 > +				strlcpy(init_utsname()->nodename, ip,
 > +					sizeof(init_utsname()->nodename));
 >  				ic_host_name_set = 1;
 >  				break;
 >  			case 5:
 
 This also probably makes sense as utsname().  It doesn't
 really matter as this is before init is executed. But logically
 this is a user space or per namespace action.
 
 > diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
 > index aa8965e..97c8439 100644
 > --- a/net/sunrpc/clnt.c
 > +++ b/net/sunrpc/clnt.c
 > @@ -176,10 +176,10 @@ rpc_new_client(struct rpc_xprt *xprt, ch
 >  	}
 >
 >  	/* save the nodename */
 > -	clnt->cl_nodelen = strlen(system_utsname.nodename);
 > +	clnt->cl_nodelen = strlen(init_utsname()->nodename);
 >  	if (clnt->cl_nodelen > UNX_MAXNODENAME)
 >  		clnt->cl_nodelen = UNX_MAXNODENAME;
 > -	memcpy(clnt->cl_nodename, system_utsname.nodename, clnt->cl_nodelen);
 > +	memcpy(clnt->cl_nodename, init_utsname()->nodename, clnt->cl_nodelen);
 >  	return clnt;
 >
 >  out_no_auth:
 
 Using nodename is practically the definition of something
 that should per namespace I think.  Plus it would be really inconsistent
 to use utsname() and the init_utsname for the nfs rpc calls.
 
 Unless I am missing something.
 
 Eric
 |  
	|  |  |  
	| 
		
			| Re: [PATCH 3/7] uts namespaces: use init_utsname when appropriate [message #2527 is a reply to message #2513] | Sat, 08 April 2006 20:27   |  
			| 
				
				
					|  serue Messages: 750
 Registered: February 2006
 | Senior Member |  |  |  
	| Quoting Eric W. Biederman (ebiederm@xmission.com): > "Serge E. Hallyn" <serue@us.ibm.com> writes:
 >
 > > diff --git a/include/asm-i386/elf.h b/include/asm-i386/elf.h
 > > index 4153d80..8d455e2 100644
 > > --- a/include/asm-i386/elf.h
 > > +++ b/include/asm-i386/elf.h
 > > @@ -108,7 +108,7 @@ typedef struct user_fxsr_struct elf_fpxr
 > >     For the moment, we have only optimizations for the Intel generations,
 > >     but that could change... */
 > >
 > > -#define ELF_PLATFORM  (system_utsname.machine)
 > > +#define ELF_PLATFORM  (init_utsname()->machine)
 > >
 > >  #ifdef __KERNEL__
 > >  #define SET_PERSONALITY(ex, ibcs2) do { } while (0)
 >
 > I think this one needs to be utsname()->machine.
 >
 > Currently it doesn't matter.  But Herbert has expressed
 > the desire to make a machine appear like an older one.
 
 Ok.
 
 > > diff --git a/net/ipv4/ipconfig.c b/net/ipv4/ipconfig.c
 > > index cb8a92f..81db372 100644
 ...
 > > @@ -1479,11 +1479,11 @@ static int __init ip_auto_config_setup(c
 > >  			case 4:
 > >  				if ((dp = strchr(ip, '.'))) {
 > >  					*dp++ = '\0';
 > > -					strlcpy(system_utsname.domainname, dp,
 > > - sizeof(system_utsname.domainname));
 > > +					strlcpy(init_utsname()->domainname, dp,
 > > + sizeof(init_utsname()->domainname));
 > >  				}
 > > -				strlcpy(system_utsname.nodename, ip,
 > > -					sizeof(system_utsname.nodename));
 > > +				strlcpy(init_utsname()->nodename, ip,
 > > +					sizeof(init_utsname()->nodename));
 > >  				ic_host_name_set = 1;
 > >  				break;
 > >  			case 5:
 >
 > This also probably makes sense as utsname().  It doesn't
 > really matter as this is before init is executed. But logically
 > this is a user space or per namespace action.
 
 Right, I was kind of favoring using init_utsname() for anything
 __init.  But utsname() will of course work just as well there.
 
 > > diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
 > > index aa8965e..97c8439 100644
 > > --- a/net/sunrpc/clnt.c
 > > +++ b/net/sunrpc/clnt.c
 > > @@ -176,10 +176,10 @@ rpc_new_client(struct rpc_xprt *xprt, ch
 > >  	}
 > >
 > >  	/* save the nodename */
 > > -	clnt->cl_nodelen = strlen(system_utsname.nodename);
 > > +	clnt->cl_nodelen = strlen(init_utsname()->nodename);
 > >  	if (clnt->cl_nodelen > UNX_MAXNODENAME)
 > >  		clnt->cl_nodelen = UNX_MAXNODENAME;
 > > -	memcpy(clnt->cl_nodename, system_utsname.nodename, clnt->cl_nodelen);
 > > +	memcpy(clnt->cl_nodename, init_utsname()->nodename, clnt->cl_nodelen);
 > >  	return clnt;
 > >
 > >  out_no_auth:
 >
 > Using nodename is practically the definition of something
 > that should per namespace I think.  Plus it would be really inconsistent
 > to use utsname() and the init_utsname for the nfs rpc calls.
 >
 > Unless I am missing something.
 
 It seemed like this would be happening in any old context, so that
 current->uts_ns could be any process'.  Tracing it back further,
 it seems like nfs+lockd should have the context available.  So I'll
 switch this as well.
 
 thanks,
 -serge
 |  
	|  |  |  
	|  |  
	| 
		
			| Re:  Re: [PATCH 3/7] uts namespaces: use init_utsname when appropriate [message #2529 is a reply to message #2528] | Sun, 09 April 2006 00:12   |  
			|  |  
	| Sam Vilain wrote: 
 >On Sat, 2006-04-08 at 01:09 -0600, Eric W. Biederman wrote:
 >
 >
 >>>-#define ELF_PLATFORM  (system_utsname.machine)
 >>>+#define ELF_PLATFORM  (init_utsname()->machine)
 >>>
 >>> #ifdef __KERNEL__
 >>> #define SET_PERSONALITY(ex, ibcs2) do { } while (0)
 >>>
 >>>
 >>I think this one needs to be utsname()->machine.
 >>Currently it doesn't matter.  But Herbert has expressed
 >>the desire to make a machine appear like an older one.
 >>
 >>
 >
 >This is extremely useful for faking it as "i386" on x86_64 systems, for
 >instance.
 >
 >
 Could 'setarch' be of any help here? Works fine for us. Or am I missing
 something?
 |  
	|  |  |  
	|  |  
	| 
		
			| Re: [PATCH 3/7] uts namespaces: use init_utsname when appropriate [message #2540 is a reply to message #2527] | Sun, 09 April 2006 09:44   |  
			| 
				
				
					|  ebiederm Messages: 1354
 Registered: February 2006
 | Senior Member |  |  |  
	| "Serge E. Hallyn" <serue@us.ibm.com> writes: 
 >> This also probably makes sense as utsname().  It doesn't
 >> really matter as this is before init is executed. But logically
 >> this is a user space or per namespace action.
 >
 > Right, I was kind of favoring using init_utsname() for anything
 > __init.  But utsname() will of course work just as well there.
 
 Basically anything that should move to klibc I favor using
 utsname() for.  That tends to make it clear it follows
 the usual user space rules.
 
 With a little luck HPA might actually have this code deleted
 in -mm before we get to far.
 
 >> > diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
 >> > index aa8965e..97c8439 100644
 >> > --- a/net/sunrpc/clnt.c
 >> > +++ b/net/sunrpc/clnt.c
 >> > @@ -176,10 +176,10 @@ rpc_new_client(struct rpc_xprt *xprt, ch
 >> >  	}
 >> >
 >> >  	/* save the nodename */
 >> > -	clnt->cl_nodelen = strlen(system_utsname.nodename);
 >> > +	clnt->cl_nodelen = strlen(init_utsname()->nodename);
 >> >  	if (clnt->cl_nodelen > UNX_MAXNODENAME)
 >> >  		clnt->cl_nodelen = UNX_MAXNODENAME;
 >> > -	memcpy(clnt->cl_nodename, system_utsname.nodename, clnt->cl_nodelen);
 >> > +	memcpy(clnt->cl_nodename, init_utsname()->nodename, clnt->cl_nodelen);
 >> >  	return clnt;
 >> >
 >> >  out_no_auth:
 >>
 >> Using nodename is practically the definition of something
 >> that should per namespace I think.  Plus it would be really inconsistent
 >> to use utsname() and the init_utsname for the nfs rpc calls.
 >>
 >> Unless I am missing something.
 >
 > It seemed like this would be happening in any old context, so that
 > current->uts_ns could be any process'.  Tracing it back further,
 > it seems like nfs+lockd should have the context available.  So I'll
 > switch this as well.
 
 I have not traced that path recently.  So I don't remember.
 This is one of those odd cases that makes a real difference.
 
 This reminds me of another piece of the conversation.
 kernel_thread vs. kthread, and the oddities of daemonize.
 
 In general user space cannot kill kernel threads, so having
 a kernel thread inside a namespace is dangerous because it
 means the namespace can never exit.
 
 There are two ways to avoid the associated problems.
 - modify daemonize to always use the instance of that
 namespace associated with init_task.
 - modify all interesting kernel threads to use the
 kthread api instead of kernel_thread.  Using kthread
 makes the kernel threads children of keventd and always
 in the initial namespace instance.  As such we know
 we aren't inside of any user space namespace instance.
 
 Eric
 |  
	|  |  |  
	|  |  
	| 
		
			| Re: [PATCH 3/7] uts namespaces: use init_utsname when appropriate [message #2587 is a reply to message #2540] | Mon, 10 April 2006 20:39  |  
			| 
				
				
					|  serue Messages: 750
 Registered: February 2006
 | Senior Member |  |  |  
	| Quoting Eric W. Biederman (ebiederm@xmission.com): > "Serge E. Hallyn" <serue@us.ibm.com> writes:
 >
 > >> This also probably makes sense as utsname().  It doesn't
 > >> really matter as this is before init is executed. But logically
 > >> this is a user space or per namespace action.
 > >
 > > Right, I was kind of favoring using init_utsname() for anything
 > > __init.  But utsname() will of course work just as well there.
 >
 > Basically anything that should move to klibc I favor using
 > utsname() for.  That tends to make it clear it follows
 > the usual user space rules.
 >
 > With a little luck HPA might actually have this code deleted
 > in -mm before we get to far.
 
 Here is a new version of the init_utsname patch.  I'm sending a
 new version of the utsname() patch in reply to the original [2/7]
 patch.
 
 From: Serge Hallyn <serue@us.ibm.com>
 Subject: [PATCH 3/7] uts namespaces: use init_utsname when appropriate
 
 In some places, particularly drivers and __init code, the init utsns is the
 appropriate one to use.  This patch replaces those with a the init_utsname
 helper.
 
 Changes: Removed several uses of init_utsname().  Hope I picked all the
 right ones in net/ipv4/ipconfig.c.  These are now changed to
 utsname() (the per-process namespace utsname) in the previous
 patch (2/7)
 
 Signed-off-by: Serge E. Hallyn <serue@us.ibm.com>
 
 ---
 
 arch/arm/kernel/setup.c                   |    2 +-
 arch/arm26/kernel/setup.c                 |    2 +-
 arch/cris/kernel/setup.c                  |    2 +-
 arch/i386/kernel/process.c                |    6 +++---
 arch/i386/kernel/traps.c                  |    6 +++---
 arch/powerpc/kernel/process.c             |    2 +-
 arch/powerpc/kernel/setup_64.c            |    2 +-
 arch/powerpc/platforms/pseries/setup.c    |    2 +-
 arch/sh/kernel/setup.c                    |    2 +-
 arch/um/kernel/um_arch.c                  |    6 +++---
 arch/um/sys-x86_64/sysrq.c                |    2 +-
 arch/x86_64/kernel/process.c              |    6 +++---
 drivers/infiniband/hw/ipath/ipath_verbs.c |    2 +-
 drivers/parisc/led.c                      |    2 +-
 drivers/scsi/lpfc/lpfc_ct.c               |    8 ++++----
 drivers/usb/core/hcd.c                    |    4 ++--
 drivers/usb/gadget/ether.c                |    2 +-
 drivers/usb/gadget/file_storage.c         |    2 +-
 drivers/usb/gadget/serial.c               |    2 +-
 drivers/usb/gadget/zero.c                 |    2 +-
 include/asm-i386/bugs.h                   |    2 +-
 include/asm-sh/bugs.h                     |    2 +-
 kernel/power/snapshot.c                   |   10 +++++-----
 net/ipv4/ipconfig.c                       |    2 +-
 sound/core/info_oss.c                     |   10 +++++-----
 25 files changed, 45 insertions(+), 45 deletions(-)
 
 3941501899f74ae1fee21a074cdc2e420a4b3f27
 diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c
 index 4375284..a4dc8de 100644
 --- a/arch/arm/kernel/setup.c
 +++ b/arch/arm/kernel/setup.c
 @@ -319,7 +319,7 @@ static void __init setup_processor(void)
 cpu_name, processor_id, (int)processor_id & 15,
 proc_arch[cpu_architecture()]);
 
 -	sprintf(system_utsname.machine, "%s%c", list->arch_name, ENDIANNESS);
 +	sprintf(init_utsname()->machine, "%s%c", list->arch_name, ENDIANNESS);
 sprintf(elf_platform, "%s%c", list->elf_name, ENDIANNESS);
 elf_hwcap = list->elf_hwcap;
 
 diff --git a/arch/arm26/kernel/setup.c b/arch/arm26/kernel/setup.c
 index 4eb329e..8e6a441 100644
 --- a/arch/arm26/kernel/setup.c
 +++ b/arch/arm26/kernel/setup.c
 @@ -144,7 +144,7 @@ static void __init setup_processor(void)
 
 dump_cpu_info();
 
 -	sprintf(system_utsname.machine, "%s", list->arch_name);
 +	sprintf(init_utsname()->machine, "%s", list->arch_name);
 sprintf(elf_platform, "%s", list->elf_name);
 elf_hwcap = list->elf_hwcap;
 
 diff --git a/arch/cris/kernel/setup.c b/arch/cris/kernel/setup.c
 index 619a6ee..1974c01 100644
 --- a/arch/cris/kernel/setup.c
 +++ b/arch/cris/kernel/setup.c
 @@ -161,7 +161,7 @@ setup_arch(char **cmdline_p)
 show_etrax_copyright();
 
 /* Setup utsname */
 -	strcpy(system_utsname.machine, cris_machine_name);
 +	strcpy(init_utsname()->machine, cris_machine_name);
 }
 
 static void *c_start(struct seq_file *m, loff_t *pos)
 diff --git a/arch/i386/kernel/process.c b/arch/i386/kernel/process.c
 index 6259afe..da2e439 100644
 --- a/arch/i386/kernel/process.c
 +++ b/arch/i386/kernel/process.c
 @@ -297,9 +297,9 @@ void show_regs(struct pt_regs * regs)
 if (user_mode_vm(regs))
 printk(" ESP: %04x:%08lx",0xffff & regs->xss,regs->esp);
 printk(" EFLAGS: %08lx    %s  (%s %.*s)\n",
 -	       regs->eflags, print_tainted(), system_utsname.release,
 -	       (int)strcspn(system_utsname.version, " "),
 -	       system_utsname.version);
 +	       regs->eflags, print_tainted(), init_utsname()->release,
 +	       (int)strcspn(init_utsname()->version, " "),
 +	       init_utsname()->version);
 printk("EAX: %08lx EBX: %08lx ECX: %08lx EDX: %08lx\n",
 regs->eax,regs->ebx,regs->ecx,regs->edx);
 printk("ESI: %08lx EDI: %08lx EBP: %08lx",
 diff --git a/arch/i386/kernel/traps.c b/arch/i386/kernel/traps.c
 index e385279..dd62423 100644
 --- a/arch/i386/kernel/traps.c
 +++ b/arch/i386/kernel/traps.c
 @@ -260,9 +260,9 @@ void show_registers(struct pt_regs *regs
 printk(KERN_EMERG "CPU:    %d\nEIP:    %04x:[<%08lx>]    %s VLI\n"
 "EFLAGS: %08lx   (%s %.*s) \n",
 smp_processor_id(), 0xffff & regs->xcs, regs->eip,
 -		print_tainted(), regs->eflags, system_utsname.release,
 -		(int)strcspn(system_utsname.version, " "),
 -		system_utsname.version);
 +		print_tainted(), regs->eflags, init_utsname()->release,
 +		(int)strcspn(init_utsname()->version, " "),
 +		init_utsname()->version);
 print_symbol(KERN_EMERG "EIP is at %s\n", regs->eip);
 printk(KERN_EMERG "eax: %08lx   ebx: %08lx   ecx: %08lx   edx: %08lx\n",
 regs->eax, regs->ebx, regs->ecx, regs->edx);
 diff --git a/arch/powerpc/kernel/process.c b/arch/powerpc/kernel/process.c
 index 2dd47d2..6ce9e10 100644
 --- a/arch/powerpc/kernel/process.c
 +++ b/arch/powerpc/kernel/process.c
 @@ -425,7 +425,7 @@ void show_regs(struct pt_regs * regs)
 printk("NIP: "REG" LR: "REG" CTR: "REG"\n",
 regs->nip, regs->link, regs->ctr);
 printk("REGS: %p TRAP: %04lx   %s  (%s)\n",
 -	       regs, regs->trap, print_tainted(), system_utsname.release);
 +	       regs, regs->trap, print_tainted(), init_utsname()->release);
 printk("MSR: "REG" ", regs->msr);
 printbits(regs->msr, msr_bits);
 printk("  CR: %08lX  XER: %08lX\n", regs->ccr, regs->xer);
 diff --git a/arch/powerpc/kernel/setup_64.c b/arch/powerpc/kernel/setup_64.c
 index 13e91c4..1c6619f 100644
 --- a/arch/powerpc/kernel/setup_64.c
 +++ b/arch/powerpc/kernel/setup_64.c
 @@ -435,7 +435,7 @@ void __init setup_system(void)
 smp_release_cpus();
 #endif
 
 -	printk("Starting Linux PPC64 %s\n", system_utsname.version);
 +	printk("Starting Linux PPC64 %s\n", init_utsname()->version);
 
 printk("-----------------------------------------------------\n ");
 printk("ppc64_pft_size                = 0x%lx\n", ppc64_pft_size);
 diff --git a/arch/powerpc/platforms/pseries/setup.c b/arch/powerpc/platforms/pseries/setup.c
 index 5eb55ef..58b7a74 100644
 --- a/arch/powerpc/platforms/pseries/setup.c
 +++ b/arch/powerpc/platforms/pseries/setup.c
 @@ -255,7 +255,7 @@ static int __init pSeries_init_panel(voi
 {
 /* Manually leave the kernel version on the panel. */
 ppc_md.progress("Linux ppc64\n", 0);
 -	ppc_md.progress(system_utsname.version, 0);
 +	ppc_md.progress(init_utsname()->version, 0);
 
 return 0;
 }
 diff --git a/arch/sh/kernel/setup.c b/arch/sh/kernel/setup.c
 index bb229ef..024401e 100644
 --- a/arch/sh/kernel/setup.c
 +++ b/arch/sh/kernel/setup.c
 @@ -481,7 +481,7 @@ static int show_cpuinfo(struct seq_file
 seq_printf(m, "machine\t\t: %s\n", get_system_type());
 
 seq_printf(m, "processor\t: %d\n", cpu);
 -	seq_printf(m, "cpu family\t: %s\n", system_utsname.machine);
 +	seq_printf(m, "cpu family\t: %s\n", init_utsname()->machine);
 seq_printf(m, "cpu type\t: %s\n", get_cpu_subtype());
 
 show_cpuflags(m);
 diff --git a/arch/um/kernel/um_arch.c b/arch/um/kernel/um_arch.c
 index 7d51dd7..b49dd7d 100644
 --- a/arch/um/kernel/um_arch.c
 +++ b/arch/um/kernel/um_arch.c
 @@ -167,7 +167,7 @@ static char *usage_string =
 
 static int __init uml_version_setup(char *line, int *add)
 {
 -	printf("%s\n", system_utsname.release);
 +	printf("%s\n", init_utsname()->release);
 exit(0);
 
 return 0;
 @@ -278,7 +278,7 @@ static int __init Usage(char *line, int
 {
 const char **p;
 
 -	printf(usage_string, system_utsname.release);
 +	printf(usage_string, init_utsname()->release);
 p = &__uml_help_start;
 while (p < &__uml_help_end) {
 printf("%s", *p);
 @@ -400,7 +400,7 @@ int linux_main(int argc, char **argv)
 /* Reserve up to 4M after the current brk */
 uml_reserved = ROUND_4M(brk_start) + (1 << 22);
 
 -	setup_machinename(system_utsname.machine);
 +	setup_machinename(init_utsname()->machine);
 
 #ifdef CONFIG_CMDLINE_ON_HOST
 argv1_begin = argv[1];
 diff --git a/arch/um/sys-x86_64/sysrq.c b/arch/um/sys-x86_64/sysrq.c
 index d0a25af..ce3e07f 100644
 --- a/arch/um/sys-x86_64/sysrq.c
 +++ b/arch/um/sys-x86_64/sysrq.c
 @@ -16,7 +16,7 @@ void __show_regs(struct pt_regs * regs)
 printk("\n");
 print_modules();
 printk("Pid: %d, comm: %.20s %s %s\n",
 -	       curren
...
 
 
 |  
	|  |  | 
 
 
 Current Time: Sat Oct 25 19:31:33 GMT 2025 
 Total time taken to generate the page: 0.14566 seconds |