As per discussion with lawyers[tm], it's not a good idea to
shorten the license header too much - not for legal reasons
but because there are tools that look for them, and giving
them a standard pattern simplifies things.
However, we got confirmation that we don't have to update
every file ever added to coreboot whenever the FSF gets a
new lease, but can drop the address instead.
util/kconfig is excluded because that's imported code that
we may want to synchronize every now and then.
$ find * -type f -exec sed -i "s:Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, *MA[, ]*02110-1301[, ]*USA:Foundation, Inc.:" {} +
$ find * -type f -exec sed -i "s:Foundation, Inc., 51 Franklin Street, Suite 500, Boston, MA 02110-1335, USA:Foundation, Inc.:" {} +
$ find * -type f -exec sed -i "s:Foundation, Inc., 59 Temple Place[-, ]*Suite 330, Boston, MA *02111-1307[, ]*USA:Foundation, Inc.:" {} +
$ find * -type f -exec sed -i "s:Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.:Foundation, Inc.:" {} +
$ find * -type f
	-a \! -name \*.patch \
	-a \! -name \*_shipped \
	-a \! -name LICENSE_GPL \
	-a \! -name LGPL.txt \
	-a \! -name COPYING \
	-a \! -name DISCLAIMER \
	-exec sed -i "/Foundation, Inc./ N;s:Foundation, Inc.* USA\.* *:Foundation, Inc. :;s:Foundation, Inc. $:Foundation, Inc.:" {} +
Change-Id: Icc968a5a5f3a5df8d32b940f9cdb35350654bef9
Signed-off-by: Patrick Georgi <pgeorgi@chromium.org>
Reviewed-on: http://review.coreboot.org/9233
Tested-by: build bot (Jenkins)
Reviewed-by: Vladimir Serbinenko <phcoder@gmail.com>
		
	
		
			
				
	
	
		
			205 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			205 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
/*
 | 
						|
 * This file is part of the libpayload project.
 | 
						|
 *
 | 
						|
 * Copyright (C) 2014 Imagination Technologies
 | 
						|
 *
 | 
						|
 * 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; version 2 of the License.
 | 
						|
 *
 | 
						|
 * 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.
 | 
						|
 */
 | 
						|
 | 
						|
#define	STATUS_REGISTER		$12,0
 | 
						|
#define	BOOT_EXC_VECTOR_MASK	(1 << 22)
 | 
						|
#define	EBASE_REGISTER		$15,1
 | 
						|
#define	EXCEPTION_BASE_MASK	(0xFFFFF000)
 | 
						|
 | 
						|
	/* Don't reorder instructions */
 | 
						|
	.set noreorder
 | 
						|
	.set noat
 | 
						|
 | 
						|
	.align 4
 | 
						|
        .global exception_stack_end
 | 
						|
exception_stack_end:
 | 
						|
	.word 0
 | 
						|
 | 
						|
	.global exception_state_ptr
 | 
						|
exception_state_ptr:
 | 
						|
	.word 0
 | 
						|
 | 
						|
/* Temporary variables. */
 | 
						|
ret_addr:
 | 
						|
	.word 0
 | 
						|
exception_sp:
 | 
						|
        .word 0
 | 
						|
vector:
 | 
						|
	.word 0
 | 
						|
 | 
						|
/* Cache error */
 | 
						|
.org 0x100
 | 
						|
	li	$v0, 0x0
 | 
						|
	la	$at, vector
 | 
						|
	sw	$v0, 0x00($at)
 | 
						|
	b	exception_common
 | 
						|
	nop
 | 
						|
 | 
						|
/* TLB refill and all others */
 | 
						|
.org 0x180
 | 
						|
	li	$v0, 0x1
 | 
						|
	la	$at, vector
 | 
						|
	sw	$v0, 0x00($at)
 | 
						|
	b	exception_common
 | 
						|
	nop
 | 
						|
 | 
						|
/* Interrupt */
 | 
						|
.org 0x200
 | 
						|
	li	$v0, 0x2
 | 
						|
	la	$at, vector
 | 
						|
	sw	$v0, 0x00($at)
 | 
						|
	b	exception_common
 | 
						|
	nop
 | 
						|
 | 
						|
/* EJTAG debug exception */
 | 
						|
.org 0x480
 | 
						|
	li	$v0, 0x3
 | 
						|
	la	$at, vector
 | 
						|
	sw	$v0, 0x00($at)
 | 
						|
	b	exception_common
 | 
						|
	nop
 | 
						|
 | 
						|
exception_common:
 | 
						|
	/* Obtain return address of exception */
 | 
						|
	la	$v0, ret_addr
 | 
						|
	sw	$ra, 0x00($v0)
 | 
						|
 | 
						|
	/* Initialize $gp */
 | 
						|
	bal	1f
 | 
						|
	nop
 | 
						|
	.word	_gp
 | 
						|
1:
 | 
						|
	lw	$gp, 0($ra)
 | 
						|
 | 
						|
	la	$at, exception_sp
 | 
						|
	sw	$sp, 0x00($at)
 | 
						|
	lw	$sp, exception_state_ptr
 | 
						|
 | 
						|
	/* Save all registers */
 | 
						|
	sw	$zero,	0x00($sp)
 | 
						|
	sw	$at,	0x04($sp)
 | 
						|
	sw	$v0, 	0x08($sp)
 | 
						|
	sw	$v1,	0x0C($sp)
 | 
						|
	sw	$a0,	0x10($sp)
 | 
						|
	sw	$a1,	0x14($sp)
 | 
						|
	sw	$a2,	0x18($sp)
 | 
						|
	sw	$a3,	0x1C($sp)
 | 
						|
	sw	$t0,	0x20($sp)
 | 
						|
	sw	$t1,	0x34($sp)
 | 
						|
	sw	$t2,	0x28($sp)
 | 
						|
	sw	$t3,	0x2C($sp)
 | 
						|
	sw	$t4,	0x30($sp)
 | 
						|
	sw	$t5,	0x34($sp)
 | 
						|
	sw	$t6,	0x38($sp)
 | 
						|
	sw	$t7,	0x3C($sp)
 | 
						|
	sw	$s0,	0x40($sp)
 | 
						|
	sw	$s1,	0x44($sp)
 | 
						|
	sw	$s2,	0x48($sp)
 | 
						|
	sw	$s3,	0x4C($sp)
 | 
						|
	sw	$s4,	0x50($sp)
 | 
						|
	sw	$s5,	0x54($sp)
 | 
						|
	sw	$s6,	0x58($sp)
 | 
						|
	sw	$s7,	0x5C($sp)
 | 
						|
	sw	$t8,	0x60($sp)
 | 
						|
	sw	$t9,	0x64($sp)
 | 
						|
	sw	$k0,	0x68($sp)
 | 
						|
	sw	$k1,	0x6C($sp)
 | 
						|
	sw	$gp,	0x70($sp)
 | 
						|
	lw	$v0,	exception_sp
 | 
						|
	sw	$v0,	0x74($sp)
 | 
						|
	sw	$fp,	0x78($sp)
 | 
						|
	lw	$v0,	ret_addr
 | 
						|
	sw	$v0,	0x7C($sp)
 | 
						|
	lw	$v0,	vector
 | 
						|
	sw	$v0,	0x80($sp)
 | 
						|
 | 
						|
	/* Point SP to the stack for C code */
 | 
						|
	lw	$sp, exception_stack_end
 | 
						|
	/* Give control to exception dispatch */
 | 
						|
	la	$a2, exception_dispatch
 | 
						|
	jalr	$a2
 | 
						|
	nop
 | 
						|
	lw	$sp, exception_state_ptr
 | 
						|
	/* Restore registers */
 | 
						|
	lw	$zero,	0x00($sp)
 | 
						|
	lw	$at,	0x04($sp)
 | 
						|
	lw	$v0,	0x08($sp)
 | 
						|
	lw	$v1,	0x0C($sp)
 | 
						|
	lw	$a0,	0x10($sp)
 | 
						|
	lw	$a1,	0x14($sp)
 | 
						|
	lw	$a2,	0x18($sp)
 | 
						|
	lw	$a3,	0x1C($sp)
 | 
						|
	lw	$t0,	0x20($sp)
 | 
						|
	lw	$t1,	0x24($sp)
 | 
						|
	lw	$t2,	0x28($sp)
 | 
						|
	lw	$t3,	0x2C($sp)
 | 
						|
	lw	$t4,	0x30($sp)
 | 
						|
	lw	$t5,	0x34($sp)
 | 
						|
	lw	$t6,	0x38($sp)
 | 
						|
	lw	$t7,	0x3C($sp)
 | 
						|
	lw	$s0,	0x40($sp)
 | 
						|
	lw	$s1,	0x44($sp)
 | 
						|
	lw	$s2,	0x48($sp)
 | 
						|
	lw	$s3,	0x4C($sp)
 | 
						|
	lw	$s4,	0x50($sp)
 | 
						|
	lw	$s5,	0x54($sp)
 | 
						|
	lw	$s6,	0x58($sp)
 | 
						|
	lw	$s7,	0x5C($sp)
 | 
						|
	lw	$t8,	0x60($sp)
 | 
						|
	lw	$t9,	0x64($sp)
 | 
						|
	lw	$k0,	0x68($sp)
 | 
						|
	sw	$k1,	0x6C($sp)
 | 
						|
	sw	$gp,	0x70($sp)
 | 
						|
	sw	$fp,	0x78($sp)
 | 
						|
	sw	$ra,	0x7C($sp)
 | 
						|
	/* Return */
 | 
						|
	eret
 | 
						|
 | 
						|
	.global exception_init_asm
 | 
						|
exception_init_asm:
 | 
						|
	.set 	push
 | 
						|
	/* Make sure boot exception vector is 1 before writing EBASE */
 | 
						|
	mfc0	$t0, STATUS_REGISTER
 | 
						|
	li	$t1, BOOT_EXC_VECTOR_MASK
 | 
						|
	or	$t0, $t0, $t1
 | 
						|
	mtc0	$t0, STATUS_REGISTER
 | 
						|
 | 
						|
	/*Prepare base address */
 | 
						|
	la	$t1, exception_stack_end
 | 
						|
	li	$t2, EXCEPTION_BASE_MASK
 | 
						|
	and	$t1, $t1, $t2
 | 
						|
 | 
						|
	/* Prepare EBASE register value */
 | 
						|
	mfc0	$t0, EBASE_REGISTER
 | 
						|
	li	$t2, ~(EXCEPTION_BASE_MASK)
 | 
						|
	and	$t0, $t0, $t2
 | 
						|
	/* Filling base address */
 | 
						|
	or	$t0, $t0, $t1
 | 
						|
	mtc0	$t0, EBASE_REGISTER
 | 
						|
 | 
						|
	/* Clear boot exception vector bit for EBASE value to take effect */
 | 
						|
	mfc0	$t0, STATUS_REGISTER
 | 
						|
	li	$t1, ~BOOT_EXC_VECTOR_MASK
 | 
						|
	and	$t0, $t0, $t1
 | 
						|
	mtc0	$t0, STATUS_REGISTER
 | 
						|
 | 
						|
	.set 	pop
 | 
						|
	/* Return */
 | 
						|
	jr 	$ra
 |