lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:	Wed, 15 Dec 2010 18:16:43 +0530
From:	"Suzuki K. Poulose" <suzuki@...ibm.com>
To:	Cong Wang <amwang@...hat.com>
Cc:	linux-kernel@...r.kernel.org,
	Jeremy Fitzhardinge <jeremy.fitzhardinge@...rix.com>,
	Christoph Hellwig <hch@....de>,
	Masami Hiramatsu <mhiramat@...hat.com>,
	Ananth N Mavinakayanahalli <ananth@...ibm.com>,
	Daisuke HATAYAMA <d.hatayama@...fujitsu.com>,
	Andi Kleen <andi@...stfloor.org>,
	Roland McGrath <roland@...hat.com>,
	Linus Torvalds <torvalds@...ux-foundation.org>,
	KAMEZAWA Hiroyuki <kamezawa.hiroyu@...fujitsu.com>,
	KOSAKI Motohiro <kosaki.motohiro@...fujitsu.com>,
	Oleg Nesterov <oleg@...hat.com>,
	Andrew Morton <akpm@...ux-foundation.org>
Subject: Re: [Patch 18/21] Generate the data sections for ELF Core

On Wed, 15 Dec 2010 15:19:54 +0800
Cong Wang <amwang@...hat.com> wrote:

> 于 2010年12月14日 18:22, Suzuki K. Poulose 写道:
> ...
> > +	/*
> > +	 * Read from the vma segments
> > +	 * a. verify if the *fpos is within a phdr
> > +	 * b. Use access_process_vm() to get data page by page
> > +	 * c. copy_to_user into user buffer
> > +	 */
> 
> 
> This kind of comments is useless, "code tells you how, comments tell you why."
> 
> 
> > +
> > +	while (buflen) {
> > +		size_t bufsz, offset, bytes;
> > +		char *readbuf;
> > +		struct elf_phdr *phdr = get_pos_elfphdr(cp, *fpos);
> > +
> > +		if (!phdr)
> > +			break;
> > +
> > +		bufsz = (buflen>  PAGE_SIZE) ? PAGE_SIZE : buflen;
> > +		readbuf = kmalloc(bufsz, GFP_KERNEL);
> > +		if (!readbuf) {
> > +			ret = -ENOMEM;
> > +			goto out;
> > +		}
> > +
> > +		offset = *fpos - phdr->p_offset;
> > +		bytes = access_process_vm(cp->task, (phdr->p_vaddr + offset),
> > +						readbuf, bufsz, 0);
> > +		if (!bytes) {
> > +			ret = -EIO;
> > +			goto out;
> 
> 
> Why you don't kfree(readbuf) here?
> 

I will add that.
> > +		}
> > +		if (copy_to_user(buffer, readbuf, bytes)) {
> > +			ret = -EFAULT;
> > +			kfree(readbuf);
> > +			goto out;
> > +		} else
> > +			acc += bytes;
> > +
> > +		kfree(readbuf);
> > +		buflen -= bytes;
> > +		buffer += bytes;
> > +		*fpos += bytes;
> > +	}
> > +
> > +	/* Fill extnum section header if present */
> > +	if (buflen&&
> > +		elf_hdr->e_shoff&&
> > +		(*fpos>= elf_hdr->e_shoff)&&
> > +		(*fpos<  (elf_hdr->e_shoff + sizeof(struct elf_shdr)))) {
> 
> 
> This indention seems ugly.

I will fix this.
> 
> > +
> > +		off_t offset = *fpos - elf_hdr->e_shoff;
> 
> Are you sure it is 'off_t' not 'loff_t'?
> 

You are right. I will change it
> > +		size_t shdrsz = sizeof(struct elf_shdr) - offset;
> > +
> > +		shdrsz = (buflen<  shdrsz) ? buflen : shdrsz;
> > +		if (copy_to_user(buffer, ((char *)cp->shdr) + offset, shdrsz)) {
> > +			ret = -EFAULT;
> > +			goto out;
> > +		} else {
> > +			acc += shdrsz;
> > +			buflen -= shdrsz;
> > +			buffer += shdrsz;
> > +		}
> > +	}
> >
> > +done:
> > +	ret = acc;
> >   out:
> >   	return ret;
> >   }
> 

Thank You !

Suzuki
> Thanks.

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ