linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [RFC/PATCH] Support for mach-xbox
@ 2003-06-02 20:27 Anders Gustafsson
  2003-06-02 20:50 ` mikpe
                   ` (2 more replies)
  0 siblings, 3 replies; 7+ messages in thread
From: Anders Gustafsson @ 2003-06-02 20:27 UTC (permalink / raw)
  To: linux-kernel

Hi,

Attached is a patch that adds a new subachitecture for the xbox gaming
system. All it does outside the subarchitecture is adding posibility to
blacklist pci-devices through an mach-hook.

xbox-linux team

-- 
Anders Gustafsson - andersg@0x63.nu - http://0x63.nu/

You can import this changeset into BK by piping this whole message to:
'| bk receive [path to repository]' or apply the patch as usual.

===================================================================


ChangeSet
  1.1327 03/06/02 19:11:56 andersg@0x63.nu +10 -0
  Added XBOX subarch

  include/asm-i386/mach-xbox/mach_pci_blacklist.h
    1.1 03/06/02 19:11:46 andersg@0x63.nu +6 -0

  include/asm-i386/mach-default/mach_pci_blacklist.h
    1.1 03/06/02 19:11:46 andersg@0x63.nu +6 -0

  arch/i386/mach-xbox/setup.c
    1.1 03/06/02 19:11:46 andersg@0x63.nu +79 -0

  include/asm-i386/mach-xbox/mach_pci_blacklist.h
    1.0 03/06/02 19:11:46 andersg@0x63.nu +0 -0
    BitKeeper file /data/dev/kernel/bk/xbox-2.5/include/asm-i386/mach-xbox/mach_pci_blacklist.h

  include/asm-i386/mach-default/mach_pci_blacklist.h
    1.0 03/06/02 19:11:46 andersg@0x63.nu +0 -0
    BitKeeper file /data/dev/kernel/bk/xbox-2.5/include/asm-i386/mach-default/mach_pci_blacklist.h

  arch/i386/mach-xbox/setup.c
    1.0 03/06/02 19:11:46 andersg@0x63.nu +0 -0
    BitKeeper file /data/dev/kernel/bk/xbox-2.5/arch/i386/mach-xbox/setup.c

  arch/i386/mach-xbox/reboot.c
    1.1 03/06/02 19:11:45 andersg@0x63.nu +50 -0

  arch/i386/mach-xbox/Makefile
    1.1 03/06/02 19:11:45 andersg@0x63.nu +7 -0

  include/asm-i386/timex.h
    1.5 03/06/02 19:11:45 andersg@0x63.nu +9 -5
    Added XBOX subarch

  arch/i386/pci/direct.c
    1.15 03/06/02 19:11:45 andersg@0x63.nu +4 -0
    Added XBOX subarch
    Added a mach-hook for blacklisting pci-devices. The xbox hangs solid
    if you touch some pci devices.

  arch/i386/mach-xbox/reboot.c
    1.0 03/06/02 19:11:45 andersg@0x63.nu +0 -0
    BitKeeper file /data/dev/kernel/bk/xbox-2.5/arch/i386/mach-xbox/reboot.c

  arch/i386/mach-xbox/Makefile
    1.0 03/06/02 19:11:45 andersg@0x63.nu +0 -0
    BitKeeper file /data/dev/kernel/bk/xbox-2.5/arch/i386/mach-xbox/Makefile

  arch/i386/boot/compressed/Makefile
    1.17 03/06/02 19:11:45 andersg@0x63.nu +3 -0
    Added XBOX subarch
    There is some strange interaction when paging is off, that makes 1.1 xboxen
    crash while decompressing kernel, unless decompressor is compiled without
    optimization.

  arch/i386/Makefile
    1.52 03/06/02 19:11:44 andersg@0x63.nu +4 -0
    Added XBOX subarch

  arch/i386/Kconfig
    1.58 03/06/02 19:11:44 andersg@0x63.nu +19 -2
    Added XBOX subarch


 arch/i386/Kconfig                                  |   21 +++++
 arch/i386/Makefile                                 |    4 +
 arch/i386/boot/compressed/Makefile                 |    3 
 arch/i386/mach-xbox/Makefile                       |    7 +
 arch/i386/mach-xbox/reboot.c                       |   50 +++++++++++++
 arch/i386/mach-xbox/setup.c                        |   79 +++++++++++++++++++++
 arch/i386/pci/direct.c                             |    4 +
 include/asm-i386/mach-default/mach_pci_blacklist.h |    6 +
 include/asm-i386/mach-xbox/mach_pci_blacklist.h    |    6 +
 include/asm-i386/timex.h                           |   14 ++-
 10 files changed, 187 insertions(+), 7 deletions(-)


diff -Nru a/arch/i386/Kconfig b/arch/i386/Kconfig
--- a/arch/i386/Kconfig	Mon Jun  2 19:23:26 2003
+++ b/arch/i386/Kconfig	Mon Jun  2 19:23:26 2003
@@ -43,6 +43,22 @@
 	help
 	  Choose this option if your computer is a standard PC or compatible.
 
+config X86_XBOX
+	bool "XBox Gaming System"
+	help
+	  This option is needed to make Linux boot on XBox Gaming Systems.
+	  
+	  The XBox can be considered as a standard PC with a Pentium III Celeron 733 MHz,
+	  IDE harddrive, DVD, Ethernet, USB and graphics. 
+	  
+	  To boot the kernel you need "_romwell", either used as a replacement BIOS (cromwell)
+	  or as a bootloader.
+	  
+	  For more information see http://xbox-linux.sourceforge.net/ 
+	  
+	  If you do not specifically need a kernel for XBOX machine,
+	  say N here otherwise the kernel you build will not be bootable.
+
 config X86_VOYAGER
 	bool "Voyager (NCR)"
 	help
@@ -395,6 +411,7 @@
 	  Otherwise, say N.
 
 config SMP
+	depends on !X86_XBOX
 	bool "Symmetric multi-processing support"
 	---help---
 	  This enables support for systems with more than one CPU. If you have
@@ -1090,7 +1107,7 @@
 
 config MCA
 	bool "MCA support"
-	depends on !(X86_VISWS || X86_VOYAGER)
+	depends on !(X86_VISWS || X86_VOYAGER || X86_XBOX)
 	help
 	  MicroChannel Architecture is found in some IBM PS/2 machines and
 	  laptops.  It is a bus system similar to PCI or ISA. See
@@ -1571,7 +1588,7 @@
 
 config X86_BIOS_REBOOT
 	bool
-	depends on !(X86_VISWS || X86_VOYAGER)
+	depends on !(X86_VISWS || X86_VOYAGER || X86_XBOX)
 	default y
 
 config X86_TRAMPOLINE
diff -Nru a/arch/i386/Makefile b/arch/i386/Makefile
--- a/arch/i386/Makefile	Mon Jun  2 19:23:26 2003
+++ b/arch/i386/Makefile	Mon Jun  2 19:23:26 2003
@@ -53,6 +53,10 @@
 # Default subarch .c files
 mcore-y  := mach-default
 
+# Xbox subarch support
+mflags-$(CONFIG_X86_XBOX)	:= -Iinclude/asm-i386/mach-xbox
+mcore-$(CONFIG_X86_XBOX)	:= mach-xbox
+
 # Voyager subarch support
 mflags-$(CONFIG_X86_VOYAGER)	:= -Iinclude/asm-i386/mach-voyager
 mcore-$(CONFIG_X86_VOYAGER)	:= mach-voyager
diff -Nru a/arch/i386/boot/compressed/Makefile b/arch/i386/boot/compressed/Makefile
--- a/arch/i386/boot/compressed/Makefile	Mon Jun  2 19:23:26 2003
+++ b/arch/i386/boot/compressed/Makefile	Mon Jun  2 19:23:26 2003
@@ -5,6 +5,9 @@
 #
 
 targets		:= vmlinux vmlinux.bin vmlinux.bin.gz head.o misc.o piggy.o
+ifeq ($(CONFIG_X86_XBOX),y)
+CFLAGS_misc.o   := -O0
+endif
 EXTRA_AFLAGS	:= -traditional
 
 LDFLAGS_vmlinux := -Ttext $(IMAGE_OFFSET) -e startup_32
diff -Nru a/arch/i386/mach-xbox/Makefile b/arch/i386/mach-xbox/Makefile
--- /dev/null	Wed Dec 31 16:00:00 1969
+++ b/arch/i386/mach-xbox/Makefile	Mon Jun  2 19:23:26 2003
@@ -0,0 +1,7 @@
+#
+# Makefile for the linux kernel.
+#
+
+EXTRA_CFLAGS	+= -I../kernel
+
+obj-y				:= setup.o reboot.o
diff -Nru a/arch/i386/mach-xbox/reboot.c b/arch/i386/mach-xbox/reboot.c
--- /dev/null	Wed Dec 31 16:00:00 1969
+++ b/arch/i386/mach-xbox/reboot.c	Mon Jun  2 19:23:26 2003
@@ -0,0 +1,50 @@
+/*
+ * arch/i386/mach-xbox/reboot.c 
+ * Olivier Fauchon <olivier.fauchon@free.fr>
+ * Anders Gustafsson <andersg@0x63.nu>
+ *
+ */
+
+#include <asm/io.h>
+
+/* we don't use any of those, but dmi_scan.c needs 'em */
+void (*pm_power_off)(void);
+int reboot_thru_bios;
+
+#define XBOX_SMB_IO_BASE 0xC000
+#define XBOX_SMB_HOST_ADDRESS       (0x4 + XBOX_SMB_IO_BASE)
+#define XBOX_SMB_HOST_COMMAND       (0x8 + XBOX_SMB_IO_BASE)
+#define XBOX_SMB_HOST_DATA          (0x6 + XBOX_SMB_IO_BASE)
+#define XBOX_SMB_GLOBAL_ENABLE       (0x2 + XBOX_SMB_IO_BASE)
+
+#define XBOX_PIC_ADDRESS 0x10
+
+#define SMC_CMD_POWER 0x02
+#define SMC_SUBCMD_POWER_RESET 0x01
+#define SMC_SUBCMD_POWER_CYCLE 0x40
+#define SMC_SUBCMD_POWER_OFF 0x80
+
+
+static void xbox_pic_cmd(u8 command){
+	outw_p(((XBOX_PIC_ADDRESS) << 1),XBOX_SMB_HOST_ADDRESS);
+        outb_p(SMC_CMD_POWER, XBOX_SMB_HOST_COMMAND);
+        outw_p(command, XBOX_SMB_HOST_DATA);
+        outw_p(inw(XBOX_SMB_IO_BASE),XBOX_SMB_IO_BASE);
+        outb_p(0x0a,XBOX_SMB_GLOBAL_ENABLE);
+}
+
+void machine_restart(char * __unused)
+{
+	printk(KERN_INFO "Sending POWER_RESET to XBOX-PIC.\n");
+	xbox_pic_cmd(SMC_SUBCMD_POWER_RESET);  
+}
+
+void machine_power_off(void)
+{
+	printk(KERN_INFO "Sending POWER_OFF to XBOX-PIC.\n");
+	xbox_pic_cmd(SMC_SUBCMD_POWER_OFF);  
+}
+
+void machine_halt(void)
+{
+}
diff -Nru a/arch/i386/mach-xbox/setup.c b/arch/i386/mach-xbox/setup.c
--- /dev/null	Wed Dec 31 16:00:00 1969
+++ b/arch/i386/mach-xbox/setup.c	Mon Jun  2 19:23:26 2003
@@ -0,0 +1,79 @@
+/*
+ *	Machine specific setup for xbox
+ */
+
+#include <linux/config.h>
+#include <linux/smp.h>
+#include <linux/init.h>
+#include <linux/irq.h>
+#include <linux/interrupt.h>
+#include <asm/arch_hooks.h>
+
+/**
+ * pre_intr_init_hook - initialisation prior to setting up interrupt vectors
+ *
+ * Description:
+ *	Perform any necessary interrupt initialisation prior to setting up
+ *	the "ordinary" interrupt call gates.  For legacy reasons, the ISA
+ *	interrupts should be initialised here if the machine emulates a PC
+ *	in any way.
+ **/
+void __init pre_intr_init_hook(void)
+{
+	init_ISA_irqs();
+}
+
+/**
+ * intr_init_hook - post gate setup interrupt initialisation
+ *
+ * Description:
+ *	Fill in any interrupts that may have been left out by the general
+ *	init_IRQ() routine.  interrupts having to do with the machine rather
+ *	than the devices on the I/O bus (like APIC interrupts in intel MP
+ *	systems) are started here.
+ **/
+void __init intr_init_hook(void)
+{
+#ifdef CONFIG_X86_LOCAL_APIC
+	apic_intr_init();
+#endif
+
+}
+
+/**
+ * pre_setup_arch_hook - hook called prior to any setup_arch() execution
+ *
+ * Description:
+ *	generally used to activate any machine specific identification
+ *	routines that may be needed before setup_arch() runs.  On VISWS
+ *	this is used to get the board revision and type.
+ **/
+void __init pre_setup_arch_hook(void)
+{
+}
+
+/**
+ * trap_init_hook - initialise system specific traps
+ *
+ * Description:
+ *	Called as the final act of trap_init().  Used in VISWS to initialise
+ *	the various board specific APIC traps.
+ **/
+void __init trap_init_hook(void)
+{
+}
+
+static struct irqaction irq0  = { timer_interrupt, SA_INTERRUPT, 0, "timer", NULL, NULL};
+
+/**
+ * time_init_hook - do any specific initialisations for the system timer.
+ *
+ * Description:
+ *	Must plug the system timer interrupt source at HZ into the IRQ listed
+ *	in irq_vectors.h:TIMER_IRQ
+ **/
+void __init time_init_hook(void)
+{
+	setup_irq(0, &irq0);
+}
+
diff -Nru a/arch/i386/pci/direct.c b/arch/i386/pci/direct.c
--- a/arch/i386/pci/direct.c	Mon Jun  2 19:23:26 2003
+++ b/arch/i386/pci/direct.c	Mon Jun  2 19:23:26 2003
@@ -4,6 +4,7 @@
 
 #include <linux/pci.h>
 #include <linux/init.h>
+#include "mach_pci_blacklist.h"
 #include "pci.h"
 
 /*
@@ -20,6 +21,9 @@
 	if (!value || (bus > 255) || (dev > 31) || (fn > 7) || (reg > 255))
 		return -EINVAL;
 
+	if (mach_pci_is_blacklisted(bus,dev,fn))
+		return -EINVAL;
+	
 	spin_lock_irqsave(&pci_config_lock, flags);
 
 	outl(PCI_CONF1_ADDRESS(bus, dev, fn, reg), 0xCF8);
diff -Nru a/include/asm-i386/mach-default/mach_pci_blacklist.h b/include/asm-i386/mach-default/mach_pci_blacklist.h
--- /dev/null	Wed Dec 31 16:00:00 1969
+++ b/include/asm-i386/mach-default/mach_pci_blacklist.h	Mon Jun  2 19:23:26 2003
@@ -0,0 +1,6 @@
+#ifndef __ASM_MACH_PCI_BLACKLIST_H
+#define __ASM_MACH_PCI_BLACKLIST_H
+
+#define mach_pci_is_blacklisted(bus,dev,fn) 0
+
+#endif
diff -Nru a/include/asm-i386/mach-xbox/mach_pci_blacklist.h b/include/asm-i386/mach-xbox/mach_pci_blacklist.h
--- /dev/null	Wed Dec 31 16:00:00 1969
+++ b/include/asm-i386/mach-xbox/mach_pci_blacklist.h	Mon Jun  2 19:23:26 2003
@@ -0,0 +1,6 @@
+#ifndef __ASM_MACH_PCI_BLACKLIST_H
+#define __ASM_MACH_PCI_BLACKLIST_H
+
+#define mach_pci_is_blacklisted(bus,dev,fn) ( (bus>1) || (bus&&(dev||fn)) || ((bus==0 && dev==0) && ((fn==1)||(fn==2))) )
+
+#endif
diff -Nru a/include/asm-i386/timex.h b/include/asm-i386/timex.h
--- a/include/asm-i386/timex.h	Mon Jun  2 19:23:26 2003
+++ b/include/asm-i386/timex.h	Mon Jun  2 19:23:26 2003
@@ -12,11 +12,15 @@
 #ifdef CONFIG_X86_PC9800
    extern int CLOCK_TICK_RATE;
 #else
-#ifdef CONFIG_MELAN
-#  define CLOCK_TICK_RATE 1189200 /* AMD Elan has different frequency! */
-#else
-#  define CLOCK_TICK_RATE 1193180 /* Underlying HZ */
-#endif
+#  ifdef CONFIG_MELAN
+#    define CLOCK_TICK_RATE 1189200 /* AMD Elan has different frequency! */
+#  else
+#    ifdef CONFIG_X86_XBOX
+#      define CLOCK_TICK_RATE 1124998 /* so has the Xbox */
+#    else 
+#      define CLOCK_TICK_RATE 1193180 /* Underlying HZ */
+#    endif
+#  endif
 #endif
 
 #define CLOCK_TICK_FACTOR	20	/* Factor of both 1000000 and CLOCK_TICK_RATE */

===================================================================


This BitKeeper patch contains the following changesets:
+
## Wrapped with uu ##


M(R!5<V5R.@EA;F1E<G-G"B,@2&]S=#H),'@V,RYN=0HC(%)O;W0Z"2]D871A
M+V1E=B]K97)N96PO8FLO>&)O>"TR+C4*"B,@4&%T8V@@=F5R<SH),2XS"B,@
M4&%T8V@@='EP93H)4D5'54Q!4@H*/3T@0VAA;F=E4V5T(#T]"G1O<G9A;&1S
M0&%T:&QO;BYT<F%N<VUE=&$N8V]M?$-H86YG95-E='PR,# R,#(P-3$W,S U
M-GPQ-C T-WQC,60Q,6$T,65D,#(T.#8T"G1O<G9A;&1S0'!E;F=U:6XN=')A
M;G-M971A+F-O;7Q#:&%N9V53971\,C P,S U,S Q.3,Y,S)\-#$P,C4*1" Q
M+C$S,C<@,#,O,#8O,#(@,3DZ,3$Z-38K,#(Z,# @86YD97)S9T P>#8S+FYU
M("LQ," M, I"('1O<G9A;&1S0&%T:&QO;BYT<F%N<VUE=&$N8V]M?$-H86YG
M95-E='PR,# R,#(P-3$W,S U-GPQ-C T-WQC,60Q,6$T,65D,#(T.#8T"D,*
M8R!!9&1E9"!80D]8('-U8F%R8V@*2R S-C X,0I0($-H86YG95-E= HM+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2T*
M"C!A, H^(&%N9&5R<V= ,'@V,RYN=7QI;F-L=61E+V%S;2UI,S@V+VUA8V@M
M>&)O>"]M86-H7W!C:5]B;&%C:VQI<W0N:'PR,# S,#8P,C$W,3$T-GPS,S$T
M,'PR965C9#4T8F8U,S1E(&%N9&5R<V= ,'@V,RYN=7QI;F-L=61E+V%S;2UI
M,S@V+VUA8V@M>&)O>"]M86-H7W!C:5]B;&%C:VQI<W0N:'PR,# S,#8P,C$W
M,3$T-WPQ-34Q,0H^(&%N9&5R<V= ,'@V,RYN=7QA<F-H+VDS.#8O;6%C:"UX
M8F]X+TUA:V5F:6QE?#(P,#,P-C R,3<Q,30U?#$P.34T?#,X.6%F-SDY.#,X
M83$U,B!A;F1E<G-G0#!X-C,N;G5\87)C:"]I,S@V+VUA8V@M>&)O>"]-86ME
M9FEL97PR,# S,#8P,C$W,3$T-GPP-S(Q,@H^('1O<G9A;&1S0&%T:&QO;BYT
M<F%N<VUE=&$N8V]M?&%R8V@O:3,X-B]B;V]T+V-O;7!R97-S960O36%K969I
M;&5\,C P,C R,#4Q-S0P,C!\,30R.#E\965D,C0S8S-F-#5B968V(&%N9&5R
M<V= ,'@V,RYN=7QA<F-H+VDS.#8O8F]O="]C;VUP<F5S<V5D+TUA:V5F:6QE
M?#(P,#,P-C R,3<Q,30U?#4W-#8Y"CX@=&]R=F%L9'- 871H;&]N+G1R86YS
M;65T82YC;VU\87)C:"]I,S@V+TUA:V5F:6QE?#(P,#(P,C U,3<T,#(P?#$X
M-S$P?#%B.&%A,68P8S0P83%D8F8@86YD97)S9T P>#8S+FYU?&%R8V@O:3,X
M-B]-86ME9FEL97PR,# S,#8P,C$W,3$T-'PR,C4Y- H^(&%N9&5R<V= ,'@V
M,RYN=7QA<F-H+VDS.#8O;6%C:"UX8F]X+W-E='5P+F-\,C P,S V,#(Q-S$Q
M-#9\,#,Q-C5\,C%A,S<P,34U9&9F-S$R(&%N9&5R<V= ,'@V,RYN=7QA<F-H
M+VDS.#8O;6%C:"UX8F]X+W-E='5P+F-\,C P,S V,#(Q-S$Q-#=\,S4V-#@*
M/B!Z:7!P96Q ;&EN=7@M;38X:RYO<F=;=&]R=F%L9'-=?&%R8V@O:3,X-B]+
M8V]N9FEG?#(P,#(Q,#,P,#0S,C$X?#(T-C@X?#8Q,C,Q.#!A8CDQ-3<V,&,@
M86YD97)S9T P>#8S+FYU?&%R8V@O:3,X-B]+8V]N9FEG?#(P,#,P-C R,3<Q
M,30T?#$T,C$W"CX@=&]R=F%L9'- 871H;&]N+G1R86YS;65T82YC;VU\:6YC
M;'5D92]A<VTM:3,X-B]T:6UE>"YH?#(P,#(P,C U,3<S.30T?#8S.#8R?&%A
M-69D,6%F.3%F934P9C<@86YD97)S9T P>#8S+FYU?&EN8VQU9&4O87-M+6DS
M.#8O=&EM97@N:'PR,# S,#8P,C$W,3$T-7PV,34V- H^(&%N9&5R<V= ,'@V
M,RYN=7QA<F-H+VDS.#8O;6%C:"UX8F]X+W)E8F]O="YC?#(P,#,P-C R,3<Q
M,30U?#4W,3 S?#0P8S,Y9F1B.3AE96-A96$@86YD97)S9T P>#8S+FYU?&%R
M8V@O:3,X-B]M86-H+7AB;W@O<F5B;V]T+F-\,C P,S V,#(Q-S$Q-#9\,S,Y
M-#D*/B!M;V-H96Q <V5G9F%U;'0N;W-D;"YO<F=\87)C:"]I,S@V+VME<FYE
M;"]P8VDO9&ER96-T+F-\,C P,C T,38Q-3 X,S!\-#0W,S)\,S@W8S4W9# Y
M,&%D-#@X."!A;F1E<G-G0#!X-C,N;G5\87)C:"]I,S@V+W!C:2]D:7)E8W0N
M8WPR,# S,#8P,C$W,3$T-7PU-#,Q,@H^(&%N9&5R<V= ,'@V,RYN=7QI;F-L
M=61E+V%S;2UI,S@V+VUA8V@M9&5F875L="]M86-H7W!C:5]B;&%C:VQI<W0N
M:'PR,# S,#8P,C$W,3$T-GPU,3DQ-7QC,#AF-&,W,&,Q-#5D83 X(&%N9&5R
M<V= ,'@V,RYN=7QI;F-L=61E+V%S;2UI,S@V+VUA8V@M9&5F875L="]M86-H
M7W!C:5]B;&%C:VQI<W0N:'PR,# S,#8P,C$W,3$T-WPQ,#(S,@H*/3T@87)C
M:"]I,S@V+VUA8V@M>&)O>"]-86ME9FEL92 ]/0I.97<@9FEL93H@87)C:"]I
M,S@V+VUA8V@M>&)O>"]-86ME9FEL90I6(#0*"F%N9&5R<V= ,'@V,RYN=7QA
M<F-H+VDS.#8O;6%C:"UX8F]X+TUA:V5F:6QE?#(P,#,P-C R,3<Q,30U?#$P
M.34T?#,X.6%F-SDY.#,X83$U,@I$(#$N," P,R\P-B\P,B Q.3HQ,3HT-2LP
M,CHP,"!A;F1E<G-G0#!X-C,N;G4@*S @+3 *0B!T;W)V86QD<T!A=&AL;VXN
M=')A;G-M971A+F-O;7Q#:&%N9V53971\,C P,C R,#4Q-S,P-39\,38P-#=\
M8S%D,3%A-#%E9# R-#@V- IC($)I=$ME97!E<B!F:6QE("]D871A+V1E=B]K
M97)N96PO8FLO>&)O>"TR+C4O87)C:"]I,S@V+VUA8V@M>&)O>"]-86ME9FEL
M90I+(#$P.34T"E @87)C:"]I,S@V+VUA8V@M>&)O>"]-86ME9FEL90I2(#,X
M.6%F-SDY.#,X83$U,@I8(#!X.#(Q"BTM+2TM+2TM+2TM+2TM+2TM+2TM+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+0H*"F%N9&5R<V= ,'@V,RYN=7QA
M<F-H+VDS.#8O;6%C:"UX8F]X+TUA:V5F:6QE?#(P,#,P-C R,3<Q,30U?#$P
M.34T?#,X.6%F-SDY.#,X83$U,@I$(#$N,2 P,R\P-B\P,B Q.3HQ,3HT-2LP
M,CHP,"!A;F1E<G-G0#!X-C,N;G4@*S<@+3 *0B!T;W)V86QD<T!A=&AL;VXN
M=')A;G-M971A+F-O;7Q#:&%N9V53971\,C P,C R,#4Q-S,P-39\,38P-#=\
M8S%D,3%A-#%E9# R-#@V- I#"D8@,0I+(#<R,3(*3R M<G<M<G<M<BTM"E @
M87)C:"]I,S@V+VUA8V@M>&)O>"]-86ME9FEL90HM+2TM+2TM+2TM+2TM+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2T*"DDP(#<*(PHC($UA
M:V5F:6QE(&9O<B!T:&4@;&EN=7@@:V5R;F5L+@HC"EP*15A44D%?0T9,04=3
M"2L]("U)+BXO:V5R;F5L"EP*;V)J+7D)"0D).CT@<V5T=7 N;R!R96)O;W0N
M;PH*/3T@87)C:"]I,S@V+VUA8V@M>&)O>"]R96)O;W0N8R ]/0I.97<@9FEL
M93H@87)C:"]I,S@V+VUA8V@M>&)O>"]R96)O;W0N8PI6(#0*"F%N9&5R<V= 
M,'@V,RYN=7QA<F-H+VDS.#8O;6%C:"UX8F]X+W)E8F]O="YC?#(P,#,P-C R
M,3<Q,30U?#4W,3 S?#0P8S,Y9F1B.3AE96-A96$*1" Q+C @,#,O,#8O,#(@
M,3DZ,3$Z-#4K,#(Z,# @86YD97)S9T P>#8S+FYU("LP("TP"D(@=&]R=F%L
M9'- 871H;&]N+G1R86YS;65T82YC;VU\0VAA;F=E4V5T?#(P,#(P,C U,3<S
M,#4V?#$V,#0W?&,Q9#$Q830Q960P,C0X-C0*8R!":71+965P97(@9FEL92 O
M9&%T82]D978O:V5R;F5L+V)K+WAB;W@M,BXU+V%R8V@O:3,X-B]M86-H+7AB
M;W@O<F5B;V]T+F,*2R U-S$P,PI0(&%R8V@O:3,X-B]M86-H+7AB;W@O<F5B
M;V]T+F,*4B T,&,S.69D8CDX965C865A"E@@,'@X,C$*+2TM+2TM+2TM+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM"@H*86YD97)S
M9T P>#8S+FYU?&%R8V@O:3,X-B]M86-H+7AB;W@O<F5B;V]T+F-\,C P,S V
M,#(Q-S$Q-#5\-3<Q,#-\-#!C,SEF9&(Y.&5E8V%E80I$(#$N,2 P,R\P-B\P
M,B Q.3HQ,3HT-2LP,CHP,"!A;F1E<G-G0#!X-C,N;G4@*S4P("TP"D(@=&]R
M=F%L9'- 871H;&]N+G1R86YS;65T82YC;VU\0VAA;F=E4V5T?#(P,#(P,C U
M,3<S,#4V?#$V,#0W?&,Q9#$Q830Q960P,C0X-C0*0PI&(#$*2R S,SDT.0I/
M("UR=RUR=RUR+2T*4"!A<F-H+VDS.#8O;6%C:"UX8F]X+W)E8F]O="YC"BTM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM
M+0H*23 @-3 *+RH*("H@87)C:"]I,S@V+VUA8V@M>&)O>"]R96)O;W0N8R *
M("H@3VQI=FEE<B!&875C:&]N(#QO;&EV:65R+F9A=6-H;VY 9G)E92YF<CX*
M("H@06YD97)S($=U<W1A9G-S;VX@/&%N9&5R<V= ,'@V,RYN=3X*("H*("HO
M"EP*(VEN8VQU9&4@/&%S;2]I;RYH/@I<"B\J('=E(&1O;B=T('5S92!A;GD@
M;V8@=&AO<V4L(&)U="!D;6E?<V-A;BYC(&YE961S("=E;2 J+PIV;VED("@J
M<&U?<&]W97)?;V9F*2AV;VED*3L*:6YT(')E8F]O=%]T:')U7V)I;W,["EP*
M(V1E9FEN92!80D]87U--0E])3U]"05-%(#!X0S P, HC9&5F:6YE(%A"3UA?
M4TU"7TA/4U1?041$4D534R @(" @(" H,'@T("L@6$)/6%]334)?24]?0D%3
M12D*(V1E9FEN92!80D]87U--0E](3U-47T-/34U!3D0@(" @(" @*#!X." K
M(%A"3UA?4TU"7TE/7T)!4T4I"B-D969I;F4@6$)/6%]334)?2$]35%]$051!
M(" @(" @(" @("@P>#8@*R!80D]87U--0E])3U]"05-%*0HC9&5F:6YE(%A"
M3UA?4TU"7T=,3T)!3%]%3D%"3$4@(" @(" @*#!X,B K(%A"3UA?4TU"7TE/
M7T)!4T4I"EP*(V1E9FEN92!80D]87U!)0U]!1$1215-3(#!X,3 *7 HC9&5F
M:6YE(%--0U]#341?4$]715(@,'@P,@HC9&5F:6YE(%--0U]354)#341?4$]7
M15)?4D53150@,'@P,0HC9&5F:6YE(%--0U]354)#341?4$]715)?0UE#3$4@
M,'@T, HC9&5F:6YE(%--0U]354)#341?4$]715)?3T9&(#!X.# *7 I<"G-T
M871I8R!V;VED('AB;WA?<&EC7V-M9"AU."!C;VUM86YD*7L*"6]U='=?<"@H
M*%A"3UA?4$E#7T%$1%)%4U,I(#P\(#$I+%A"3UA?4TU"7TA/4U1?041$4D53
M4RD["B @(" @(" @;W5T8E]P*%--0U]#341?4$]715(L(%A"3UA?4TU"7TA/
M4U1?0T]-34%.1"D["B @(" @(" @;W5T=U]P*&-O;6UA;F0L(%A"3UA?4TU"
M7TA/4U1?1$%402D["B @(" @(" @;W5T=U]P*&EN=RA80D]87U--0E])3U]"
M05-%*2Q80D]87U--0E])3U]"05-%*3L*(" @(" @("!O=71B7W H,'@P82Q8
M0D]87U--0E]'3$]"04Q?14Y!0DQ%*3L*?0I<"G9O:60@;6%C:&EN95]R97-T
M87)T*&-H87(@*B!?7W5N=7-E9"D*>PH)<')I;G1K*$M%4DY?24Y&3R B4V5N
M9&EN9R!03U=%4E]215-%5"!T;R!80D]8+5!)0RY<;B(I.PH)>&)O>%]P:6-?
M8VUD*%--0U]354)#341?4$]715)?4D53150I.R @"GT*7 IV;VED(&UA8VAI
M;F5?<&]W97)?;V9F*'9O:60I"GL*"7!R:6YT:RA+15).7TE.1D\@(E-E;F1I
M;F<@4$]715)?3T9&('1O(%A"3U@M4$E#+EQN(BD["@EX8F]X7W!I8U]C;60H
M4TU#7U-50D--1%]03U=%4E]/1D8I.R @"GT*7 IV;VED(&UA8VAI;F5?:&%L
M="AV;VED*0I["GT*"CT](&%R8V@O:3,X-B]M86-H+7AB;W@O<V5T=7 N8R ]
M/0I.97<@9FEL93H@87)C:"]I,S@V+VUA8V@M>&)O>"]S971U<"YC"E8@- H*
M86YD97)S9T P>#8S+FYU?&%R8V@O:3,X-B]M86-H+7AB;W@O<V5T=7 N8WPR
M,# S,#8P,C$W,3$T-GPP,S$V-7PR,6$S-S Q-35D9F8W,3(*1" Q+C @,#,O
M,#8O,#(@,3DZ,3$Z-#8K,#(Z,# @86YD97)S9T P>#8S+FYU("LP("TP"D(@
M=&]R=F%L9'- 871H;&]N+G1R86YS;65T82YC;VU\0VAA;F=E4V5T?#(P,#(P
M,C U,3<S,#4V?#$V,#0W?&,Q9#$Q830Q960P,C0X-C0*8R!":71+965P97(@
M9FEL92 O9&%T82]D978O:V5R;F5L+V)K+WAB;W@M,BXU+V%R8V@O:3,X-B]M
M86-H+7AB;W@O<V5T=7 N8PI+(#,Q-C4*4"!A<F-H+VDS.#8O;6%C:"UX8F]X
M+W-E='5P+F,*4B R,6$S-S Q-35D9F8W,3(*6" P>#@R,0HM+2TM+2TM+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2T*"@IA;F1E
M<G-G0#!X-C,N;G5\87)C:"]I,S@V+VUA8V@M>&)O>"]S971U<"YC?#(P,#,P
M-C R,3<Q,30V?# S,38U?#(Q83,W,#$U-61F9C<Q,@I$(#$N,2 P,R\P-B\P
M,B Q.3HQ,3HT-BLP,CHP,"!A;F1E<G-G0#!X-C,N;G4@*S<Y("TP"D(@=&]R
M=F%L9'- 871H;&]N+G1R86YS;65T82YC;VU\0VAA;F=E4V5T?#(P,#(P,C U
M,3<S,#4V?#$V,#0W?&,Q9#$Q830Q960P,C0X-C0*0PI&(#$*2R S-38T. I/
M("UR=RUR=RUR+2T*4"!A<F-H+VDS.#8O;6%C:"UX8F]X+W-E='5P+F,*+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM
M"@I)," W.0HO*@H@*@E-86-H:6YE('-P96-I9FEC('-E='5P(&9O<B!X8F]X
M"B J+PI<"B-I;F-L=61E(#QL:6YU>"]C;VYF:6<N:#X*(VEN8VQU9&4@/&QI
M;G5X+W-M<"YH/@HC:6YC;'5D92 \;&EN=7@O:6YI="YH/@HC:6YC;'5D92 \
M;&EN=7@O:7)Q+F@^"B-I;F-L=61E(#QL:6YU>"]I;G1E<G)U<'0N:#X*(VEN
M8VQU9&4@/&%S;2]A<F-H7VAO;VMS+F@^"EP*+RHJ"B J('!R95]I;G1R7VEN
M:71?:&]O:R M(&EN:71I86QI<V%T:6]N('!R:6]R('1O('-E='1I;F<@=7 @
M:6YT97)R=7!T('9E8W1O<G,*("H*("H@1&5S8W)I<'1I;VXZ"B J"5!E<F9O
M<FT@86YY(&YE8V5S<V%R>2!I;G1E<G)U<'0@:6YI=&EA;&ES871I;VX@<')I
M;W(@=&\@<V5T=&EN9R!U< H@*@ET:&4@(F]R9&EN87)Y(B!I;G1E<G)U<'0@
M8V%L;"!G871E<RX@($9O<B!L96=A8WD@<F5A<V]N<RP@=&AE($E300H@*@EI
M;G1E<G)U<'1S('-H;W5L9"!B92!I;FET:6%L:7-E9"!H97)E(&EF('1H92!M
M86-H:6YE(&5M=6QA=&5S(&$@4$,*("H):6X@86YY('=A>2X*("HJ+PIV;VED
M(%]?:6YI="!P<F5?:6YT<E]I;FET7VAO;VLH=F]I9"D*>PH):6YI=%])4T%?
M:7)Q<R@I.PI]"EP*+RHJ"B J(&EN=')?:6YI=%]H;V]K("T@<&]S="!G871E
M('-E='5P(&EN=&5R<G5P="!I;FET:6%L:7-A=&EO;@H@*@H@*B!$97-C<FEP
M=&EO;CH*("H)1FEL;"!I;B!A;GD@:6YT97)R=7!T<R!T:&%T(&UA>2!H879E
M(&)E96X@;&5F="!O=70@8GD@=&AE(&=E;F5R86P*("H):6YI=%])4E$H*2!R
M;W5T:6YE+B @:6YT97)R=7!T<R!H879I;F<@=&\@9&\@=VET:"!T:&4@;6%C
M:&EN92!R871H97(*("H)=&AA;B!T:&4@9&5V:6-E<R!O;B!T:&4@22]/(&)U
M<R H;&EK92!!4$E#(&EN=&5R<G5P=',@:6X@:6YT96P@35 *("H)<WES=&5M
M<RD@87)E('-T87)T960@:&5R92X*("HJ+PIV;VED(%]?:6YI="!I;G1R7VEN
M:71?:&]O:RAV;VED*0I["B-I9F1E9B!#3TY&24=?6#@V7TQ/0T%,7T%024,*
M"6%P:6-?:6YT<E]I;FET*"D["B-E;F1I9@I<"GT*7 HO*BH*("H@<')E7W-E
M='5P7V%R8VA?:&]O:R M(&AO;VL@8V%L;&5D('!R:6]R('1O(&%N>2!S971U
M<%]A<F-H*"D@97AE8W5T:6]N"B J"B J($1E<V-R:7!T:6]N.@H@*@EG96YE
M<F%L;'D@=7-E9"!T;R!A8W1I=F%T92!A;GD@;6%C:&EN92!S<&5C:69I8R!I
M9&5N=&EF:6-A=&EO;@H@*@ER;W5T:6YE<R!T:&%T(&UA>2!B92!N965D960@
M8F5F;W)E('-E='5P7V%R8V@H*2!R=6YS+B @3VX@5DE35U,*("H)=&AI<R!I
M<R!U<V5D('1O(&=E="!T:&4@8F]A<F0@<F5V:7-I;VX@86YD('1Y<&4N"B J
M*B\*=F]I9"!?7VEN:70@<')E7W-E='5P7V%R8VA?:&]O:RAV;VED*0I["GT*
M7 HO*BH*("H@=')A<%]I;FET7VAO;VL@+2!I;FET:6%L:7-E('-Y<W1E;2!S
M<&5C:69I8R!T<F%P<PH@*@H@*B!$97-C<FEP=&EO;CH*("H)0V%L;&5D(&%S
M('1H92!F:6YA;"!A8W0@;V8@=')A<%]I;FET*"DN("!5<V5D(&EN(%9)4U=3
M('1O(&EN:71I86QI<V4*("H)=&AE('9A<FEO=7,@8F]A<F0@<W!E8VEF:6,@
M05!)0R!T<F%P<RX*("HJ+PIV;VED(%]?:6YI="!T<F%P7VEN:71?:&]O:RAV
M;VED*0I["GT*7 IS=&%T:6,@<W1R=6-T(&ER<6%C=&EO;B!I<G$P(" ]('L@
M=&EM97)?:6YT97)R=7!T+"!305])3E1%4E)54%0L(# L(")T:6UE<B(L($Y5
M3$PL($Y53$Q].PI<"B\J*@H@*B!T:6UE7VEN:71?:&]O:R M(&1O(&%N>2!S
M<&5C:69I8R!I;FET:6%L:7-A=&EO;G,@9F]R('1H92!S>7-T96T@=&EM97(N
M"B J"B J($1E<V-R:7!T:6]N.@H@*@E-=7-T('!L=6<@=&AE('-Y<W1E;2!T
M:6UE<B!I;G1E<G)U<'0@<V]U<F-E(&%T($A:(&EN=&\@=&AE($E242!L:7-T
M960*("H):6X@:7)Q7W9E8W1O<G,N:#I424U%4E])4E$*("HJ+PIV;VED(%]?
M:6YI="!T:6UE7VEN:71?:&]O:RAV;VED*0I["@ES971U<%]I<G$H,"P@)FER
M<3 I.PI]"EP*"CT](&EN8VQU9&4O87-M+6DS.#8O;6%C:"UD969A=6QT+VUA
M8VA?<&-I7V)L86-K;&ES="YH(#T]"DYE=R!F:6QE.B!I;F-L=61E+V%S;2UI
M,S@V+VUA8V@M9&5F875L="]M86-H7W!C:5]B;&%C:VQI<W0N: I6(#0*"F%N
M9&5R<V= ,'@V,RYN=7QI;F-L=61E+V%S;2UI,S@V+VUA8V@M9&5F875L="]M
M86-H7W!C:5]B;&%C:VQI<W0N:'PR,# S,#8P,C$W,3$T-GPU,3DQ-7QC,#AF
M-&,W,&,Q-#5D83 X"D0@,2XP(# S+S V+S R(#$Y.C$Q.C0V*S R.C P(&%N
M9&5R<V= ,'@V,RYN=2 K," M, I"('1O<G9A;&1S0&%T:&QO;BYT<F%N<VUE
M=&$N8V]M?$-H86YG95-E='PR,# R,#(P-3$W,S U-GPQ-C T-WQC,60Q,6$T
M,65D,#(T.#8T"F,@0FET2V5E<&5R(&9I;&4@+V1A=&$O9&5V+VME<FYE;"]B
M:R]X8F]X+3(N-2]I;F-L=61E+V%S;2UI,S@V+VUA8V@M9&5F875L="]M86-H
M7W!C:5]B;&%C:VQI<W0N: I+(#4Q.3$U"E @:6YC;'5D92]A<VTM:3,X-B]M
M86-H+61E9F%U;'0O;6%C:%]P8VE?8FQA8VML:7-T+F@*4B!C,#AF-&,W,&,Q
M-#5D83 X"E@@,'@X,C$*+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM"@H*86YD97)S9T P>#8S+FYU?&EN8VQU9&4O
M87-M+6DS.#8O;6%C:"UD969A=6QT+VUA8VA?<&-I7V)L86-K;&ES="YH?#(P
M,#,P-C R,3<Q,30V?#4Q.3$U?&,P.&8T8S<P8S$T-61A,#@*1" Q+C$@,#,O
M,#8O,#(@,3DZ,3$Z-#8K,#(Z,# @86YD97)S9T P>#8S+FYU("LV("TP"D(@
M=&]R=F%L9'- 871H;&]N+G1R86YS;65T82YC;VU\0VAA;F=E4V5T?#(P,#(P
M,C U,3<S,#4V?#$V,#0W?&,Q9#$Q830Q960P,C0X-C0*0PI&(#$*2R Q,#(S
M,@I/("UR=RUR=RUR+2T*4"!I;F-L=61E+V%S;2UI,S@V+VUA8V@M9&5F875L
M="]M86-H7W!C:5]B;&%C:VQI<W0N: HM+2TM+2TM+2TM+2TM+2TM+2TM+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2T*"DDP(#8*(VEF;F1E9B!?7T%3
M35]-04-(7U!#25]"3$%#2TQ)4U1?2 HC9&5F:6YE(%]?05--7TU!0TA?4$-)
M7T),04-+3$E35%]("EP*(V1E9FEN92!M86-H7W!C:5]I<U]B;&%C:VQI<W1E
M9"AB=7,L9&5V+&9N*2 P"EP*(V5N9&EF"@H]/2!I;F-L=61E+V%S;2UI,S@V
M+VUA8V@M>&)O>"]M86-H7W!C:5]B;&%C:VQI<W0N:" ]/0I.97<@9FEL93H@
M:6YC;'5D92]A<VTM:3,X-B]M86-H+7AB;W@O;6%C:%]P8VE?8FQA8VML:7-T
M+F@*5B T"@IA;F1E<G-G0#!X-C,N;G5\:6YC;'5D92]A<VTM:3,X-B]M86-H
M+7AB;W@O;6%C:%]P8VE?8FQA8VML:7-T+FA\,C P,S V,#(Q-S$Q-#9\,S,Q
M-#!\,F5E8V0U-&)F-3,T90I$(#$N," P,R\P-B\P,B Q.3HQ,3HT-BLP,CHP
M,"!A;F1E<G-G0#!X-C,N;G4@*S @+3 *0B!T;W)V86QD<T!A=&AL;VXN=')A
M;G-M971A+F-O;7Q#:&%N9V53971\,C P,C R,#4Q-S,P-39\,38P-#=\8S%D
M,3%A-#%E9# R-#@V- IC($)I=$ME97!E<B!F:6QE("]D871A+V1E=B]K97)N
M96PO8FLO>&)O>"TR+C4O:6YC;'5D92]A<VTM:3,X-B]M86-H+7AB;W@O;6%C
M:%]P8VE?8FQA8VML:7-T+F@*2R S,S$T, I0(&EN8VQU9&4O87-M+6DS.#8O
M;6%C:"UX8F]X+VUA8VA?<&-I7V)L86-K;&ES="YH"E(@,F5E8V0U-&)F-3,T
M90I8(#!X.#(Q"BTM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM
M+2TM+2TM+2TM+2TM+0H*"F%N9&5R<V= ,'@V,RYN=7QI;F-L=61E+V%S;2UI
M,S@V+VUA8V@M>&)O>"]M86-H7W!C:5]B;&%C:VQI<W0N:'PR,# S,#8P,C$W
M,3$T-GPS,S$T,'PR965C9#4T8F8U,S1E"D0@,2XQ(# S+S V+S R(#$Y.C$Q
M.C0V*S R.C P(&%N9&5R<V= ,'@V,RYN=2 K-B M, I"('1O<G9A;&1S0&%T
M:&QO;BYT<F%N<VUE=&$N8V]M?$-H86YG95-E='PR,# R,#(P-3$W,S U-GPQ
M-C T-WQC,60Q,6$T,65D,#(T.#8T"D,*1B Q"DL@,34U,3$*3R M<G<M<G<M
M<BTM"E @:6YC;'5D92]A<VTM:3,X-B]M86-H+7AB;W@O;6%C:%]P8VE?8FQA
M8VML:7-T+F@*+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM
M+2TM+2TM+2TM+2TM"@I)," V"B-I9FYD968@7U]!4TU?34%#2%]00TE?0DQ!
M0TM,25-47T@*(V1E9FEN92!?7T%335]-04-(7U!#25]"3$%#2TQ)4U1?2 I<
M"B-D969I;F4@;6%C:%]P8VE?:7-?8FQA8VML:7-T960H8G5S+&1E=BQF;BD@
M*" H8G5S/C$I('Q\("AB=7,F)BAD979\?&9N*2D@?'P@*"AB=7,]/3 @)B8@
M9&5V/3TP*2 F)B H*&9N/3TQ*7Q\*&9N/3TR*2DI("D*7 HC96YD:68*"CT]
M(&%R8V@O:3,X-B]P8VDO9&ER96-T+F,@/3T*;6]C:&5L0'-E9V9A=6QT+F]S
M9&PN;W)G?&%R8V@O:3,X-B]K97)N96PO<&-I+V1I<F5C="YC?#(P,#(P-#$V
M,34P.#,P?#0T-S,R?#,X-V,U-V0P.3!A9#0X.#@*9W)E9T!K<F]A:"YC;VU;
M9W)E9UU\87)C:"]I,S@V+W!C:2]D:7)E8W0N8WPR,# S,#(R,#(R,C,S-7PT
M-C,U- I$(#$N,34@,#,O,#8O,#(@,3DZ,3$Z-#4K,#(Z,# @86YD97)S9T P
M>#8S+FYU("LT("TP"D(@=&]R=F%L9'- 871H;&]N+G1R86YS;65T82YC;VU\
M0VAA;F=E4V5T?#(P,#(P,C U,3<S,#4V?#$V,#0W?&,Q9#$Q830Q960P,C0X
M-C0*0PIC($%D9&5D(%A"3U@@<W5B87)C: IC($%D9&5D(&$@;6%C:"UH;V]K
M(&9O<B!B;&%C:VQI<W1I;F<@<&-I+61E=FEC97,N(%1H92!X8F]X(&AA;F=S
M('-O;&ED"F,@:68@>6]U('1O=6-H('-O;64@<&-I(&1E=FEC97,N"DL@-30S
M,3(*3R M<G<M<G<M<BTM"E @87)C:"]I,S@V+W!C:2]D:7)E8W0N8PHM+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2T*
M"DDV(#$*(VEN8VQU9&4@(FUA8VA?<&-I7V)L86-K;&ES="YH(@I),C(@,PH)
M:68@*&UA8VA?<&-I7VES7V)L86-K;&ES=&5D*&)U<RQD978L9FXI*0H)"7)E
M='5R;B M14E.5D%,.PH)"@H]/2!A<F-H+VDS.#8O36%K969I;&4@/3T*=&]R
M=F%L9'- 871H;&]N+G1R86YS;65T82YC;VU\87)C:"]I,S@V+TUA:V5F:6QE
M?#(P,#(P,C U,3<T,#(P?#$X-S$P?#%B.&%A,68P8S0P83%D8F8*86MP;4!D
M:6=E;RYC;VU;=&]R=F%L9'-=?&%R8V@O:3,X-B]-86ME9FEL97PR,# S,#4P
M.# U,3,Q-7PQ,CDV.0I$(#$N-3(@,#,O,#8O,#(@,3DZ,3$Z-#0K,#(Z,# @
M86YD97)S9T P>#8S+FYU("LT("TP"D(@=&]R=F%L9'- 871H;&]N+G1R86YS
M;65T82YC;VU\0VAA;F=E4V5T?#(P,#(P,C U,3<S,#4V?#$V,#0W?&,Q9#$Q
M830Q960P,C0X-C0*0PIC($%D9&5D(%A"3U@@<W5B87)C: I+(#(R-3DT"D\@
M+7)W+7)W+7(M+0I0(&%R8V@O:3,X-B]-86ME9FEL90HM+2TM+2TM+2TM+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2T*"DDU-2 T"B,@
M6&)O>"!S=6)A<F-H('-U<'!O<G0*;69L86=S+20H0T].1DE'7U@X-E]80D]8
M*0DZ/2 M26EN8VQU9&4O87-M+6DS.#8O;6%C:"UX8F]X"FUC;W)E+20H0T].
M1DE'7U@X-E]80D]8*0DZ/2!M86-H+7AB;W@*7 H*/3T@87)C:"]I,S@V+V)O
M;W0O8V]M<')E<W-E9"]-86ME9FEL92 ]/0IT;W)V86QD<T!A=&AL;VXN=')A
M;G-M971A+F-O;7QA<F-H+VDS.#8O8F]O="]C;VUP<F5S<V5D+TUA:V5F:6QE
M?#(P,#(P,C U,3<T,#(P?#$T,C@Y?&5E9#(T,V,S9C0U8F5F-@IS86U ;6%R
M<RYR879N8F]R9RYO<F=\87)C:"]I,S@V+V)O;W0O8V]M<')E<W-E9"]-86ME
M9FEL97PR,# S,#,P.3(Q-#<T,7PU,S0R-PI$(#$N,3<@,#,O,#8O,#(@,3DZ
M,3$Z-#4K,#(Z,# @86YD97)S9T P>#8S+FYU("LS("TP"D(@=&]R=F%L9'- 
M871H;&]N+G1R86YS;65T82YC;VU\0VAA;F=E4V5T?#(P,#(P,C U,3<S,#4V
M?#$V,#0W?&,Q9#$Q830Q960P,C0X-C0*0PIC($%D9&5D(%A"3U@@<W5B87)C
M: IC(%1H97)E(&ES('-O;64@<W1R86YG92!I;G1E<F%C=&EO;B!W:&5N('!A
M9VEN9R!I<R!O9F8L('1H870@;6%K97,@,2XQ('AB;WAE;@IC(&-R87-H('=H
M:6QE(&1E8V]M<')E<W-I;F<@:V5R;F5L+"!U;FQE<W,@9&5C;VUP<F5S<V]R
M(&ES(&-O;7!I;&5D('=I=&AO=70*8R!O<'1I;6EZ871I;VXN"DL@-3<T-CD*
M3R M<G<M<G<M<BTM"E @87)C:"]I,S@V+V)O;W0O8V]M<')E<W-E9"]-86ME
M9FEL90HM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM
M+2TM+2TM+2T*"DDW(#,*:69E<2 H)"A#3TY&24=?6#@V7UA"3U@I+'DI"D-&
M3$%'4U]M:7-C+F\@(" Z/2 M3S *96YD:68*"CT](&EN8VQU9&4O87-M+6DS
M.#8O=&EM97@N:" ]/0IT;W)V86QD<T!A=&AL;VXN=')A;G-M971A+F-O;7QI
M;F-L=61E+V%S;2UI,S@V+W1I;65X+FA\,C P,C R,#4Q-S,Y-#1\-C,X-C)\
M86$U9F0Q868Y,69E-3!F-PIA;&%N0&QX;W)G=6LN=6MU=2YO<F<N=6M;=&]R
M=F%L9'-=?&EN8VQU9&4O87-M+6DS.#8O=&EM97@N:'PR,# S,#,R,C R,C8R
M-7PU,SDP- I$(#$N-2 P,R\P-B\P,B Q.3HQ,3HT-2LP,CHP,"!A;F1E<G-G
M0#!X-C,N;G4@*SD@+34*0B!T;W)V86QD<T!A=&AL;VXN=')A;G-M971A+F-O
M;7Q#:&%N9V53971\,C P,C R,#4Q-S,P-39\,38P-#=\8S%D,3%A-#%E9# R
M-#@V- I#"F,@061D960@6$)/6"!S=6)A<F-H"DL@-C$U-C0*3R M<G<M<G<M
M<BTM"E @:6YC;'5D92]A<VTM:3,X-B]T:6UE>"YH"BTM+2TM+2TM+2TM+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+0H*1#$U(#4*23$Y
M(#D*(R @:69D968@0T].1DE'7TU%3$%."B,@(" @9&5F:6YE($-,3T-+7U1)
M0TM?4D%412 Q,3@Y,C P("\J($%-1"!%;&%N(&AA<R!D:69F97)E;G0@9G)E
M<75E;F-Y(2 J+PHC("!E;'-E"B,@(" @:69D968@0T].1DE'7U@X-E]80D]8
M"B,@(" @("!D969I;F4@0TQ/0TM?5$E#2U]2051%(#$Q,C0Y.3@@+RH@<V\@
M:&%S('1H92!88F]X("HO"B,@(" @96QS92 *(R @(" @(&1E9FEN92!#3$]#
M2U]424-+7U)!5$4@,3$Y,S$X," O*B!5;F1E<FQY:6YG($A:("HO"B,@(" @
M96YD:68*(R @96YD:68*"CT](&%R8V@O:3,X-B]+8V]N9FEG(#T]"GII<'!E
M;$!L:6YU>"UM-CAK+F]R9UMT;W)V86QD<UU\87)C:"]I,S@V+TMC;VYF:6=\
M,C P,C$P,S P-#,R,3A\,C0V.#A\-C$R,S$X,&%B.3$U-S8P8PIA:W!M0&1I
M9V5O+F-O;5MT;W)V86QD<UU\87)C:"]I,S@V+TMC;VYF:6=\,C P,S U,#@P
M-3$S,35\,C@U-C$*1" Q+C4X(# S+S V+S R(#$Y.C$Q.C0T*S R.C P(&%N
M9&5R<V= ,'@V,RYN=2 K,3D@+3(*0B!T;W)V86QD<T!A=&AL;VXN=')A;G-M
M971A+F-O;7Q#:&%N9V53971\,C P,C R,#4Q-S,P-39\,38P-#=\8S%D,3%A
M-#%E9# R-#@V- I#"F,@061D960@6$)/6"!S=6)A<F-H"DL@,30R,3<*3R M
M<G<M<G<M<BTM"E @87)C:"]I,S@V+TMC;VYF:6<*+2TM+2TM+2TM+2TM+2TM
M+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM+2TM"@I)-#4@,38*8V]N
M9FEG(%@X-E]80D]8"@EB;V]L(")80F]X($=A;6EN9R!3>7-T96TB"@EH96QP
M"@D@(%1H:7,@;W!T:6]N(&ES(&YE961E9"!T;R!M86ME($QI;G5X(&)O;W0@
M;VX@6$)O>"!'86UI;F<@4WES=&5M<RX*"2 @"@D@(%1H92!80F]X(&-A;B!B
M92!C;VYS:61E<F5D(&%S(&$@<W1A;F1A<F0@4$,@=VET:"!A(%!E;G1I=6T@
M24E)($-E;&5R;VX@-S,S($U(>BP*"2 @241%(&AA<F1D<FEV92P@1%9$+"!%
M=&AE<FYE="P@55-"(&%N9"!G<F%P:&EC<RX@"@D@( H)("!4;R!B;V]T('1H
M92!K97)N96P@>6]U(&YE960@(E]R;VUW96QL(BP@96ET:&5R('5S960@87,@
M82!R97!L86-E;65N="!"24]3("AC<F]M=V5L;"D*"2 @;W(@87,@82!B;V]T
M;&]A9&5R+@H)(" *"2 @1F]R(&UO<F4@:6YF;W)M871I;VX@<V5E(&AT=' Z
M+R]X8F]X+6QI;G5X+G-O=7)C969O<F=E+FYE="\@"@D@( H)("!)9B!Y;W4@
M9&\@;F]T('-P96-I9FEC86QL>2!N965D(&$@:V5R;F5L(&9O<B!80D]8(&UA
M8VAI;F4L"@D@('-A>2!.(&AE<F4@;W1H97)W:7-E('1H92!K97)N96P@>6]U
M(&)U:6QD('=I;&P@;F]T(&)E(&)O;W1A8FQE+@I<"DDS.3<@,0H)9&5P96YD
M<R!O;B A6#@V7UA"3U@*1#$P.3,@,0I),3 Y,R Q"@ED97!E;F1S(&]N("$H
M6#@V7U9)4U=3('Q\(%@X-E]63UE!1T52('Q\(%@X-E]80D]8*0I$,34W-" Q
M"DDQ-3<T(#$*"61E<&5N9',@;VX@(2A8.#9?5DE35U,@?'P@6#@V7U9/64%'
K15(@?'P@6#@V7UA"3U@I"@HC(%!A=&-H(&-H96-K<W5M/64Y8S$V-S(T"@  
 

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFC/PATCH] Support for mach-xbox
  2003-06-02 20:27 [RFC/PATCH] Support for mach-xbox Anders Gustafsson
@ 2003-06-02 20:50 ` mikpe
  2003-06-02 21:01   ` Anders Gustafsson
  2003-06-02 21:56 ` Sam Ravnborg
  2003-06-06 14:56 ` Pavel Machek
  2 siblings, 1 reply; 7+ messages in thread
From: mikpe @ 2003-06-02 20:50 UTC (permalink / raw)
  To: Anders Gustafsson; +Cc: linux-kernel

Anders Gustafsson writes:
 > Hi,
 > 
 > Attached is a patch that adds a new subachitecture for the xbox gaming
 > system. All it does outside the subarchitecture is adding posibility to
 > blacklist pci-devices through an mach-hook.
...
 > +config X86_XBOX
 > +	bool "XBox Gaming System"
 > +	help
 > +	  This option is needed to make Linux boot on XBox Gaming Systems.
 > +	  
 > +	  The XBox can be considered as a standard PC with a Pentium III Celeron 733 MHz,

There is no such thing as a "Pentium III Celeron". Presumably you meant
"Coppermine-based Celeron 733 MHz", but even that is uncertain.
Please post a /proc/cpuinfo copy from one of these boxes.

/Mikael

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFC/PATCH] Support for mach-xbox
  2003-06-02 20:50 ` mikpe
@ 2003-06-02 21:01   ` Anders Gustafsson
  0 siblings, 0 replies; 7+ messages in thread
From: Anders Gustafsson @ 2003-06-02 21:01 UTC (permalink / raw)
  To: mikpe; +Cc: linux-kernel

On Mon, Jun 02, 2003 at 10:50:19PM +0200, mikpe@csd.uu.se wrote:
> There is no such thing as a "Pentium III Celeron". Presumably you meant
> "Coppermine-based Celeron 733 MHz", but even that is uncertain.
> Please post a /proc/cpuinfo copy from one of these boxes.

If you make those helptexts visible in menuconfig. :)


processor       : 0
vendor_id       : GenuineIntel
cpu family      : 6
model           : 8
model name      : Celeron (Coppermine)
stepping        : 10
cpu MHz         : 778.052
cache size      : 128 KB


-- 
Anders Gustafsson - andersg@0x63.nu - http://0x63.nu/

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFC/PATCH] Support for mach-xbox
  2003-06-02 20:27 [RFC/PATCH] Support for mach-xbox Anders Gustafsson
  2003-06-02 20:50 ` mikpe
@ 2003-06-02 21:56 ` Sam Ravnborg
  2003-06-06 14:56 ` Pavel Machek
  2 siblings, 0 replies; 7+ messages in thread
From: Sam Ravnborg @ 2003-06-02 21:56 UTC (permalink / raw)
  To: Anders Gustafsson; +Cc: linux-kernel

On Mon, Jun 02, 2003 at 10:27:14PM +0200, Anders Gustafsson wrote:
> Hi,
> 
> Attached is a patch that adds a new subachitecture for the xbox gaming
> system. All it does outside the subarchitecture is adding posibility to
> blacklist pci-devices through an mach-hook.

A few comments.

	Sam

> diff -Nru a/arch/i386/boot/compressed/Makefile b/arch/i386/boot/compressed/Makefile
> --- a/arch/i386/boot/compressed/Makefile	Mon Jun  2 19:23:26 2003
> +++ b/arch/i386/boot/compressed/Makefile	Mon Jun  2 19:23:26 2003
> @@ -5,6 +5,9 @@
>  #
>  
>  targets		:= vmlinux vmlinux.bin vmlinux.bin.gz head.o misc.o piggy.o
> +ifeq ($(CONFIG_X86_XBOX),y)
> +CFLAGS_misc.o   := -O0
> +endif
Add a comment why this special case is needed.

> diff -Nru a/arch/i386/mach-xbox/Makefile b/arch/i386/mach-xbox/Makefile
> --- /dev/null	Wed Dec 31 16:00:00 1969
> +++ b/arch/i386/mach-xbox/Makefile	Mon Jun  2 19:23:26 2003
> @@ -0,0 +1,7 @@
> +#
> +# Makefile for the linux kernel.
> +#
> +
> +EXTRA_CFLAGS	+= -I../kernel
Above line is not needed. Kill it.

> +static void xbox_pic_cmd(u8 command){
> +	outw_p(((XBOX_PIC_ADDRESS) << 1),XBOX_SMB_HOST_ADDRESS);
> +        outb_p(SMC_CMD_POWER, XBOX_SMB_HOST_COMMAND);
> +        outw_p(command, XBOX_SMB_HOST_DATA);
> +        outw_p(inw(XBOX_SMB_IO_BASE),XBOX_SMB_IO_BASE);
> +        outb_p(0x0a,XBOX_SMB_GLOBAL_ENABLE);
> +}
Follow coding style. See Documentation/CodingStyle
- Braces on one line
- Indent with tabs


^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFC/PATCH] Support for mach-xbox
  2003-06-02 20:27 [RFC/PATCH] Support for mach-xbox Anders Gustafsson
  2003-06-02 20:50 ` mikpe
  2003-06-02 21:56 ` Sam Ravnborg
@ 2003-06-06 14:56 ` Pavel Machek
  2003-06-08  9:18   ` Anders Gustafsson
  2 siblings, 1 reply; 7+ messages in thread
From: Pavel Machek @ 2003-06-06 14:56 UTC (permalink / raw)
  To: Anders Gustafsson; +Cc: linux-kernel

Hi,

> Attached is a patch that adds a new subachitecture for the xbox gaming

Why does xbox need new subarchitecture?
It should be normal PC...
-- 
				Pavel
Written on sharp zaurus, because my Velo1 broke. If you have Velo you don't need...


^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFC/PATCH] Support for mach-xbox
  2003-06-06 14:56 ` Pavel Machek
@ 2003-06-08  9:18   ` Anders Gustafsson
  2003-06-08 18:16     ` Pavel Machek
  0 siblings, 1 reply; 7+ messages in thread
From: Anders Gustafsson @ 2003-06-08  9:18 UTC (permalink / raw)
  To: Pavel Machek; +Cc: linux-kernel

On Fri, Jun 06, 2003 at 04:56:52PM +0200, Pavel Machek wrote:
> Hi,
> 
> > Attached is a patch that adds a new subachitecture for the xbox gaming
> 
> Why does xbox need new subarchitecture?
> It should be normal PC...

It need to blacklist some pci-devices, if you touch them it hangs. And it
has different CLOCK_TICK_RATE. So booting an xbox-kernel on other PC's will
make the blacklisted pci-devices disappear, and you will get wrong
CLOCK_TICK_RATE. It also has different restart/shutdown code. 

-- 
Anders Gustafsson - andersg@0x63.nu - http://0x63.nu/

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFC/PATCH] Support for mach-xbox
  2003-06-08  9:18   ` Anders Gustafsson
@ 2003-06-08 18:16     ` Pavel Machek
  0 siblings, 0 replies; 7+ messages in thread
From: Pavel Machek @ 2003-06-08 18:16 UTC (permalink / raw)
  To: Anders Gustafsson; +Cc: Pavel Machek, linux-kernel

Hi!

> > > Attached is a patch that adds a new subachitecture for the xbox gaming
> > 
> > Why does xbox need new subarchitecture?
> > It should be normal PC...
> 
> It need to blacklist some pci-devices, if you touch them it hangs. And it
> has different CLOCK_TICK_RATE. So booting an xbox-kernel on other
> PC's will

Okay, different CLOCK_TICK_RATE is good enough reason I guess.
									Pavel
-- 
When do you have a heart between your knees?
[Johanka's followup: and *two* hearts?]

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2003-06-08 18:02 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2003-06-02 20:27 [RFC/PATCH] Support for mach-xbox Anders Gustafsson
2003-06-02 20:50 ` mikpe
2003-06-02 21:01   ` Anders Gustafsson
2003-06-02 21:56 ` Sam Ravnborg
2003-06-06 14:56 ` Pavel Machek
2003-06-08  9:18   ` Anders Gustafsson
2003-06-08 18:16     ` Pavel Machek

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).