From owner-freebsd-hackers@FreeBSD.ORG Thu Nov 19 10:59:15 2009 Return-Path: Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id AD857106578B for ; Thu, 19 Nov 2009 10:59:15 +0000 (UTC) (envelope-from sharadc@in.niksun.com) Received: from in.niksun.com (210.18.76.166.sify.net [210.18.76.166]) by mx1.freebsd.org (Postfix) with ESMTP id 3C6358FC1E for ; Thu, 19 Nov 2009 10:59:14 +0000 (UTC) Received: from sharadc.in.niksun.com (unknown [10.60.5.27]) by in.niksun.com (Postfix) with ESMTP id 9E7385CC4; Thu, 19 Nov 2009 16:37:33 +0530 (IST) From: Sharad Chandra Organization: NIKSUN To: freebsd-hackers@freebsd.org Date: Thu, 19 Nov 2009 16:27:33 +0530 User-Agent: KMail/1.9.4 References: <200911171529.20098.sharadc@in.niksun.com> <200911181433.52557.jkim@FreeBSD.org> In-Reply-To: <200911181433.52557.jkim@FreeBSD.org> X-Face: "$jQ]ksJ8"4@"hbi0lV=]BJ`myq*p; AcKl=e)=?utf-8?q?=5B3jei!uFob=0A=09?=(xpq6aZ|P(h&l}OxOfr`KGp2}$`IF-)7F6Pp[X#)n*&VF>=?utf-8?q?BoCU0iZ=3F6=7CAZpbi=23F=3B=5E0wP-d=0A=09W=5EucFs*nP?=@dj7x`; _PG@wRen8\in2VpfmCz(,.|>=?utf-8?q?U2KD*hIJHk86=5EH=5E=0A=09ct/-=3F=3D8i16u?=,oB'J*9^\#aN' MIME-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: 7bit Content-Disposition: inline Message-Id: <200911191627.34076.sharadc@in.niksun.com> Cc: Kostik Belousov , Robert Watson , Manprit Singh , Jung-uk Kim Subject: Re: mprotect(2) clears the flag for whole page which causes program crash. X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 19 Nov 2009 10:59:15 -0000 ,---- [Jung-uk Kim wrote:] | On Wednesday 18 November 2009 01:52 pm, Robert Watson wrote: | > On Tue, 17 Nov 2009, Sharad Chandra wrote: | > > Is it known bug or is there any workaround? How will a userland | > > process make sure that process will not crash as malloc(3) can | > > allocate where ever it get the memory free to use. | > | > mprotect(2) operates on pages, so you'll want to use mmap(2) and | > munmap(2) to allocate and free pages directly rather than | > mallac(3), which manages byte ranges from pages managed using those | > same interfaces. | | For example: | | http://docs.freebsd.org/cgi/mid.cgi?200911181926.nAIJQHOR081471 | Thanks everyone. mmap(2) worked and program did not crash. Only problem with it I use only fraction of allocated memory (each request alocate minimum of one page and my request is in hundreds), rest is waste of it so no one else will get this memory to use. And if a process runs as daemon and makes many request, It can hold a lot of it. Just a question floated in mind. Many thanks, Sharad Chandra