From owner-freebsd-hackers@FreeBSD.ORG Wed Feb 11 18:32:02 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 015A91065670 for ; Wed, 11 Feb 2009 18:32:02 +0000 (UTC) (envelope-from tinguely@casselton.net) Received: from casselton.net (casselton.net [63.165.140.2]) by mx1.freebsd.org (Postfix) with ESMTP id 945118FC14 for ; Wed, 11 Feb 2009 18:32:01 +0000 (UTC) (envelope-from tinguely@casselton.net) Received: from casselton.net (localhost [127.0.0.1]) by casselton.net (8.14.3/8.14.3) with ESMTP id n1BIFdnB036623; Wed, 11 Feb 2009 12:15:39 -0600 (CST) (envelope-from tinguely@casselton.net) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=casselton.net; s=ccnMail; t=1234376139; bh=Fe1jWPEMEOwayGHcbU+IKkwE7N/uMy8sN3pSRvwhwAc=; h=Date:From:Message-Id:To:Subject:In-Reply-To; b=YV+px/fSM7D5eZPdXnNqht7QDK0uGTJeAgI3XtsrDI5Tl6b7p/8lhLJ7TL+hzC8ac +e6TipkXQ0n2pPLzbm9hqEqVcjLaclIwzUjzZEJJfieqRdjGypVNWAWPsv6wAMr3Xq a7tUBKHLhiDr9nNb+IRrVFpYko5y9CkOAP1xQbR4= Received: (from tinguely@localhost) by casselton.net (8.14.3/8.14.2/Submit) id n1BIFdYa036622; Wed, 11 Feb 2009 12:15:39 -0600 (CST) (envelope-from tinguely) Date: Wed, 11 Feb 2009 12:15:39 -0600 (CST) From: Mark Tinguely Message-Id: <200902111815.n1BIFdYa036622@casselton.net> To: freebsd-hackers@freebsd.org, mehulc87@gmail.com In-Reply-To: <251d650c0902110545w7c521e66tcb74f8ecc83e17a1@mail.gmail.com> X-Mailman-Approved-At: Wed, 11 Feb 2009 18:35:54 +0000 Cc: Subject: Re: understanding of PTD symbol 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: Wed, 11 Feb 2009 18:32:02 -0000 > Hello all, > I am having doubts in understanding the usage of the > symbol PTD. Could anyone pls explain the usage of PTD in the FreeBSD > kernel?? > > In pmap_growkernel when we execute the following instruction wht is > returned by pdir_pde ? Is it the physical address of a page table for > KVA addressing?? > > while (pdir_pde(PTD, kernel_vm_end)) > > When I used objdump on the kernel executable i found the address of > PTD symbol to be 0xBFEFF000 , I could not understand this , as in a > virtual memory with 1G/3G split the kernel addressing must be between > the addresses 0xC0000000 and 0xFFFFFFFF. > > Regards, > Mehul On the i386/amd64, the page table sits just below the kernel virtual memory. The recursive virtual address reference to the page table is inside this address. Assume i386 with 4 byte pointers and 4GB virtual address space with the 3GB user vm and 1GB kernel vm: the PTmap will start at 0xbfc00000 (which is one 4MB entry below the KVA). the PTD page directory descripters for the page table descripter will be 0xdeff000 which is 767 4K entries into the page table. Note: 768 is the 3G mark, so 767 is one less than 3/4 into the page table. PTDpde is the page table descriptor the the page table. It is PTD + 767 * 4 I found it easier to draw the various layouts and the page table itself. The i386 in 32 bit mode is 10 bits for the page directory, 10 bits for the page table and 12 bits for the physical page. The ARM processor is funner with 12/8/12 bits. --Mark Tinguely.