mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
OpenRISC: Miscellaneous
Adds README file, TODO list, and a couple of other pieces that didn't seem to fit into any other patch. Signed-off-by: Jonas Bonn <jonas@southpole.se> Reviewed-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
parent
224cd129fd
commit
616257669e
4 changed files with 231 additions and 0 deletions
99
arch/openrisc/README.openrisc
Normal file
99
arch/openrisc/README.openrisc
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
OpenRISC Linux
|
||||||
|
==============
|
||||||
|
|
||||||
|
This is a port of Linux to the OpenRISC class of microprocessors; the initial
|
||||||
|
target architecture, specifically, is the 32-bit OpenRISC 1000 family (or1k).
|
||||||
|
|
||||||
|
For information about OpenRISC processors and ongoing development:
|
||||||
|
|
||||||
|
website http://openrisc.net
|
||||||
|
|
||||||
|
For more information about Linux on OpenRISC, please contact South Pole AB.
|
||||||
|
|
||||||
|
email: info@southpole.se
|
||||||
|
|
||||||
|
website: http://southpole.se
|
||||||
|
http://southpoleconsulting.com
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
|
||||||
|
Build instructions for OpenRISC toolchain and Linux
|
||||||
|
===================================================
|
||||||
|
|
||||||
|
In order to build and run Linux for OpenRISC, you'll need at least a basic
|
||||||
|
toolchain and, perhaps, the architectural simulator. Steps to get these bits
|
||||||
|
in place are outlined here.
|
||||||
|
|
||||||
|
1) The toolchain can be obtained from openrisc.net. Instructions for building
|
||||||
|
a toolchain can be found at:
|
||||||
|
|
||||||
|
http://openrisc.net/toolchain-build.html
|
||||||
|
|
||||||
|
2) or1ksim (optional)
|
||||||
|
|
||||||
|
or1ksim is the architectural simulator which will allow you to actually run
|
||||||
|
your OpenRISC Linux kernel if you don't have an OpenRISC processor at hand.
|
||||||
|
|
||||||
|
git clone git://openrisc.net/jonas/or1ksim-svn
|
||||||
|
|
||||||
|
cd or1ksim
|
||||||
|
./configure --prefix=$OPENRISC_PREFIX
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
3) Linux kernel
|
||||||
|
|
||||||
|
Build the kernel as usual
|
||||||
|
|
||||||
|
make ARCH=openrisc defconfig
|
||||||
|
make ARCH=openrisc
|
||||||
|
|
||||||
|
4) Run in architectural simulator
|
||||||
|
|
||||||
|
Grab the or1ksim platform configuration file (from the or1ksim source) and
|
||||||
|
together with your freshly built vmlinux, run your kernel with the following
|
||||||
|
incantation:
|
||||||
|
|
||||||
|
sim -f arch/openrisc/or1ksim.cfg vmlinux
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
|
||||||
|
Terminology
|
||||||
|
===========
|
||||||
|
|
||||||
|
In the code, the following particles are used on symbols to limit the scope
|
||||||
|
to more or less specific processor implementations:
|
||||||
|
|
||||||
|
openrisc: the OpenRISC class of processors
|
||||||
|
or1k: the OpenRISC 1000 family of processors
|
||||||
|
or1200: the OpenRISC 1200 processor
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
|
||||||
|
History
|
||||||
|
========
|
||||||
|
|
||||||
|
18. 11. 2003 Matjaz Breskvar (phoenix@bsemi.com)
|
||||||
|
initial port of linux to OpenRISC/or32 architecture.
|
||||||
|
all the core stuff is implemented and seams usable.
|
||||||
|
|
||||||
|
08. 12. 2003 Matjaz Breskvar (phoenix@bsemi.com)
|
||||||
|
complete change of TLB miss handling.
|
||||||
|
rewrite of exceptions handling.
|
||||||
|
fully functional sash-3.6 in default initrd.
|
||||||
|
a much improved version with changes all around.
|
||||||
|
|
||||||
|
10. 04. 2004 Matjaz Breskvar (phoenix@bsemi.com)
|
||||||
|
alot of bugfixes all over.
|
||||||
|
ethernet support, functional http and telnet servers.
|
||||||
|
running many standard linux apps.
|
||||||
|
|
||||||
|
26. 06. 2004 Matjaz Breskvar (phoenix@bsemi.com)
|
||||||
|
port to 2.6.x
|
||||||
|
|
||||||
|
30. 11. 2004 Matjaz Breskvar (phoenix@bsemi.com)
|
||||||
|
lots of bugfixes and enhancments.
|
||||||
|
added opencores framebuffer driver.
|
||||||
|
|
||||||
|
09. 10. 2010 Jonas Bonn (jonas@southpole.se)
|
||||||
|
major rewrite to bring up to par with upstream Linux 2.6.36
|
16
arch/openrisc/TODO.openrisc
Normal file
16
arch/openrisc/TODO.openrisc
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
The OpenRISC Linux port is fully functional and has been tracking upstream
|
||||||
|
since 2.6.35. There are, however, remaining items to be completed within
|
||||||
|
the coming months. Here's a list of known-to-be-less-than-stellar items
|
||||||
|
that are due for investigation shortly, i.e. our TODO list:
|
||||||
|
|
||||||
|
-- Implement the rest of the DMA API... dma_map_sg, etc.
|
||||||
|
|
||||||
|
-- Consolidate usage of memblock and bootmem... move everything over to
|
||||||
|
memblock.
|
||||||
|
|
||||||
|
-- Finish the renaming cleanup... there are references to or32 in the code
|
||||||
|
which was an older name for the architecture. The name we've settled on is
|
||||||
|
or1k and this change is slowly trickling through the stack. For the time
|
||||||
|
being, or32 is equivalent to or1k.
|
||||||
|
|
||||||
|
-- Implement optimized version of memcpy and memset
|
70
arch/openrisc/kernel/asm-offsets.c
Normal file
70
arch/openrisc/kernel/asm-offsets.c
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
/*
|
||||||
|
* OpenRISC asm-offsets.c
|
||||||
|
*
|
||||||
|
* Linux architectural port borrowing liberally from similar works of
|
||||||
|
* others. All original copyrights apply as per the original source
|
||||||
|
* declaration.
|
||||||
|
*
|
||||||
|
* Modifications for the OpenRISC architecture:
|
||||||
|
* Copyright (C) 2003 Matjaz Breskvar <phoenix@bsemi.com>
|
||||||
|
* Copyright (C) 2010-2011 Jonas Bonn <jonas@southpole.se>
|
||||||
|
*
|
||||||
|
* 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 used to generate definitions needed by
|
||||||
|
* assembly language modules.
|
||||||
|
*
|
||||||
|
* We use the technique used in the OSF Mach kernel code:
|
||||||
|
* generate asm statements containing #defines,
|
||||||
|
* compile this file to assembler, and then extract the
|
||||||
|
* #defines from the assembly-language output.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/signal.h>
|
||||||
|
#include <linux/sched.h>
|
||||||
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/errno.h>
|
||||||
|
#include <linux/string.h>
|
||||||
|
#include <linux/types.h>
|
||||||
|
#include <linux/ptrace.h>
|
||||||
|
#include <linux/mman.h>
|
||||||
|
#include <linux/mm.h>
|
||||||
|
#include <linux/io.h>
|
||||||
|
#include <linux/thread_info.h>
|
||||||
|
#include <asm/page.h>
|
||||||
|
#include <asm/pgtable.h>
|
||||||
|
#include <asm/processor.h>
|
||||||
|
|
||||||
|
#define DEFINE(sym, val) \
|
||||||
|
asm volatile("\n->" #sym " %0 " #val : : "i" (val))
|
||||||
|
|
||||||
|
#define BLANK() asm volatile("\n->" : : )
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
/* offsets into the task_struct */
|
||||||
|
DEFINE(TASK_STATE, offsetof(struct task_struct, state));
|
||||||
|
DEFINE(TASK_FLAGS, offsetof(struct task_struct, flags));
|
||||||
|
DEFINE(TASK_PTRACE, offsetof(struct task_struct, ptrace));
|
||||||
|
DEFINE(TASK_THREAD, offsetof(struct task_struct, thread));
|
||||||
|
DEFINE(TASK_MM, offsetof(struct task_struct, mm));
|
||||||
|
DEFINE(TASK_ACTIVE_MM, offsetof(struct task_struct, active_mm));
|
||||||
|
|
||||||
|
/* offsets into thread_info */
|
||||||
|
DEFINE(TI_TASK, offsetof(struct thread_info, task));
|
||||||
|
DEFINE(TI_FLAGS, offsetof(struct thread_info, flags));
|
||||||
|
DEFINE(TI_PREEMPT, offsetof(struct thread_info, preempt_count));
|
||||||
|
DEFINE(TI_KSP, offsetof(struct thread_info, ksp));
|
||||||
|
|
||||||
|
DEFINE(PT_SIZE, sizeof(struct pt_regs));
|
||||||
|
|
||||||
|
/* Interrupt register frame */
|
||||||
|
DEFINE(STACK_FRAME_OVERHEAD, STACK_FRAME_OVERHEAD);
|
||||||
|
DEFINE(INT_FRAME_SIZE, STACK_FRAME_OVERHEAD + sizeof(struct pt_regs));
|
||||||
|
|
||||||
|
DEFINE(NUM_USER_SEGMENTS, TASK_SIZE >> 28);
|
||||||
|
return 0;
|
||||||
|
}
|
46
arch/openrisc/kernel/or32_ksyms.c
Normal file
46
arch/openrisc/kernel/or32_ksyms.c
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
/*
|
||||||
|
* OpenRISC or32_ksyms.c
|
||||||
|
*
|
||||||
|
* Linux architectural port borrowing liberally from similar works of
|
||||||
|
* others. All original copyrights apply as per the original source
|
||||||
|
* declaration.
|
||||||
|
*
|
||||||
|
* Modifications for the OpenRISC architecture:
|
||||||
|
* Copyright (C) 2003 Matjaz Breskvar <phoenix@bsemi.com>
|
||||||
|
* Copyright (C) 2010-2011 Jonas Bonn <jonas@southpole.se>
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/module.h>
|
||||||
|
#include <linux/elfcore.h>
|
||||||
|
#include <linux/sched.h>
|
||||||
|
#include <linux/in6.h>
|
||||||
|
#include <linux/interrupt.h>
|
||||||
|
#include <linux/vmalloc.h>
|
||||||
|
#include <linux/semaphore.h>
|
||||||
|
|
||||||
|
#include <asm/processor.h>
|
||||||
|
#include <asm/uaccess.h>
|
||||||
|
#include <asm/checksum.h>
|
||||||
|
#include <asm/io.h>
|
||||||
|
#include <asm/hardirq.h>
|
||||||
|
#include <asm/delay.h>
|
||||||
|
#include <asm/pgalloc.h>
|
||||||
|
|
||||||
|
#define DECLARE_EXPORT(name) extern void name(void); EXPORT_SYMBOL(name)
|
||||||
|
|
||||||
|
/* compiler generated symbols */
|
||||||
|
DECLARE_EXPORT(__udivsi3);
|
||||||
|
DECLARE_EXPORT(__divsi3);
|
||||||
|
DECLARE_EXPORT(__umodsi3);
|
||||||
|
DECLARE_EXPORT(__modsi3);
|
||||||
|
DECLARE_EXPORT(__muldi3);
|
||||||
|
DECLARE_EXPORT(__ashrdi3);
|
||||||
|
DECLARE_EXPORT(__ashldi3);
|
||||||
|
DECLARE_EXPORT(__lshrdi3);
|
||||||
|
|
||||||
|
EXPORT_SYMBOL(__copy_tofrom_user);
|
Loading…
Reference in a new issue