From owner-svn-src-projects@FreeBSD.ORG Fri May 15 01:53:09 2009 Return-Path: Delivered-To: svn-src-projects@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 60160106566C; Fri, 15 May 2009 01:53:09 +0000 (UTC) (envelope-from gonzo@FreeBSD.org) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:4f8:fff6::2c]) by mx1.freebsd.org (Postfix) with ESMTP id 4D8338FC0C; Fri, 15 May 2009 01:53:09 +0000 (UTC) (envelope-from gonzo@FreeBSD.org) Received: from svn.freebsd.org (localhost [127.0.0.1]) by svn.freebsd.org (8.14.3/8.14.3) with ESMTP id n4F1r9m0008584; Fri, 15 May 2009 01:53:09 GMT (envelope-from gonzo@svn.freebsd.org) Received: (from gonzo@localhost) by svn.freebsd.org (8.14.3/8.14.3/Submit) id n4F1r9Bw008583; Fri, 15 May 2009 01:53:09 GMT (envelope-from gonzo@svn.freebsd.org) Message-Id: <200905150153.n4F1r9Bw008583@svn.freebsd.org> From: Oleksandr Tymoshenko Date: Fri, 15 May 2009 01:53:09 +0000 (UTC) To: src-committers@freebsd.org, svn-src-projects@freebsd.org X-SVN-Group: projects MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Cc: Subject: svn commit: r192132 - projects/mips/sys/mips/atheros X-BeenThere: svn-src-projects@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: "SVN commit messages for the src " projects" tree" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 15 May 2009 01:53:09 -0000 Author: gonzo Date: Fri May 15 01:53:09 2009 New Revision: 192132 URL: http://svn.freebsd.org/changeset/base/192132 Log: - Calculate CPU frequency using dividers from PLL registers Modified: projects/mips/sys/mips/atheros/ar71xx_machdep.c Modified: projects/mips/sys/mips/atheros/ar71xx_machdep.c ============================================================================== --- projects/mips/sys/mips/atheros/ar71xx_machdep.c Fri May 15 01:51:47 2009 (r192131) +++ projects/mips/sys/mips/atheros/ar71xx_machdep.c Fri May 15 01:53:09 2009 (r192132) @@ -97,8 +97,8 @@ platform_start(__register_t a0 __unused, __register_t a2 __unused, __register_t a3 __unused) { vm_offset_t kernend; - uint64_t platform_counter_freq; - uint32_t reg; + uint64_t platform_counter_freq, freq; + uint32_t reg, div, pll_config; /* clear the BSS and SBSS segments */ kernend = round_page((vm_offset_t)&end); @@ -118,11 +118,16 @@ platform_start(__register_t a0 __unused, * should be called first. */ init_param1(); - /* TODO: Get CPU freq from RedBoot. Is it possible? */ - platform_counter_freq = 680000000UL; + pll_config = ATH_READ_REG(AR71XX_PLL_CPU_CONFIG); + div = ((pll_config >> PLL_FB_SHIFT) & PLL_FB_MASK) + 1; + freq = div * AR71XX_BASE_FREQ; + div = ((pll_config >> PLL_CPU_DIV_SEL_SHIFT) & PLL_CPU_DIV_SEL_MASK) + + 1; + platform_counter_freq = freq / div; mips_timer_init_params(platform_counter_freq, 0); cninit(); + printf("platform frequency: %lld\n", platform_counter_freq); printf("arguments: \n"); printf(" a0 = %08x\n", a0); printf(" a1 = %08x\n", a1);