⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fsl_law.c

📁 uboot详细解读可用启动引导LINUX2.6内核
💻 C
字号:
/* * Copyright 2008 Freescale Semiconductor, Inc. * * (C) Copyright 2000 * Wolfgang Denk, DENX Software Engineering, wd@denx.de. * * See file CREDITS for list of people who contributed to this * project. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA */#include <common.h>#include <asm/fsl_law.h>#include <asm/io.h>DECLARE_GLOBAL_DATA_PTR;#define LAWAR_EN	0x80000000/* number of LAWs in the hw implementation */#if defined(CONFIG_MPC8540) || defined(CONFIG_MPC8541) || \    defined(CONFIG_MPC8560) || defined(CONFIG_MPC8555)#define FSL_HW_NUM_LAWS 8#elif defined(CONFIG_MPC8548) || defined(CONFIG_MPC8544) || \      defined(CONFIG_MPC8568) || \      defined(CONFIG_MPC8641) || defined(CONFIG_MPC8610)#define FSL_HW_NUM_LAWS 10#elif defined(CONFIG_MPC8572)#define FSL_HW_NUM_LAWS 12#else#error FSL_HW_NUM_LAWS not defined for this platform#endifvoid set_law(u8 idx, phys_addr_t addr, enum law_size sz, enum law_trgt_if id){	volatile u32 *base = (volatile u32 *)(CFG_IMMR + 0xc08);	volatile u32 *lawbar = base + 8 * idx;	volatile u32 *lawar = base + 8 * idx + 2;	gd->used_laws |= (1 << idx);	out_be32(lawbar, addr >> 12);	out_be32(lawar, LAWAR_EN | ((u32)id << 20) | (u32)sz);	return ;}int set_next_law(phys_addr_t addr, enum law_size sz, enum law_trgt_if id){	u32 idx = ffz(gd->used_laws);	if (idx >= FSL_HW_NUM_LAWS)		return -1;	set_law(idx, addr, sz, id);	return idx;}int set_last_law(phys_addr_t addr, enum law_size sz, enum law_trgt_if id){	u32 idx;	/* we have no LAWs free */	if (gd->used_laws == -1)		return -1;	/* grab the last free law */	idx = __ilog2(~(gd->used_laws));	if (idx >= FSL_HW_NUM_LAWS)		return -1;	set_law(idx, addr, sz, id);	return idx;}void disable_law(u8 idx){	volatile u32 *base = (volatile u32 *)(CFG_IMMR + 0xc08);	volatile u32 *lawbar = base + 8 * idx;	volatile u32 *lawar = base + 8 * idx + 2;	gd->used_laws &= ~(1 << idx);	out_be32(lawar, 0);	out_be32(lawbar, 0);	return;}void print_laws(void){	volatile u32 *base = (volatile u32 *)(CFG_IMMR + 0xc08);	volatile u32 *lawbar = base;	volatile u32 *lawar = base + 2;	int i;	printf("\nLocal Access Window Configuration\n");	for(i = 0; i < FSL_HW_NUM_LAWS; i++) {		printf("\tLAWBAR%d : 0x%08x, LAWAR%d : 0x%08x\n",		       i, in_be32(lawbar), i, in_be32(lawar));		lawbar += 8;		lawar += 8;	}	return;}void init_laws(void){	int i;	gd->used_laws = ~((1 << FSL_HW_NUM_LAWS) - 1);	for (i = 0; i < num_law_entries; i++) {		if (law_table[i].index == -1)			set_next_law(law_table[i].addr, law_table[i].size,					law_table[i].trgt_id);		else			set_law(law_table[i].index, law_table[i].addr,				law_table[i].size, law_table[i].trgt_id);	}	return ;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -