mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-26 16:56:07 +00:00 
			
		
		
		
	 d8a944582d
			
		
	
	
		d8a944582d
		
	
	
	
	
		
			
			The OMAP2 clock code currently #includes a large .h file full of static
data structures.  Instead, define the data in a .c file.
Russell King <linux@arm.linux.org.uk> proposed this new arrangement:
    http://marc.info/?l=linux-omap&m=125967425908895&w=2
This patch also deals with most of the flagrant checkpatch violations.
While here, separate the prcm_config data structures out into their own
files, opp2xxx.h and opp24{2,3}0_data.c, and only build in the OPP tables
for the target device.  This should save some memory.  In the long run,
these prcm_config tables should be replaced with OPP code.
Signed-off-by: Paul Walmsley <paul@pwsan.com>
Cc: Russell King <linux@arm.linux.org.uk>
Cc: Richard Woodruff <r-woodruff2@ti.com>
Cc: Nishanth Menon <nm@ti.com>
		
	
			
		
			
				
	
	
		
			79 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __ARCH_ARM_MACH_OMAP2_SDRC_H
 | |
| #define __ARCH_ARM_MACH_OMAP2_SDRC_H
 | |
| 
 | |
| /*
 | |
|  * OMAP2 SDRC register definitions
 | |
|  *
 | |
|  * Copyright (C) 2007 Texas Instruments, Inc.
 | |
|  * Copyright (C) 2007 Nokia Corporation
 | |
|  *
 | |
|  * Written by Paul Walmsley
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU General Public License version 2 as
 | |
|  * published by the Free Software Foundation.
 | |
|  */
 | |
| #undef DEBUG
 | |
| 
 | |
| #include <plat/sdrc.h>
 | |
| 
 | |
| #ifndef __ASSEMBLER__
 | |
| 
 | |
| #include <linux/io.h>
 | |
| 
 | |
| extern void __iomem *omap2_sdrc_base;
 | |
| extern void __iomem *omap2_sms_base;
 | |
| 
 | |
| #define OMAP_SDRC_REGADDR(reg)			(omap2_sdrc_base + (reg))
 | |
| #define OMAP_SMS_REGADDR(reg)			(omap2_sms_base + (reg))
 | |
| 
 | |
| /* SDRC global register get/set */
 | |
| 
 | |
| static inline void sdrc_write_reg(u32 val, u16 reg)
 | |
| {
 | |
| 	__raw_writel(val, OMAP_SDRC_REGADDR(reg));
 | |
| }
 | |
| 
 | |
| static inline u32 sdrc_read_reg(u16 reg)
 | |
| {
 | |
| 	return __raw_readl(OMAP_SDRC_REGADDR(reg));
 | |
| }
 | |
| 
 | |
| /* SMS global register get/set */
 | |
| 
 | |
| static inline void sms_write_reg(u32 val, u16 reg)
 | |
| {
 | |
| 	__raw_writel(val, OMAP_SMS_REGADDR(reg));
 | |
| }
 | |
| 
 | |
| static inline u32 sms_read_reg(u16 reg)
 | |
| {
 | |
| 	return __raw_readl(OMAP_SMS_REGADDR(reg));
 | |
| }
 | |
| #else
 | |
| #define OMAP242X_SDRC_REGADDR(reg)					\
 | |
| 			OMAP2_L3_IO_ADDRESS(OMAP2420_SDRC_BASE + (reg))
 | |
| #define OMAP243X_SDRC_REGADDR(reg)					\
 | |
| 			OMAP2_L3_IO_ADDRESS(OMAP243X_SDRC_BASE + (reg))
 | |
| #define OMAP34XX_SDRC_REGADDR(reg)					\
 | |
| 			OMAP2_L3_IO_ADDRESS(OMAP343X_SDRC_BASE + (reg))
 | |
| #endif	/* __ASSEMBLER__ */
 | |
| 
 | |
| /* Minimum frequency that the SDRC DLL can lock at */
 | |
| #define MIN_SDRC_DLL_LOCK_FREQ		83000000
 | |
| 
 | |
| /* Scale factor for fixed-point arith in omap3_core_dpll_m2_set_rate() */
 | |
| #define SDRC_MPURATE_SCALE		8
 | |
| 
 | |
| /* 2^SDRC_MPURATE_BASE_SHIFT: MPU MHz that SDRC_MPURATE_LOOPS is defined for */
 | |
| #define SDRC_MPURATE_BASE_SHIFT		9
 | |
| 
 | |
| /*
 | |
|  * SDRC_MPURATE_LOOPS: Number of MPU loops to execute at
 | |
|  * 2^MPURATE_BASE_SHIFT MHz for SDRC to stabilize
 | |
|  */
 | |
| #define SDRC_MPURATE_LOOPS		96
 | |
| 
 | |
| 
 | |
| #endif
 |