From: monstr@seznam.cz
To: linux-kernel@vger.kernel.org
Cc: linux-arch@vger.kernel.org, alan@lxorguk.ukuu.org.uk,
Michal Simek <monstr@monstr.eu>,
vapier.adi@gmail.com, arnd@arndb.de, matthew@wil.cx,
microblaze-uclinux@itee.uq.edu.au, drepper@redhat.com,
linuxppc-dev@ozlabs.org, will.newton@gmail.com, hpa@zytor.com,
John.Linn@xilinx.com, john.williams@petalogix.com
Subject: [PATCH 03/60] microblaze_v4: Cpuinfo handling
Date: Thu, 26 Jun 2008 14:29:32 +0200 [thread overview]
Message-ID: <1214483429-32360-4-git-send-email-monstr@seznam.cz> (raw)
In-Reply-To: <1214483429-32360-3-git-send-email-monstr@seznam.cz>
From: Michal Simek <monstr@monstr.eu>
Signed-off-by: Michal Simek <monstr@monstr.eu>
---
arch/microblaze/kernel/cpu/cpuinfo-pvr-full.c | 84 ++++++++++++++++++
arch/microblaze/kernel/cpu/cpuinfo-static.c | 115 +++++++++++++++++++++++++
arch/microblaze/kernel/cpu/cpuinfo.c | 85 ++++++++++++++++++
include/asm-microblaze/cpuinfo.h | 110 +++++++++++++++++++++++
4 files changed, 394 insertions(+), 0 deletions(-)
create mode 100644 arch/microblaze/kernel/cpu/cpuinfo-pvr-full.c
create mode 100644 arch/microblaze/kernel/cpu/cpuinfo-static.c
create mode 100644 arch/microblaze/kernel/cpu/cpuinfo.c
create mode 100644 include/asm-microblaze/cpuinfo.h
diff --git a/arch/microblaze/kernel/cpu/cpuinfo-pvr-full.c b/arch/microblaze/kernel/cpu/cpuinfo-pvr-full.c
new file mode 100644
index 0000000..aff07ef
--- /dev/null
+++ b/arch/microblaze/kernel/cpu/cpuinfo-pvr-full.c
@@ -0,0 +1,84 @@
+/*
+ * Support for MicroBlaze PVR (processor version register)
+ *
+ * Copyright (C) 2007 John Williams <john.williams@petalogix.com>
+ * Copyright (C) 2007 PetaLogix
+ *
+ * This file is subject to the terms and conditions of the GNU General Public
+ * License. See the file "COPYING" in the main directory of this archive
+ * for more details.
+ *
+ */
+
+#include <linux/init.h>
+#include <linux/string.h>
+#include <linux/autoconf.h>
+#include <asm/pvr.h>
+#include <asm/cpuinfo.h>
+
+/*
+ * Helper macro to map between fields in our struct cpuinfo, and
+ * the PVR macros in pvr.h.
+ */
+
+#define CI(c, p) ci->c = PVR_##p(pvr)
+
+void set_cpuinfo_pvr_full(struct cpuinfo *ci, struct device_node *cpu)
+{
+ struct pvr_s pvr;
+ get_pvr(&pvr);
+
+ CI(use_barrel, USE_BARREL);
+ CI(use_divider, USE_DIV);
+ CI(use_mult, USE_HW_MUL);
+ CI(use_fpu, USE_FPU);
+
+ CI(use_mul_64, USE_MUL64);
+ CI(use_msr_instr, USE_MSR_INSTR);
+ CI(use_pcmp_instr, USE_PCMP_INSTR);
+ CI(ver_code, VERSION);
+
+ CI(use_icache, USE_ICACHE);
+ CI(icache_tagbits, ICACHE_ADDR_TAG_BITS);
+ CI(icache_write, ICACHE_ALLOW_WR);
+ CI(icache_line, ICACHE_LINE_LEN);
+ CI(icache_size, ICACHE_BYTE_SIZE);
+ CI(icache_base, ICACHE_BASEADDR);
+ CI(icache_high, ICACHE_HIGHADDR);
+
+ CI(use_dcache, USE_DCACHE);
+ CI(dcache_tagbits, DCACHE_ADDR_TAG_BITS);
+ CI(dcache_write, DCACHE_ALLOW_WR);
+ CI(dcache_line, DCACHE_LINE_LEN);
+ CI(dcache_size, DCACHE_BYTE_SIZE);
+ CI(dcache_base, DCACHE_BASEADDR);
+ CI(dcache_high, DCACHE_HIGHADDR);
+
+ CI(use_dopb, D_OPB);
+ CI(use_iopb, I_OPB);
+ CI(use_dlmb, D_LMB);
+ CI(use_ilmb, I_LMB);
+ CI(num_fsl, FSL_LINKS);
+
+ CI(irq_edge, INTERRUPT_IS_EDGE);
+ CI(irq_positive, EDGE_IS_POSITIVE);
+
+ CI(area_optimised, AREA_OPTIMISED);
+ CI(opcode_0_illegal, OPCODE_0x0_ILLEGAL);
+ CI(exc_unaligned, UNALIGNED_EXCEPTION);
+ CI(exc_ill_opcode, ILL_OPCODE_EXCEPTION);
+ CI(exc_iopb, IOPB_BUS_EXCEPTION);
+ CI(exc_dopb, DOPB_BUS_EXCEPTION);
+ CI(exc_div_zero, DIV_ZERO_EXCEPTION);
+ CI(exc_fpu, FPU_EXCEPTION);
+
+ CI(hw_debug, DEBUG_ENABLED);
+ CI(num_pc_brk, NUMBER_OF_PC_BRK);
+ CI(num_rd_brk, NUMBER_OF_RD_ADDR_BRK);
+ CI(num_wr_brk, NUMBER_OF_WR_ADDR_BRK);
+
+ CI(fpga_family_code, TARGET_FAMILY);
+
+ /* take timebase-frequency from DTS */
+ ci->cpu_clock_freq = fcpu(cpu, "timebase-frequency");
+}
diff --git a/arch/microblaze/kernel/cpu/cpuinfo-static.c b/arch/microblaze/kernel/cpu/cpuinfo-static.c
new file mode 100644
index 0000000..7d1592d
--- /dev/null
+++ b/arch/microblaze/kernel/cpu/cpuinfo-static.c
@@ -0,0 +1,115 @@
+/*
+ * Copyright (C) 2007-2008 Michal Simek <monstr@monstr.eu>
+ * Copyright (C) 2007 John Williams <john.williams@petalogix.com>
+ * Copyright (C) 2007 PetaLogix
+ *
+ * This file is subject to the terms and conditions of the GNU General Public
+ * License. See the file "COPYING" in the main directory of this archive
+ * for more details.
+ *
+ */
+
+#include <linux/kernel.h>
+#include <linux/init.h>
+#include <linux/string.h>
+#include <linux/autoconf.h>
+#include <asm/cpuinfo.h>
+
+const static char family_string[] = CONFIG_XILINX_MICROBLAZE0_FAMILY;
+const static char cpu_ver_string[] = CONFIG_XILINX_MICROBLAZE0_HW_VER;
+
+void __init set_cpuinfo_static(struct cpuinfo *ci, struct device_node *cpu)
+{
+ int i;
+
+ ci->use_barrel = fcpu(cpu, "xlnx,use-barrel");
+ ci->use_divider = fcpu(cpu, "xlnx,use-div");
+ ci->use_mult = fcpu(cpu, "xlnx,use-hw-mul");
+ ci->use_fpu = fcpu(cpu, "xlnx,use-fpu");
+ ci->use_mul_64 = (ci->use_mult == 2 ? 1 : 0);
+ ci->use_msr_instr = fcpu(cpu, "xlnx,use-msr-instr");
+ ci->use_pcmp_instr = fcpu(cpu, "xlnx,use-pcmp-instr");
+
+ ci->use_exception = fcpu(cpu, "xlnx,unaligned-exceptions") ||
+ fcpu(cpu, "xlnx,ill-opcode-exception") ||
+ fcpu(cpu, "xlnx,iopb-bus-exception") ||
+ fcpu(cpu, "xlnx,dopb-bus-exception") ||
+ fcpu(cpu, "xlnx,div-zero-exception") ||
+ fcpu(cpu, "xlnx,fpu-exception");
+
+ ci->exc_unaligned = fcpu(cpu, "xlnx,unaligned-exceptions");
+ ci->exc_unaligned = fcpu(cpu, "xlnx,ill-opcode-exception");
+ ci->exc_iopb = fcpu(cpu, "xlnx,iopb-bus-exception");
+ ci->exc_dopb = fcpu(cpu, "xlnx,dopb-bus-exception");
+ ci->exc_fpu = fcpu(cpu, "xlnx,fpu-exception");
+ ci->exc_div_zero = fcpu(cpu, "xlnx,div-zero-exception");
+ ci->opcode_0_illegal = fcpu(cpu, "xlnx,opcode-0x0-illegal");
+
+ ci->use_icache = fcpu(cpu, "xlnx,use-icache");
+ ci->icache_tagbits = fcpu(cpu, "xlnx,addr-tag-bits");
+ ci->icache_write = fcpu(cpu, "xlnx,allow-icache-wr");
+ ci->icache_line = fcpu(cpu, "xlnx,icache-line-len") << 2;
+ if (!ci->icache_line) {
+ if (fcpu(cpu, "xlnx,icache-use-fsl"))
+ ci->icache_line = 4 << 2;
+ else
+ ci->icache_line = 1 << 2;
+ }
+ ci->icache_size = fcpu(cpu, "i-cache-size");
+ ci->icache_base = fcpu(cpu, "i-cache-baseaddr");
+ ci->icache_high = fcpu(cpu, "i-cache-highaddr");
+
+ ci->use_dcache = fcpu(cpu, "xlnx,use-dcache");
+ ci->dcache_tagbits = fcpu(cpu, "xlnx,dcache-addr-tag");
+ ci->dcache_write = fcpu(cpu, "xlnx,allow-dcache-wr");
+ ci->dcache_line = fcpu(cpu, "xlnx,dcache-line-len") << 2;
+ if (!ci->dcache_line) {
+ if (fcpu(cpu, "xlnx,dcache-use-fsl"))
+ ci->dcache_line = 4 << 2;
+ else
+ ci->dcache_line = 1 << 2;
+ }
+ ci->dcache_size = fcpu(cpu, "d-cache-size");
+ ci->dcache_base = fcpu(cpu, "d-cache-baseaddr");
+ ci->dcache_high = fcpu(cpu, "d-cache-highaddr");
+
+ ci->use_dopb = fcpu(cpu, "xlnx,d-opb");
+ ci->use_iopb = fcpu(cpu, "xlnx,i-opb");
+ ci->use_dlmb = fcpu(cpu, "xlnx,d-lmb");
+ ci->use_ilmb = fcpu(cpu, "xlnx,i-lmb");
+
+ ci->num_fsl = fcpu(cpu, "xlnx,fsl-links");
+ ci->irq_edge = fcpu(cpu, "xlnx,interrupt-is-edge");
+ ci->irq_positive = fcpu(cpu, "xlnx,edge-is-positive");
+ ci->area_optimised = 0;
+
+ ci->hw_debug = fcpu(cpu, "xlnx,debug-enabled");
+ ci->num_pc_brk = fcpu(cpu, "xlnx,number-of-pc-brk");
+ ci->num_rd_brk = fcpu(cpu, "xlnx,number-of-rd-addr-brk");
+ ci->num_wr_brk = fcpu(cpu, "xlnx,number-of-wr-addr-brk");
+
+ ci->cpu_clock_freq = fcpu(cpu, "timebase-frequency");
+
+ ci->ver_code = 0;
+ ci->fpga_family_code = 0;
+
+ /* Do various fixups based on CPU version and FPGA family strings */
+
+ /* Resolved the CPU version code */
+ for (i = 0; cpu_ver_lookup[i].s != NULL; i++) {
+ if (strcmp(cpu_ver_lookup[i].s, cpu_ver_string) == 0)
+ ci->ver_code = cpu_ver_lookup[i].k;
+ }
+
+ /* Resolved the fpga family code */
+ for (i = 0; family_string_lookup[i].s != NULL; i++) {
+ if (strcmp(family_string_lookup[i].s, family_string) == 0)
+ ci->fpga_family_code = family_string_lookup[i].k;
+ }
+
+ /* FIXME - mb3 and spartan2 do not exist in PVR */
+ /* This is mb3 and on a non Spartan2 */
+ if (ci->ver_code == 0x20 && ci->fpga_family_code != 0xf0)
+ /* Hardware Multiplier in use */
+ ci->use_mult = 1;
+}
diff --git a/arch/microblaze/kernel/cpu/cpuinfo.c b/arch/microblaze/kernel/cpu/cpuinfo.c
new file mode 100644
index 0000000..08ee835
--- /dev/null
+++ b/arch/microblaze/kernel/cpu/cpuinfo.c
@@ -0,0 +1,85 @@
+/*
+ * Copyright (C) 2007-2008 Michal Simek <monstr@monstr.eu>
+ * Copyright (C) 2007 John Williams <john.williams@petalogix.com>
+ * Copyright (C) 2007 PetaLogix
+ *
+ * This file is subject to the terms and conditions of the GNU General Public
+ * License. See the file "COPYING" in the main directory of this archive
+ * for more details.
+ *
+ */
+
+#include <linux/init.h>
+#include <linux/slab.h>
+#include <linux/autoconf.h>
+#include <asm/cpuinfo.h>
+#include <asm/pvr.h>
+
+const struct cpu_ver_key cpu_ver_lookup[] = {
+ /* These key value are as per MBV field in PVR0 */
+ {"5.00.a", 0x01},
+ {"5.00.b", 0x02},
+ {"5.00.c", 0x03},
+ {"6.00.a", 0x04},
+ {"6.00.b", 0x06},
+ {"7.00.a", 0x05},
+ {"7.00.b", 0x07},
+ {"7.10.a", 0x08},
+ {"7.10.b", 0x09},
+ /* FIXME There is no keycode defined in MBV for these versions */
+ {"2.10.a", 0x10},
+ {"3.00.a", 0x20},
+ {"4.00.a", 0x30},
+ {"4.00.b", 0x40},
+ {NULL, 0},
+};
+
+/*
+ * FIXME Not sure if the actual key is defined by Xilinx in the PVR
+ */
+const struct family_string_key family_string_lookup[] = {
+ {"virtex2", 0x4},
+ {"virtex2pro", 0x5},
+ {"spartan3", 0x6},
+ {"virtex4", 0x7},
+ {"virtex5", 0x8},
+ {"spartan3e", 0x9},
+ {"spartan3a", 0xa},
+ {"spartan3an", 0xb},
+ {"spartan3adsp", 0xc},
+ /* FIXME There is no key code defined for spartan2 */
+ {"spartan2", 0xf0},
+ {NULL, 0},
+};
+
+struct cpuinfo cpuinfo;
+
+void __init setup_cpuinfo(void)
+{
+ struct device_node *cpu = NULL;
+
+ cpu = (struct device_node *) of_find_node_by_type(NULL, "cpu");
+ if (!cpu)
+ printk(KERN_ERR "You don't have cpu!!!\n");
+
+ printk(KERN_INFO "%s: initialising\n", __func__);
+
+ switch (cpu_has_pvr()) {
+ case 0:
+ printk(KERN_WARNING
+ "%s: No PVR support. Using static CPU info from FDT\n",
+ __func__);
+ set_cpuinfo_static(&cpuinfo, cpu);
+ break;
+/* FIXME I found weird behavior with MB 7.00.a/b
+ * please do not use FULL PVR with MMU */
+ case 1:
+ printk(KERN_INFO "%s: Using full CPU PVR support\n",
+ __func__);
+ set_cpuinfo_pvr_full(&cpuinfo, cpu);
+ break;
+ default:
+ printk(KERN_WARNING "%s: Unsupported PVR setting\n", __func__);
+ set_cpuinfo_static(&cpuinfo, cpu);
+ }
+}
diff --git a/include/asm-microblaze/cpuinfo.h b/include/asm-microblaze/cpuinfo.h
new file mode 100644
index 0000000..b9cd56d
--- /dev/null
+++ b/include/asm-microblaze/cpuinfo.h
@@ -0,0 +1,110 @@
+/*
+ * Generic support for queying CPU info
+ *
+ * Copyright (C) 2007-2008 Michal Simek <monstr@monstr.eu>
+ * Copyright (C) 2007 John Williams <john.williams@petalogix.com>
+ * Copyright (C) 2007 PetaLogix
+ *
+ * This file is subject to the terms and conditions of the GNU General
+ * Public License. See the file COPYING in the main directory of this
+ * archive for more details.
+ */
+
+#ifndef _ASM_MICROBLAZE_CPUINFO_H
+#define _ASM_MICROBLAZE_CPUINFO_H
+
+#include <asm/prom.h>
+
+/* CPU Version and FPGA Family code conversion table type */
+struct cpu_ver_key {
+ const char *s;
+ const unsigned k;
+};
+
+extern const struct cpu_ver_key cpu_ver_lookup[];
+
+struct family_string_key {
+ const char *s;
+ const unsigned k;
+};
+
+extern const struct family_string_key family_string_lookup[];
+
+struct cpuinfo {
+ /* Core CPU configuration */
+ int use_barrel;
+ int use_divider;
+ int use_mult;
+ int use_fpu;
+ int use_exception;
+ int use_mul_64;
+ int use_msr_instr;
+ int use_pcmp_instr;
+
+ int ver_code;
+
+ /* CPU caches */
+ int use_icache;
+ int icache_tagbits;
+ int icache_write;
+ int icache_line;
+ int icache_size;
+ unsigned long icache_base;
+ unsigned long icache_high;
+
+ int use_dcache;
+ int dcache_tagbits;
+ int dcache_write;
+ int dcache_line;
+ int dcache_size;
+ unsigned long dcache_base;
+ unsigned long dcache_high;
+
+ /* Bus connections */
+ int use_dopb;
+ int use_iopb;
+ int use_dlmb;
+ int use_ilmb;
+ int num_fsl;
+
+ /* CPU interrupt line info */
+ int irq_edge;
+ int irq_positive;
+
+ int area_optimised;
+
+ /* HW support for CPU exceptions */
+ int opcode_0_illegal;
+ int exc_unaligned;
+ int exc_ill_opcode;
+ int exc_iopb;
+ int exc_dopb;
+ int exc_div_zero;
+ int exc_fpu;
+
+ /* HW debug support */
+ int hw_debug;
+ int num_pc_brk;
+ int num_rd_brk;
+ int num_wr_brk;
+ int cpu_clock_freq;
+
+ /* FPGA family */
+ int fpga_family_code;
+};
+
+extern struct cpuinfo cpuinfo;
+
+/* fwd declarations of the various CPUinfo populators */
+void setup_cpuinfo(void);
+
+void set_cpuinfo_static(struct cpuinfo *ci, struct device_node *cpu);
+void set_cpuinfo_pvr_full(struct cpuinfo *ci, struct device_node *cpu);
+
+static inline unsigned int fcpu(struct device_node *cpu, char *n)
+{
+ int *val;
+ return ((val = (int *) of_get_property(cpu, n, NULL)) ? *val : 0);
+}
+
+#endif /* _ASM_MICROBLAZE_CPUINFO_H */
--
1.5.4.GIT
next prev parent reply other threads:[~2008-06-26 13:43 UTC|newest]
Thread overview: 137+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-06-26 12:29 Microblaze init port v4 monstr
2008-06-26 12:29 ` [PATCH 01/60] microblaze_v4: Kconfig patches monstr
2008-06-26 12:29 ` [PATCH 02/60] microblaze_v4: Makefiles for Microblaze cpu monstr
2008-06-26 12:29 ` monstr [this message]
2008-06-26 12:29 ` [PATCH 04/60] microblaze_v4: Open firmware files1 monstr
2008-06-26 12:29 ` [PATCH 05/60] microblaze_v4: Open firmware files2 monstr
2008-06-26 12:29 ` [PATCH 06/60] microblaze_v4: Open firmware common files monstr
2008-06-26 12:29 ` [PATCH 07/60] microblaze_v4: Support for semaphores monstr
2008-06-26 12:29 ` [PATCH 08/60] microblaze_v4: exception handling monstr
2008-06-26 12:29 ` [PATCH 09/60] microblaze_v4: Signal support monstr
2008-06-26 12:29 ` [PATCH 10/60] microblaze_v4: Interrupt handling, timer support, supported function monstr
2008-06-26 12:29 ` [PATCH 11/60] microblaze_v4: cache support monstr
2008-06-26 12:29 ` [PATCH 12/60] microblaze_v4: Generic dts file for platforms monstr
2008-06-26 12:29 ` [PATCH 13/60] microblaze_v4: kernel modules support monstr
2008-06-26 12:29 ` [PATCH 14/60] microblaze_v4: lmb support monstr
2008-06-26 12:29 ` [PATCH 15/60] microblaze_v4: PVR support, cpuinfo support monstr
2008-06-26 12:29 ` [PATCH 16/60] microblaze_v4: defconfig file monstr
2008-06-26 12:29 ` [PATCH 17/60] microblaze_v4: head.S + linker script monstr
2008-06-26 12:29 ` [PATCH 18/60] microblaze_v4: supported function for memory - kernel/lib monstr
2008-06-26 12:29 ` [PATCH 19/60] microblaze_v4: checksum support monstr
2008-06-26 12:29 ` [PATCH 20/60] microblaze_v4: early_printk support monstr
2008-06-26 12:29 ` [PATCH 21/60] microblaze_v4: uaccess files monstr
2008-06-26 12:29 ` [PATCH 22/60] microblaze_v4: heartbeat file monstr
2008-06-26 12:29 ` [PATCH 23/60] microblaze_v4: setup.c - system setting monstr
2008-06-26 12:29 ` [PATCH 24/60] microblaze_v4: asm-offsets monstr
2008-06-26 12:29 ` [PATCH 25/60] microblaze_v4: process and init task function monstr
2008-06-26 12:29 ` [PATCH 26/60] microblaze_v4: time support monstr
2008-06-26 12:29 ` [PATCH 27/60] microblaze_v4: virtualization monstr
2008-06-26 12:29 ` [PATCH 28/60] microblaze_v4: ptrace support monstr
2008-06-26 12:29 ` [PATCH 29/60] microblaze_v4: traps support monstr
2008-06-26 12:29 ` [PATCH 30/60] microblaze_v4: support for a.out monstr
2008-06-26 12:30 ` [PATCH 31/60] microblaze_v4: memory inicialization, MMU, TLB monstr
2008-06-26 12:30 ` [PATCH 32/60] microblaze_v4: page.h, segment.h, unaligned.h monstr
2008-06-26 12:30 ` [PATCH 33/60] microblaze_v4: includes SHM*, msgbuf monstr
2008-06-26 12:30 ` [PATCH 34/60] microblaze_v4: bug headers files monstr
2008-06-26 12:30 ` [PATCH 35/60] microblaze_v4: definitions of types monstr
2008-06-26 12:30 ` [PATCH 36/60] microblaze_v4: ioctl support monstr
2008-06-26 12:30 ` [PATCH 37/60] microblaze_v4: io.h IO operations monstr
2008-06-26 12:30 ` [PATCH 38/60] microblaze_v4: headers for executables format FLAT, ELF monstr
2008-06-26 12:30 ` [PATCH 39/60] microblaze_v4: dma support monstr
2008-06-26 12:30 ` [PATCH 40/60] microblaze_v4: headers for irq monstr
2008-06-26 12:30 ` [PATCH 41/60] microblaze_v4: atomic.h bitops.h byteorder.h monstr
2008-06-26 12:30 ` [PATCH 42/60] microblaze_v4: headers pgalloc.h pgtable.h monstr
2008-06-26 12:30 ` [PATCH 43/60] microblaze_v4: system.h pvr.h processor.h monstr
2008-06-26 12:30 ` [PATCH 44/60] microblaze_v4: clinkage.h linkage.h sections.h kmap_types.h monstr
2008-06-26 12:30 ` [PATCH 45/60] microblaze_v4: stats headers monstr
2008-06-26 12:30 ` [PATCH 46/60] microblaze_v4: termbits.h termios.h monstr
2008-06-26 12:30 ` [PATCH 47/60] microblaze_v4: sigcontext.h siginfo.h monstr
2008-06-26 12:30 ` [PATCH 48/60] microblaze_v4: headers simple files - empty or redirect to asm-generic monstr
2008-06-26 12:30 ` [PATCH 49/60] microblaze_v4: headers files entry.h current.h mman.h registers.h sembuf.h monstr
2008-06-26 12:30 ` [PATCH 50/60] microblaze_v4: device.h param.h topology.h monstr
2008-06-26 12:30 ` [PATCH 51/60] microblaze_v4: pool.h socket.h monstr
2008-06-26 12:30 ` [PATCH 52/60] microblaze_v4: fcntl.h sockios.h ucontext.h monstr
2008-06-26 12:30 ` [PATCH 53/60] microblaze_v4: setup.h string.h thread_info.h monstr
2008-06-26 12:30 ` [PATCH 54/60] microblaze_v4: Kbuild file monstr
2008-06-26 12:30 ` [PATCH 55/60] microblaze_v4: pci headers monstr
2008-06-26 12:30 ` [PATCH 56/60] microblaze_v4: IPC headers monstr
2008-06-26 12:30 ` [PATCH 57/60] microblaze_v4: entry.S monstr
2008-06-26 12:30 ` [PATCH 58/60] microblaze_v4: sys_microblaze.c monstr
2008-06-26 12:30 ` [PATCH 59/60] microblaze_v4: syscall_table.S and unistd.h monstr
2008-06-26 12:30 ` [PATCH 60/60] microblaze_v4: Enable drivers for Microblaze monstr
2008-06-26 14:16 ` Peter Korsgaard
2008-06-26 16:31 ` [PATCH 59/60] microblaze_v4: syscall_table.S and unistd.h Arnd Bergmann
2008-06-26 17:02 ` H. Peter Anvin
2008-06-28 5:10 ` Paul Mundt
2008-06-26 15:48 ` [PATCH 58/60] microblaze_v4: sys_microblaze.c Arnd Bergmann
2008-06-26 19:07 ` Michal Simek
2008-06-26 22:34 ` Arnd Bergmann
2008-06-26 16:04 ` Arnd Bergmann
2008-06-26 15:43 ` [PATCH 52/60] microblaze_v4: fcntl.h sockios.h ucontext.h Arnd Bergmann
2008-06-26 16:46 ` Arnd Bergmann
2008-06-26 15:35 ` [PATCH 48/60] microblaze_v4: headers simple files - empty or redirect to asm-generic Arnd Bergmann
2008-06-26 16:21 ` Adrian Bunk
2008-06-26 16:38 ` Arnd Bergmann
2008-06-26 17:57 ` H. Peter Anvin
2008-06-26 22:09 ` Arnd Bergmann
2008-06-26 18:05 ` Adrian Bunk
2008-06-26 23:23 ` Arnd Bergmann
2008-06-27 11:59 ` Adrian Bunk
2008-06-27 13:19 ` Michal Simek
2008-06-27 13:55 ` Sam Ravnborg
2008-06-26 13:18 ` [PATCH 46/60] microblaze_v4: termbits.h termios.h Alan Cox
2008-06-26 18:44 ` Michal Simek
2008-06-26 15:28 ` Arnd Bergmann
2008-06-26 15:18 ` [PATCH 33/60] microblaze_v4: includes SHM*, msgbuf Arnd Bergmann
2008-06-26 15:14 ` [PATCH 31/60] microblaze_v4: memory inicialization, MMU, TLB Arnd Bergmann
2008-07-08 6:17 ` Michal Simek
2008-06-26 14:37 ` [PATCH 30/60] microblaze_v4: support for a.out Adrian Bunk
2008-06-26 19:23 ` Michal Simek
2008-06-26 19:27 ` H. Peter Anvin
2008-06-26 21:30 ` Michal Simek
2008-06-26 21:38 ` H. Peter Anvin
2008-06-28 5:04 ` Paul Mundt
2008-06-28 5:03 ` [PATCH 29/60] microblaze_v4: traps support Paul Mundt
2008-06-28 4:59 ` [PATCH 28/60] microblaze_v4: ptrace support Paul Mundt
2008-07-01 20:46 ` [PATCH 27/60] microblaze_v4: virtualization Adrian Bunk
2008-06-27 10:43 ` [PATCH 26/60] microblaze_v4: time support Thomas Gleixner
2008-06-27 13:10 ` Michal Simek
2008-06-28 4:50 ` [PATCH 25/60] microblaze_v4: process and init task function Paul Mundt
2008-06-28 4:43 ` [PATCH 24/60] microblaze_v4: asm-offsets Paul Mundt
2008-06-28 22:28 ` [PATCH 19/60] microblaze_v4: checksum support Segher Boessenkool
2008-06-30 7:18 ` Michal Simek
2008-06-30 16:25 ` Segher Boessenkool
2008-06-26 15:07 ` [PATCH 12/60] microblaze_v4: Generic dts file for platforms Jon Loeliger
2008-06-26 18:57 ` Michal Simek
2008-06-26 20:18 ` Stephen Neuendorffer
2008-06-26 21:41 ` Michal Simek
2008-06-26 21:44 ` Jon Loeliger
2008-06-28 5:49 ` Grant Likely
2008-06-30 0:02 ` John Williams
2008-06-30 3:39 ` Stephen Neuendorffer
2008-06-30 3:59 ` John Williams
2008-06-30 7:11 ` Michal Simek
2008-07-01 6:21 ` Benjamin Herrenschmidt
2008-07-01 15:58 ` Stephen Neuendorffer
2008-07-02 0:25 ` Benjamin Herrenschmidt
2008-06-30 6:48 ` Michal Simek
2008-06-26 16:35 ` [PATCH 08/60] microblaze_v4: exception handling Ray Lee
2008-06-26 19:19 ` Michal Simek
2008-06-26 19:43 ` Ray Lee
2008-06-26 21:06 ` Michal Simek
2008-06-26 14:36 ` [PATCH 07/60] microblaze_v4: Support for semaphores Adrian Bunk
2008-06-26 19:27 ` Michal Simek
2008-06-26 14:36 ` [PATCH 02/60] microblaze_v4: Makefiles for Microblaze cpu Adrian Bunk
2008-06-26 18:46 ` Michal Simek
2008-06-26 19:40 ` Adrian Bunk
2008-06-27 0:03 ` John Williams
2008-06-28 4:38 ` [PATCH 01/60] microblaze_v4: Kconfig patches Paul Mundt
2008-06-26 15:01 ` Microblaze init port v4 Adrian Bunk
2008-06-26 18:50 ` Michal Simek
2008-06-26 19:43 ` Adrian Bunk
2008-06-26 20:27 ` Stephen Neuendorffer
2008-06-27 0:12 ` John Williams
2008-06-26 15:09 ` Arnd Bergmann
2008-06-26 17:51 ` Arnd Bergmann
2008-06-26 17:54 ` H. Peter Anvin
2008-06-26 18:59 ` Michal Simek
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1214483429-32360-4-git-send-email-monstr@seznam.cz \
--to=monstr@seznam.cz \
--cc=John.Linn@xilinx.com \
--cc=alan@lxorguk.ukuu.org.uk \
--cc=arnd@arndb.de \
--cc=drepper@redhat.com \
--cc=hpa@zytor.com \
--cc=john.williams@petalogix.com \
--cc=linux-arch@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linuxppc-dev@ozlabs.org \
--cc=matthew@wil.cx \
--cc=microblaze-uclinux@itee.uq.edu.au \
--cc=monstr@monstr.eu \
--cc=vapier.adi@gmail.com \
--cc=will.newton@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).