diff options
Diffstat (limited to 'target/linux/ubicom32')
16 files changed, 2387 insertions, 20 deletions
| diff --git a/target/linux/ubicom32/config-2.6.30 b/target/linux/ubicom32/config-default index 47cb52995..47cb52995 100755 --- a/target/linux/ubicom32/config-2.6.30 +++ b/target/linux/ubicom32/config-default diff --git a/target/linux/ubicom32/files/arch/ubicom32/include/asm/atomic.h b/target/linux/ubicom32/files/arch/ubicom32/include/asm/atomic.h index 78d9fcd8f..aaf772602 100644 --- a/target/linux/ubicom32/files/arch/ubicom32/include/asm/atomic.h +++ b/target/linux/ubicom32/files/arch/ubicom32/include/asm/atomic.h @@ -236,7 +236,12 @@ static inline int atomic_add_unless(atomic_t *v, int a, int u)  #define atomic_inc_not_zero(v) atomic_add_unless((v), 1, 0) +#include <linux/version.h> +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,32) +#include <asm-generic/atomic-long.h> +#else  #include <asm-generic/atomic.h> +#endif  /*   * The following is not a real function.  The compiler should remove the function diff --git a/target/linux/ubicom32/files/arch/ubicom32/include/asm/bitsperlong.h b/target/linux/ubicom32/files/arch/ubicom32/include/asm/bitsperlong.h new file mode 100644 index 000000000..6dc0bb0c1 --- /dev/null +++ b/target/linux/ubicom32/files/arch/ubicom32/include/asm/bitsperlong.h @@ -0,0 +1 @@ +#include <asm-generic/bitsperlong.h> diff --git a/target/linux/ubicom32/files/arch/ubicom32/include/asm/page.h b/target/linux/ubicom32/files/arch/ubicom32/include/asm/page.h index 89c6ce61c..1ecb174a6 100644 --- a/target/linux/ubicom32/files/arch/ubicom32/include/asm/page.h +++ b/target/linux/ubicom32/files/arch/ubicom32/include/asm/page.h @@ -28,10 +28,12 @@  #ifndef _ASM_UBICOM32_PAGE_H  #define _ASM_UBICOM32_PAGE_H +#include <linux/const.h> +  /* PAGE_SHIFT determines the page size */ -#define PAGE_SHIFT	12 -#define PAGE_SIZE	(1 << PAGE_SHIFT) +#define PAGE_SHIFT	(12) +#define PAGE_SIZE	(_AC(1,UL) << PAGE_SHIFT)  #define PAGE_MASK	(~(PAGE_SIZE-1))  #include <asm/setup.h> @@ -99,7 +101,15 @@ extern unsigned long memory_end;  #endif /* __ASSEMBLY__ */ -#ifdef __KERNEL__ +#define VM_DATA_DEFAULT_FLAGS \ +	(VM_READ | VM_WRITE | \ +	((current->personality & READ_IMPLIES_EXEC) ? VM_EXEC : 0 ) | \ +		VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC) + +#include <linux/version.h> +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,32) +#include <asm-generic/getorder.h> +#else  #include <asm-generic/page.h>  #endif diff --git a/target/linux/ubicom32/files/arch/ubicom32/include/asm/pgtable.h b/target/linux/ubicom32/files/arch/ubicom32/include/asm/pgtable.h index 70ad115cc..ffb30a9ec 100644 --- a/target/linux/ubicom32/files/arch/ubicom32/include/asm/pgtable.h +++ b/target/linux/ubicom32/files/arch/ubicom32/include/asm/pgtable.h @@ -114,11 +114,15 @@ extern inline void flush_pages_to_ram (unsigned long address, int n)  #define	VMALLOC_START	0  #define	VMALLOC_END	0xffffffff +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,32) +#include <asm-generic/pgtable.h> +#else  #define arch_enter_lazy_mmu_mode()	do {} while (0)  #define arch_leave_lazy_mmu_mode()	do {} while (0)  #define arch_flush_lazy_mmu_mode()	do {} while (0)  #define arch_enter_lazy_cpu_mode()	do {} while (0)  #define arch_leave_lazy_cpu_mode()	do {} while (0)  #define arch_flush_lazy_cpu_mode()	do {} while (0) +#endif  #endif /* _ASM_UBICOM32_PGTABLE_H */ diff --git a/target/linux/ubicom32/files/arch/ubicom32/include/asm/signal.h b/target/linux/ubicom32/files/arch/ubicom32/include/asm/signal.h index a334e19ea..946b3f77d 100644 --- a/target/linux/ubicom32/files/arch/ubicom32/include/asm/signal.h +++ b/target/linux/ubicom32/files/arch/ubicom32/include/asm/signal.h @@ -124,7 +124,12 @@ typedef struct {  #define MINSIGSTKSZ	2048  #define SIGSTKSZ	8192 +#include <linux/version.h> +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,32) +#include <asm-generic/signal-defs.h> +#else  #include <asm-generic/signal.h> +#endif  #ifdef __KERNEL__  struct old_sigaction { diff --git a/target/linux/ubicom32/files/arch/ubicom32/include/asm/socket.h b/target/linux/ubicom32/files/arch/ubicom32/include/asm/socket.h index 2d95c24f7..24ac11314 100644 --- a/target/linux/ubicom32/files/arch/ubicom32/include/asm/socket.h +++ b/target/linux/ubicom32/files/arch/ubicom32/include/asm/socket.h @@ -84,4 +84,7 @@  #define SO_TIMESTAMPING		37  #define SCM_TIMESTAMPING	SO_TIMESTAMPING +#define SO_PROTOCOL		38 +#define SO_DOMAIN		39 +  #endif /* _ASM_UBICOM32_SOCKET_H */ diff --git a/target/linux/ubicom32/files/arch/ubicom32/kernel/init_task.c b/target/linux/ubicom32/files/arch/ubicom32/kernel/init_task.c index ff0634424..58baf5270 100644 --- a/target/linux/ubicom32/files/arch/ubicom32/kernel/init_task.c +++ b/target/linux/ubicom32/files/arch/ubicom32/kernel/init_task.c @@ -34,12 +34,15 @@  #include <linux/mqueue.h>  #include <linux/uaccess.h>  #include <asm/pgtable.h> +#include <linux/version.h>  ///static struct fs_struct init_fs = INIT_FS;  static struct signal_struct init_signals = INIT_SIGNALS(init_signals);  static struct sighand_struct init_sighand = INIT_SIGHAND(init_sighand); +#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,32)  struct mm_struct init_mm = INIT_MM(init_mm);  EXPORT_SYMBOL(init_mm); +#endif  /*   * Initial task structure. diff --git a/target/linux/ubicom32/files/arch/ubicom32/kernel/timer_device.c b/target/linux/ubicom32/files/arch/ubicom32/kernel/timer_device.c index d2d094d37..1943cbb9e 100644 --- a/target/linux/ubicom32/files/arch/ubicom32/kernel/timer_device.c +++ b/target/linux/ubicom32/files/arch/ubicom32/kernel/timer_device.c @@ -169,7 +169,7 @@ static struct clocksource timer_device_clockbase = {   * timer_device_alloc_event()   * 	Allocate a timer device event.   */ -static int timer_device_alloc_event(const char *name, int cpuid, const cpumask_t *mask) +static int timer_device_alloc_event(const char *name, int cpuid, const struct cpumask *cpumask)  {  	struct clock_event_device *dev;  	struct irqaction *action; @@ -208,10 +208,10 @@ static int timer_device_alloc_event(const char *name, int cpuid, const cpumask_t  	action->name = name;  	action->flags = IRQF_DISABLED | IRQF_TIMER;  	action->handler = timer_device_event; -	cpumask_copy(&action->mask, mask); +	//cpumask_copy(&action->mask, mask);  	action->dev_id = dev;  	setup_irq(dev->irq, action); -	irq_set_affinity(dev->irq, mask); +	irq_set_affinity(dev->irq, cpumask);  	ldsr_disable_vector(dev->irq);  	/* @@ -229,7 +229,7 @@ static int timer_device_alloc_event(const char *name, int cpuid, const cpumask_t  	dev->mult = div_sc(frequency, NSEC_PER_SEC, dev->shift);  	dev->max_delta_ns = clockevent_delta2ns(0xffffffff, dev);  	dev->min_delta_ns = clockevent_delta2ns(100, dev); -	dev->cpumask = mask; +	//dev->cpumask = mask;  	printk(KERN_NOTICE "timer[%d]: %s - created\n", dev->irq, dev->name);  	/* @@ -246,7 +246,7 @@ static int timer_device_alloc_event(const char *name, int cpuid, const cpumask_t   */  int __cpuinit local_timer_setup(unsigned int cpu)  { -	return timer_device_alloc_event("timer-cpu", cpu, cpumask_of(cpu)); +	return timer_device_alloc_event("timer-cpu", cpu);  }  #endif @@ -283,19 +283,19 @@ void timer_device_init(void)  	/*  	 * Always allocate a primary timer.  	 */ -	timer_device_alloc_event("timer-primary", -1, CPU_MASK_ALL_PTR); +	timer_device_alloc_event("timer-primary", -1, cpu_all_mask);  #if defined(CONFIG_GENERIC_CLOCKEVENTS_BROADCAST)  	/*  	 * If BROADCAST is selected we need to add a broadcast timer.  	 */ -	timer_device_alloc_event("timer-broadcast", -1, CPU_MASK_ALL_PTR); +	timer_device_alloc_event("timer-broadcast", -1, cpu_all_mask);  #endif  	/*  	 * Allocate extra timers that are requested.  	 */  	for (i = 0; i < CONFIG_TIMER_EXTRA_ALLOC; i++) { -		timer_device_alloc_event("timer-extra", -1, CPU_MASK_ALL_PTR); +		timer_device_alloc_event("timer-extra", -1, cpu_all_mask);  	}  } diff --git a/target/linux/ubicom32/files/drivers/net/ubi32-eth.c b/target/linux/ubicom32/files/drivers/net/ubi32-eth.c index e6c7392e0..e9c62f462 100644 --- a/target/linux/ubicom32/files/drivers/net/ubi32-eth.c +++ b/target/linux/ubicom32/files/drivers/net/ubi32-eth.c @@ -634,6 +634,19 @@ void ubi32_eth_cleanup(void)  	}  } +	static const struct net_device_ops ubi32_netdev_ops = { +		.ndo_open		= ubi32_eth_open, +		.ndo_stop		= ubi32_eth_close, +		.ndo_start_xmit		= ubi32_eth_start_xmit, +		.ndo_tx_timeout		= ubi32_eth_tx_timeout, +		.ndo_do_ioctl		= ubi32_eth_ioctl, +		.ndo_change_mtu		= ubi32_eth_change_mtu, +		.ndo_set_config		= ubi32_eth_set_config, +		.ndo_get_stats		= ubi32_eth_get_stats, +		.ndo_validate_addr	= eth_validate_addr, +		.ndo_set_mac_address	= eth_mac_addr, +	}; +  int ubi32_eth_init_module(void)  {  	struct ethtionode *eth_node; @@ -706,16 +719,9 @@ int ubi32_eth_init_module(void)  		spin_lock_init(&priv->lock); -		dev->open		= ubi32_eth_open; -		dev->stop		= ubi32_eth_close; -		dev->hard_start_xmit	= ubi32_eth_start_xmit; -		dev->tx_timeout		= ubi32_eth_tx_timeout; -		dev->watchdog_timeo	= UBI32_ETH_VP_TX_TIMEOUT; +		dev->netdev_ops = &ubi32_netdev_ops; -		dev->set_config		= ubi32_eth_set_config; -		dev->do_ioctl		= ubi32_eth_ioctl; -		dev->get_stats		= ubi32_eth_get_stats; -		dev->change_mtu		= ubi32_eth_change_mtu; +		dev->watchdog_timeo	= UBI32_ETH_VP_TX_TIMEOUT;  #ifdef UBICOM32_USE_NAPI  		netif_napi_add(dev, &priv->napi, ubi32_eth_napi_poll, UBI32_ETH_NAPI_WEIGHT);  #endif diff --git a/target/linux/ubicom32/files/drivers/serial/ubi32_mailbox.c b/target/linux/ubicom32/files/drivers/serial/ubi32_mailbox.c index fc0d6d21b..f14fcdfd9 100644 --- a/target/linux/ubicom32/files/drivers/serial/ubi32_mailbox.c +++ b/target/linux/ubicom32/files/drivers/serial/ubi32_mailbox.c @@ -34,6 +34,7 @@  #include <linux/tty.h>  #include <linux/tty_flip.h>  #include <linux/serial_core.h> +#include <linux/version.h>  #include <asm/ip5000.h> @@ -259,8 +260,13 @@ static void ubi32_mailbox_enable_ms(struct uart_port *port)  static void ubi32_mailbox_rx_chars(struct ubi32_mailbox_port *uart)  { +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,32) +	struct uart_state *state = uart->port.state; +	struct tty_struct *tty = state->port.tty; +#else  	struct uart_info *info = uart->port.info;  	struct tty_struct *tty = info->port.tty; +#endif  	unsigned int status, ch, flg;  	status = 0; // XXX? UART_GET_LSR(uart); @@ -308,7 +314,11 @@ static void ubi32_mailbox_rx_chars(struct ubi32_mailbox_port *uart)  static void ubi32_mailbox_tx_chars(struct ubi32_mailbox_port *uart)  { +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,32) +	struct circ_buf *xmit = &uart->port.state->xmit; +#else  	struct circ_buf *xmit = &uart->port.info->xmit; +#endif  	if (uart->port.x_char) {  		UART_PUT_CHAR(uart, uart->port.x_char); diff --git a/target/linux/ubicom32/patches-2.6.32/100-ubicom32_support.patch b/target/linux/ubicom32/patches-2.6.32/100-ubicom32_support.patch new file mode 100644 index 000000000..e16ec7dda --- /dev/null +++ b/target/linux/ubicom32/patches-2.6.32/100-ubicom32_support.patch @@ -0,0 +1,1725 @@ +--- a/drivers/char/hw_random/Kconfig ++++ b/drivers/char/hw_random/Kconfig +@@ -186,3 +186,16 @@ config HW_RANDOM_MXC_RNGA + 	  module will be called mxc-rnga. +  + 	  If unsure, say Y. ++ ++config HW_RANDOM_UBICOM32 ++	tristate "Ubicom32 HW Random Number Generator support" ++	depends on HW_RANDOM && UBICOM32 ++	default HW_RANDOM ++	---help--- ++	  This driver provides kernel-side support for the Random Number ++	  Generator hardware found on Ubicom32 processors. ++ ++	  To compile this driver as a module, choose M here: the ++	  module will be called pasemi-rng. ++ ++	  If unsure, say Y. +--- a/drivers/char/hw_random/Makefile ++++ b/drivers/char/hw_random/Makefile +@@ -18,3 +18,4 @@ obj-$(CONFIG_HW_RANDOM_VIRTIO) += virtio + obj-$(CONFIG_HW_RANDOM_TX4939) += tx4939-rng.o + obj-$(CONFIG_HW_RANDOM_MXC_RNGA) += mxc-rnga.o + obj-$(CONFIG_HW_RANDOM_OCTEON) += octeon-rng.o ++obj-$(CONFIG_HW_RANDOM_UBICOM32) += ubicom32-rng.o +--- a/drivers/crypto/Kconfig ++++ b/drivers/crypto/Kconfig +@@ -61,6 +61,40 @@ config CRYPTO_DEV_GEODE + 	  To compile this driver as a module, choose M here: the module + 	  will be called geode-aes. +  ++config CRYPTO_UBICOM32 ++        bool "Ubicom32 Security Module" ++        depends on UBICOM32 ++        help ++          This is the ubicom32 hardware acceleration common code. ++ ++config CRYPTO_AES_UBICOM32 ++        tristate "Ubicom32 AES implementation" ++        depends on CRYPTO_UBICOM32 ++        select CRYPTO_ALGAPI ++        help ++          This is the ubicom32 hardware AES implementation. ++ ++config CRYPTO_DES_UBICOM32 ++        tristate "Ubicom32 DES implementation" ++        depends on CRYPTO_UBICOM32 ++        select CRYPTO_ALGAPI ++        help ++          This is the ubicom32 hardware DES and 3DES implementation. ++ ++config CRYPTO_SHA1_UBICOM32 ++        tristate "Ubicom32 SHA1 implementation" ++        depends on CRYPTO_UBICOM32 ++        select CRYPTO_ALGAPI ++        help ++          This is the ubicom32 hardware SHA1 implementation. ++ ++config CRYPTO_MD5_UBICOM32 ++        tristate "Ubicom32 MD5 implementation" ++        depends on CRYPTO_UBICOM32 ++        select CRYPTO_ALGAPI ++        help ++          This is the ubicom32 hardware MD5 implementation. ++ + config ZCRYPT + 	tristate "Support for PCI-attached cryptographic adapters" + 	depends on S390 +--- a/drivers/mmc/host/Kconfig ++++ b/drivers/mmc/host/Kconfig +@@ -382,3 +382,10 @@ config MMC_VIA_SDMMC + 	  If you have a controller with this interface, say Y or M here. +  + 	  If unsure, say N. ++ ++config MMC_UBICOM32 ++	tristate "Ubicom32 MMC/SD host controller" ++	depends on UBICOM32 ++	help ++	  This provides support for the SD/MMC hardware found on Ubicom32 ++	  IP7K processors +--- a/drivers/mmc/host/Makefile ++++ b/drivers/mmc/host/Makefile +@@ -35,6 +35,7 @@ obj-$(CONFIG_MMC_TMIO)		+= tmio_mmc.o + obj-$(CONFIG_MMC_CB710)	+= cb710-mmc.o + obj-$(CONFIG_MMC_VIA_SDMMC)	+= via-sdmmc.o + obj-$(CONFIG_GPIOMMC)		+= gpiommc.o ++obj-$(CONFIG_MMC_UBICOM32)	+= ubicom32sd.o +  + ifeq ($(CONFIG_CB710_DEBUG),y) + 	CFLAGS-cb710-mmc	+= -DDEBUG +--- a/drivers/mtd/devices/Kconfig ++++ b/drivers/mtd/devices/Kconfig +@@ -114,6 +114,31 @@ config MTD_SST25L + 	  Set up your spi devices with the right board-specific platform data, + 	  if you want to specify device partitioning. +  ++config MTD_UBI32_NAND_SPI_ER ++	tristate "UBI32_NAND SPI-ER support" ++	help ++	  This driver supports the Micron MT29F1G01 SPI-ER NAND flash chip ++	  using the built in flash controller on the Ubicom32 architecture. ++	  Partial page writes are not supported by this driver. ++ ++config MTD_NAND_SPI_ER ++	tristate "NAND SPI-ER support" ++	help ++	  This driver supports the Micron MT29F1G01 SPI-ER NAND flash chip ++	  using a generic SPI bus.  Partial page writes are supported ++	  by this driver. ++ ++config MTD_UBI32_M25P80 ++	tristate "Ubicom processor support for most SPI Flash chips (AT26DF, M25P, W25X, ...)" ++	depends on UBICOM32 ++	default y ++	help ++	  This enables access to most modern SPI flash chips, used for ++	  program and data storage.   Series supported include Atmel AT26DF, ++	  Spansion S25SL, SST 25VF, ST M25P, and Winbond W25X.  Other chips ++	  are supported as well.  See the driver source for the current list, ++	  or to add other chips. ++ + config MTD_SLRAM + 	tristate "Uncached system RAM" + 	help +--- a/drivers/mtd/devices/Makefile ++++ b/drivers/mtd/devices/Makefile +@@ -17,3 +17,6 @@ obj-$(CONFIG_MTD_BLOCK2MTD)	+= block2mtd + obj-$(CONFIG_MTD_DATAFLASH)	+= mtd_dataflash.o + obj-$(CONFIG_MTD_M25P80)	+= m25p80.o + obj-$(CONFIG_MTD_SST25L)	+= sst25l.o ++obj-$(CONFIG_MTD_UBI32_M25P80)	+= ubi32-m25p80.o ++obj-$(CONFIG_MTD_NAND_SPI_ER)	+= nand-spi-er.o ++obj-$(CONFIG_MTD_UBI32_NAND_SPI_ER)	+= ubi32-nand-spi-er.o +--- a/drivers/net/Kconfig ++++ b/drivers/net/Kconfig +@@ -2608,6 +2608,19 @@ config S6GMAC +  + source "drivers/net/stmmac/Kconfig" +  ++config UBICOM32_GMAC ++	tristate "Ubicom Gigabit Ethernet support" ++	depends on UBICOM32 ++	help ++	  Gigabit Ethernet support for ubicom32 processors ++ ++config UBICOM32_OCM_FOR_SKB ++        bool  "USE OCM for SKB (EXPERIMENTAL)" ++        depends on UBICOM32_GMAC ++	default n ++        help ++          Allocate skb from OCM for Ethernet Receive when possible ++ + endif # NETDEV_1000 +  + # +--- a/drivers/net/Makefile ++++ b/drivers/net/Makefile +@@ -286,3 +286,5 @@ obj-$(CONFIG_VIRTIO_NET) += virtio_net.o + obj-$(CONFIG_SFC) += sfc/ +  + obj-$(CONFIG_WIMAX) += wimax/ ++ ++obj-$(CONFIG_UBICOM32_GMAC) += ubi32-eth.o +--- a/drivers/net/usb/asix.c ++++ b/drivers/net/usb/asix.c +@@ -319,14 +319,33 @@ static int asix_rx_fixup(struct usbnet * + 		/* get the packet length */ + 		size = (u16) (header & 0x0000ffff); +  +-		if ((skb->len) - ((size + 1) & 0xfffe) == 0) ++		if ((skb->len) - ((size + 1) & 0xfffe) == 0) { ++#ifndef HAVE_EFFICIENT_UNALIGNED_ACCESS ++			if (((u32)packet & 0x02) == 0) { ++				memmove(packet - 2, packet, size); ++				skb->data -= 2; ++				skb->tail -= 2; ++			} ++#endif + 			return 2; ++		} ++ + 		if (size > ETH_FRAME_LEN) { + 			deverr(dev,"asix_rx_fixup() Bad RX Length %d", size); + 			return 0; + 		} + 		ax_skb = skb_clone(skb, GFP_ATOMIC); + 		if (ax_skb) { ++#ifndef HAVE_EFFICIENT_UNALIGNED_ACCESS ++			if (((u32)packet & 0x02) == 0) { ++				memmove(packet - 2, packet, size); ++				ax_skb->data = packet - 2; ++			} else { ++				ax_skb->data = packet; ++			} ++#else ++			ax_skb->data = packet; ++#endif + 			ax_skb->len = size; + 			ax_skb->data = packet; + 			skb_set_tail_pointer(ax_skb, size); +@@ -1125,13 +1144,19 @@ static int ax88178_link_reset(struct usb + 	mode = AX88178_MEDIUM_DEFAULT; +  + 	if (ecmd.speed == SPEED_1000) ++#ifdef HAVE_EFFICIENT_UNALIGNED_ACCESS + 		mode |= AX_MEDIUM_GM; ++#else ++		mode |= AX_MEDIUM_GM | AX_MEDIUM_ENCK; ++#endif + 	else if (ecmd.speed == SPEED_100) + 		mode |= AX_MEDIUM_PS; + 	else + 		mode &= ~(AX_MEDIUM_PS | AX_MEDIUM_GM); +  ++#ifdef HAVE_EFFICIENT_UNALIGNED_ACCESS + 	mode |= AX_MEDIUM_ENCK; ++#endif +  + 	if (ecmd.duplex == DUPLEX_FULL) + 		mode |= AX_MEDIUM_FD; +--- a/drivers/oprofile/cpu_buffer.c ++++ b/drivers/oprofile/cpu_buffer.c +@@ -327,10 +327,10 @@ static inline void oprofile_end_trace(st + } +  + static inline void +-__oprofile_add_ext_sample(unsigned long pc, struct pt_regs * const regs, +-			  unsigned long event, int is_kernel) ++__oprofile_add_ext_sample_cpu(unsigned long pc, struct pt_regs * const regs, ++			      unsigned long event, int is_kernel, int cpu) + { +-	struct oprofile_cpu_buffer *cpu_buf = &__get_cpu_var(cpu_buffer); ++	struct oprofile_cpu_buffer *cpu_buf = &per_cpu(cpu_buffer, cpu); + 	unsigned long backtrace = oprofile_backtrace_depth; +  + 	/* +@@ -352,7 +352,8 @@ __oprofile_add_ext_sample(unsigned long  + void oprofile_add_ext_sample(unsigned long pc, struct pt_regs * const regs, + 			     unsigned long event, int is_kernel) + { +-	__oprofile_add_ext_sample(pc, regs, event, is_kernel); ++	__oprofile_add_ext_sample_cpu(pc, regs, event, ++				      is_kernel, smp_processor_id()); + } +  + void oprofile_add_sample(struct pt_regs * const regs, unsigned long event) +@@ -360,7 +361,8 @@ void oprofile_add_sample(struct pt_regs  + 	int is_kernel = !user_mode(regs); + 	unsigned long pc = profile_pc(regs); +  +-	__oprofile_add_ext_sample(pc, regs, event, is_kernel); ++	__oprofile_add_ext_sample_cpu(pc, regs, event, ++				      is_kernel, smp_processor_id()); + } +  + /* +--- a/drivers/pci/Makefile ++++ b/drivers/pci/Makefile +@@ -47,8 +47,8 @@ obj-$(CONFIG_PPC) += setup-bus.o + obj-$(CONFIG_MIPS) += setup-bus.o setup-irq.o + obj-$(CONFIG_X86_VISWS) += setup-irq.o + obj-$(CONFIG_MN10300) += setup-bus.o ++obj-$(CONFIG_UBICOM32) += setup-bus.o setup-irq.o +  +-# + # ACPI Related PCI FW Functions + # + obj-$(CONFIG_ACPI)    += pci-acpi.o +--- a/drivers/serial/Kconfig ++++ b/drivers/serial/Kconfig +@@ -879,6 +879,57 @@ config SERIAL_UARTLITE_CONSOLE + 	  console (the system console is the device which receives all kernel + 	  messages and warnings and which allows logins in single user mode). +  ++config SERIAL_UBI32_UARTTIO ++        tristate "Ubicom UARTTIO support" ++        depends on UBICOM32=y ++        select SERIAL_CORE ++	default y ++        help ++          Add support for the Ubicom virtual peripherial serial interface. ++ ++config SERIAL_UBI32_UARTTIO_NR_UARTS ++	int "Maximum number of UARTTIO virtual serial ports" ++	depends on SERIAL_UBI32_UARTTIO ++	default "4" ++	help ++	  Set this to the maximum number of serial ports you want the driver to support. ++ ++config SERIAL_UBI32_UARTTIO_CONSOLE ++        tristate "Ubicom UARTTIO console support" ++        depends on SERIAL_UBI32_UARTTIO=y ++        select SERIAL_CORE_CONSOLE ++	default y ++        help ++          Add support for console on the Ubicom virtual peripherial serial interface. ++ ++config SERIAL_UBI32_SERDES ++        bool "Ubicom serial port support" ++        depends on UBICOM32=y ++        select SERIAL_CORE ++	default y ++        help ++          Add support for the Ubicom serial interface. ++ ++config SERIAL_UBI32_SERDES_CONSOLE ++        bool "Ubicom serial console support" ++        depends on SERIAL_UBI32_SERDES=y ++        select SERIAL_CORE_CONSOLE ++	default y ++ ++config SERIAL_UBI32_MAILBOX ++        bool "Ubicom mailbox support" ++        depends on UBICOM32=y ++        select SERIAL_CORE ++	default n ++        help ++          Add support for the Ubicom mailbox interface. ++ ++config SERIAL_UBI32_MAILBOX_CONSOLE ++        bool "Ubicom mailbox console support" ++        depends on SERIAL_UBI32_MAILBOX=y ++        select SERIAL_CORE_CONSOLE ++	default y ++ + config SERIAL_SUNCORE + 	bool + 	depends on SPARC +--- a/drivers/serial/Makefile ++++ b/drivers/serial/Makefile +@@ -81,3 +81,6 @@ obj-$(CONFIG_SERIAL_KS8695) += serial_ks + obj-$(CONFIG_KGDB_SERIAL_CONSOLE) += kgdboc.o + obj-$(CONFIG_SERIAL_QE) += ucc_uart.o + obj-$(CONFIG_SERIAL_TIMBERDALE)	+= timbuart.o ++obj-$(CONFIG_SERIAL_UBI32_SERDES) += ubi32_serdes.o ++obj-$(CONFIG_SERIAL_UBI32_UARTTIO) += ubi32_uarttio.o ++obj-$(CONFIG_SERIAL_UBI32_MAILBOX) += ubi32_mailbox.o +--- a/drivers/spi/Kconfig ++++ b/drivers/spi/Kconfig +@@ -214,6 +214,15 @@ config SPI_S3C24XX + 	help + 	  SPI driver for Samsung S3C24XX series ARM SoCs +  ++config SPI_UBICOM32_GPIO ++	tristate "Ubicom32 SPI over GPIO" ++	depends on SPI_MASTER && UBICOM32 && EXPERIMENTAL ++	select SPI_BITBANG ++	select HAS_DMA ++	help ++	  SPI driver for the Ubicom32 architecture using ++	  GPIO lines to provide the SPI bus. ++ + config SPI_S3C24XX_GPIO + 	tristate "Samsung S3C24XX series SPI by GPIO" + 	depends on ARCH_S3C2410 && EXPERIMENTAL +--- a/drivers/spi/Makefile ++++ b/drivers/spi/Makefile +@@ -29,6 +29,7 @@ obj-$(CONFIG_SPI_MPC52xx_PSC)		+= mpc52x + obj-$(CONFIG_SPI_MPC8xxx)		+= spi_mpc8xxx.o + obj-$(CONFIG_SPI_PPC4xx)		+= spi_ppc4xx.o + obj-$(CONFIG_SPI_S3C24XX_GPIO)		+= spi_s3c24xx_gpio.o ++obj-$(CONFIG_SPI_UBICOM32_GPIO)		+= spi_ubicom32_gpio.o + obj-$(CONFIG_SPI_S3C24XX)		+= spi_s3c24xx.o + obj-$(CONFIG_SPI_TXX9)			+= spi_txx9.o + obj-$(CONFIG_SPI_XILINX)		+= xilinx_spi.o +--- a/drivers/uio/Kconfig ++++ b/drivers/uio/Kconfig +@@ -94,4 +94,12 @@ config UIO_PCI_GENERIC + 	  primarily, for virtualization scenarios. + 	  If you compile this as a module, it will be called uio_pci_generic. +  ++config UIO_UBICOM32RING ++	tristate "Ubicom32 Ring Buffer driver" ++	default n ++	help ++	  Userspace I/O interface for a Ubicom32 Ring Buffer. ++ ++	  If you compile this as a module, it will be called uio_ubicom32ring ++ + endif +--- a/drivers/uio/Makefile ++++ b/drivers/uio/Makefile +@@ -6,3 +6,4 @@ obj-$(CONFIG_UIO_SMX)	+= uio_smx.o + obj-$(CONFIG_UIO_AEC)	+= uio_aec.o + obj-$(CONFIG_UIO_SERCOS3)	+= uio_sercos3.o + obj-$(CONFIG_UIO_PCI_GENERIC)	+= uio_pci_generic.o ++obj-$(CONFIG_UIO_UBICOM32RING)	+= uio_ubicom32ring.o +--- a/drivers/usb/gadget/epautoconf.c ++++ b/drivers/usb/gadget/epautoconf.c +@@ -154,6 +154,10 @@ ep_matches ( + 			/* configure your hardware with enough buffering!! */ + 		} + 		break; ++ ++	case USB_ENDPOINT_XFER_BULK: ++		if ((gadget->is_dualspeed) && (ep->maxpacket < 512)) ++			return 0; + 	} +  + 	/* MATCH!! */ +--- a/drivers/usb/Kconfig ++++ b/drivers/usb/Kconfig +@@ -22,6 +22,7 @@ config USB_ARCH_HAS_HCD + 	default y if PCMCIA && !M32R			# sl811_cs + 	default y if ARM				# SL-811 + 	default y if SUPERH				# r8a66597-hcd ++	default y if UBICOM32				# Ubicom's onchip USB Duial role controller + 	default PCI +  + # many non-PCI SOC chips embed OHCI +--- a/drivers/usb/musb/Kconfig ++++ b/drivers/usb/musb/Kconfig +@@ -14,7 +14,7 @@ config USB_MUSB_HDRC + 	select TWL4030_USB if MACH_OMAP_3430SDP + 	select NOP_USB_XCEIV if MACH_OMAP3EVM + 	select USB_OTG_UTILS +-	tristate 'Inventra Highspeed Dual Role Controller (TI, ADI, ...)' ++	tristate 'Inventra Highspeed Dual Role Controller (TI, ADI, Ubicom, ...)' + 	help + 	  Say Y here if your system has a dual role high speed USB + 	  controller based on the Mentor Graphics silicon IP.  Then +--- a/drivers/usb/musb/Makefile ++++ b/drivers/usb/musb/Makefile +@@ -30,6 +30,10 @@ ifeq ($(CONFIG_BF52x),y) + 	musb_hdrc-objs	+= blackfin.o + endif +  ++ifeq ($(CONFIG_UBICOM32), y) ++        musb_hdrc-objs  += ubi32_usb.o ++endif ++ + ifeq ($(CONFIG_USB_GADGET_MUSB_HDRC),y) + 	musb_hdrc-objs		+= musb_gadget_ep0.o musb_gadget.o + endif +--- a/drivers/usb/musb/musb_core.c ++++ b/drivers/usb/musb/musb_core.c +@@ -105,6 +105,13 @@ + #include <asm/mach-types.h> + #endif +  ++#ifdef CONFIG_UBICOM32 ++#include <asm/ip5000.h> ++#include <asm/ubicom32-tio.h> ++extern void ubi32_usb_init(void); ++extern void ubi32_usb_int_clr(void); ++#endif ++ + #include "musb_core.h" +  +  +@@ -148,8 +155,37 @@ static inline struct musb *dev_to_musb(s + } +  + /*-------------------------------------------------------------------------*/ ++#if defined(CONFIG_UBICOM32) ++ ++/* ++ * Load an endpoint's FIFO ++ */ ++void musb_write_fifo(struct musb_hw_ep *hw_ep, u16 wCount, const u8 *pSource) ++{ ++	void __iomem *fifo = hw_ep->fifo; ++ ++	prefetch((u8 *)pSource); ++ ++	DBG(4, "%cX ep%d fifo %p count %d buf %p\n", ++			'T', hw_ep->epnum, fifo, wCount, pSource); ++ ++	usb_tio_write_fifo((u32)fifo, (u32)pSource, wCount); ++ ++} ++ ++/* ++ * Unload an endpoint's FIFO ++ */ ++void musb_read_fifo(struct musb_hw_ep *hw_ep, u16 wCount, u8 *pDest) ++{ ++ ++	void __iomem *fifo = hw_ep->fifo; ++	DBG(4, "%cX ep%d fifo %p count %d buf %p\n", ++			'R', hw_ep->epnum, fifo, wCount, pDest); ++	usb_tio_read_fifo((u32)fifo, (u32)pDest, wCount); ++} +  +-#if !defined(CONFIG_USB_TUSB6010) && !defined(CONFIG_BLACKFIN) ++#elif !defined(CONFIG_USB_TUSB6010) && !defined(CONFIG_BLACKFIN) +  + /* +  * Load an endpoint's FIFO +@@ -228,8 +264,7 @@ void musb_read_fifo(struct musb_hw_ep *h + 		readsb(fifo, dst, len); + 	} + } +- +-#endif	/* normal PIO */ ++#endif /* !T6010 && !BLACKFIN */ +  +  + /*-------------------------------------------------------------------------*/ +@@ -890,12 +925,19 @@ void musb_start(struct musb *musb) + 	musb_writeb(regs, MUSB_TESTMODE, 0); +  + 	/* put into basic highspeed mode and start session */ ++#ifndef CONFIG_UBICOM32 + 	musb_writeb(regs, MUSB_POWER, MUSB_POWER_ISOUPDATE + 						| MUSB_POWER_SOFTCONN + 						| MUSB_POWER_HSENAB + 						/* ENSUSPEND wedges tusb */ + 						/* | MUSB_POWER_ENSUSPEND */ + 						); ++#else ++	musb_writeb(regs, MUSB_POWER,  MUSB_POWER_HSENAB ++						/* ENSUSPEND wedges tusb */ ++						/* | MUSB_POWER_ENSUSPEND */ ++						); ++#endif +  + 	musb->is_active = 0; + 	devctl = musb_readb(regs, MUSB_DEVCTL); +@@ -1096,6 +1138,7 @@ static struct fifo_cfg __initdata mode_4 + }; +  +  ++#ifndef CONFIG_UBICOM32 + /* +  * configure a fifo; for non-shared endpoints, this may be called +  * once for a tx fifo and once for an rx fifo. +@@ -1255,7 +1298,7 @@ static int __init ep_config_from_table(s +  + 	return 0; + } +- ++#endif /* CONFIG_UBICOM32 */ +  + /* +  * ep_config_from_hw - when MUSB_C_DYNFIFO_DEF is false +@@ -1271,6 +1314,11 @@ static int __init ep_config_from_hw(stru + 	DBG(2, "<== static silicon ep config\n"); +  + 	/* FIXME pick up ep0 maxpacket size */ ++#ifdef CONFIG_UBICOM32 ++	/* set ep0 to shared_fifo, otherwise urb will be put to out_qh but ep0_irq try to get the urb from in_qh*/ ++	hw_ep = musb->endpoints; ++	hw_ep->is_shared_fifo = true; ++#endif +  + 	for (epnum = 1; epnum < musb->config->num_eps; epnum++) { + 		musb_ep_select(mbase, epnum); +@@ -1291,14 +1339,27 @@ static int __init ep_config_from_hw(stru + 		/* REVISIT:  this algorithm is lazy, we should at least + 		 * try to pick a double buffered endpoint. + 		 */ ++#ifndef CONFIG_UBICOM32 + 		if (musb->bulk_ep) + 			continue; + 		musb->bulk_ep = hw_ep; ++#else ++		if ((musb->bulk_ep_in) && (musb->bulk_ep_out)) ++			continue; ++		/* Save theEP with 1024 Bytes FIFO for ISO */ ++		if(hw_ep->max_packet_sz_tx == 512) { ++			if (!musb->bulk_ep_in) { ++				musb->bulk_ep_in = hw_ep; ++			} else if (!musb->bulk_ep_out) { ++				musb->bulk_ep_out = hw_ep; ++			} ++		} ++#endif /* CONFIG_UBICOM32 */ + #endif + 	} +  + #ifdef CONFIG_USB_MUSB_HDRC_HCD +-	if (!musb->bulk_ep) { ++	if ((!musb->bulk_ep_in) || (!musb->bulk_ep_out)) { + 		pr_debug("%s: missing bulk\n", musb_driver_name); + 		return -EINVAL; + 	} +@@ -1407,12 +1468,16 @@ static int __init musb_core_init(u16 mus + 	musb->epmask = 1; +  + 	if (reg & MUSB_CONFIGDATA_DYNFIFO) { ++#ifndef CONFIG_UBICOM32 + 		if (musb->config->dyn_fifo) + 			status = ep_config_from_table(musb); +-		else { ++		else ++#endif ++		{ + 			ERR("reconfigure software for Dynamic FIFOs\n"); + 			status = -ENODEV; + 		} ++ + 	} else { + 		if (!musb->config->dyn_fifo) + 			status = ep_config_from_hw(musb); +@@ -1476,8 +1541,8 @@ static int __init musb_core_init(u16 mus +  + /*-------------------------------------------------------------------------*/ +  +-#if defined(CONFIG_ARCH_OMAP2430) || defined(CONFIG_ARCH_OMAP3430) +- ++#if defined(CONFIG_ARCH_OMAP2430) || defined(CONFIG_ARCH_OMAP3430) || defined(CONFIG_UBICOM32) ++static u32_t musb_int_count = 0; + static irqreturn_t generic_interrupt(int irq, void *__hci) + { + 	unsigned long	flags; +@@ -1486,10 +1551,17 @@ static irqreturn_t generic_interrupt(int +  + 	spin_lock_irqsave(&musb->lock, flags); +  ++#ifndef CONFIG_UBICOM32 + 	musb->int_usb = musb_readb(musb->mregs, MUSB_INTRUSB); + 	musb->int_tx = musb_readw(musb->mregs, MUSB_INTRTX); + 	musb->int_rx = musb_readw(musb->mregs, MUSB_INTRRX); ++#else ++	musb_read_int_status(&musb->int_usb, &musb->int_tx, &musb->int_rx); ++	//ubi32_usb_int_clr(); ++	musb_int_count++; ++#endif +  ++	DBG(4, "usb %x, tx %x, rx %x", musb->int_usb, musb->int_tx, musb->int_rx); + 	if (musb->int_usb || musb->int_tx || musb->int_rx) + 		retval = musb_interrupt(musb); +  +@@ -2241,6 +2313,10 @@ static struct platform_driver musb_drive +  + static int __init musb_init(void) + { ++#ifdef CONFIG_UBICOM32 ++	ubi32_usb_init(); ++#endif ++ + #ifdef CONFIG_USB_MUSB_HDRC_HCD + 	if (usb_disabled()) + 		return 0; +--- a/drivers/usb/musb/musb_core.h ++++ b/drivers/usb/musb/musb_core.h +@@ -339,7 +339,12 @@ struct musb { + 	 * queue until it completes or NAKs too much; then we try the next + 	 * endpoint. + 	 */ ++#ifdef CONFIG_UBICOM32 ++	struct musb_hw_ep	*bulk_ep_in; ++	struct musb_hw_ep	*bulk_ep_out; ++#else + 	struct musb_hw_ep	*bulk_ep; ++#endif +  + 	struct list_head	control;	/* of musb_qh */ + 	struct list_head	in_bulk;	/* of musb_qh */ +--- a/drivers/usb/musb/musb_gadget.c ++++ b/drivers/usb/musb/musb_gadget.c +@@ -434,7 +434,7 @@ void musb_g_tx(struct musb *musb, u8 epn + 		 * probably rates reporting as a host error + 		 */ + 		if (csr & MUSB_TXCSR_P_SENTSTALL) { +-			csr |= MUSB_TXCSR_P_WZC_BITS; ++			csr &= ~(MUSB_TXCSR_P_WZC_BITS); + 			csr &= ~MUSB_TXCSR_P_SENTSTALL; + 			musb_writew(epio, MUSB_TXCSR, csr); + 			break; +@@ -442,7 +442,7 @@ void musb_g_tx(struct musb *musb, u8 epn +  + 		if (csr & MUSB_TXCSR_P_UNDERRUN) { + 			/* we NAKed, no big deal ... little reason to care */ +-			csr |= MUSB_TXCSR_P_WZC_BITS; ++			csr &= ~(MUSB_TXCSR_P_WZC_BITS); + 			csr &= ~(MUSB_TXCSR_P_UNDERRUN + 					| MUSB_TXCSR_TXPKTRDY); + 			musb_writew(epio, MUSB_TXCSR, csr); +@@ -577,12 +577,18 @@ static void rxstate(struct musb *musb, s + { + 	const u8		epnum = req->epnum; + 	struct usb_request	*request = &req->request; +-	struct musb_ep		*musb_ep = &musb->endpoints[epnum].ep_out; ++	struct musb_ep		*musb_ep = NULL; + 	void __iomem		*epio = musb->endpoints[epnum].regs; +-	unsigned		fifo_count = 0; +-	u16			len = musb_ep->packet_sz; ++	u16			fifo_count = 0; ++	u16			len = 0; + 	u16			csr = musb_readw(epio, MUSB_RXCSR); +  ++	if (musb->endpoints[epnum].is_shared_fifo) ++		musb_ep = &musb->endpoints[epnum].ep_in; ++	else ++		musb_ep = &musb->endpoints[epnum].ep_out; ++	len =  musb_ep->packet_sz; ++ + 	/* We shouldn't get here while DMA is active, but we do... */ + 	if (dma_channel_status(musb_ep->dma) == MUSB_DMA_STATUS_BUSY) { + 		DBG(4, "DMA pending...\n"); +@@ -730,7 +736,7 @@ static void rxstate(struct musb *musb, s + 			 */ +  + 			/* ack the read! */ +-			csr |= MUSB_RXCSR_P_WZC_BITS; ++			csr &= ~MUSB_RXCSR_P_WZC_BITS; + 			csr &= ~MUSB_RXCSR_RXPKTRDY; + 			musb_writew(epio, MUSB_RXCSR, csr); + 		} +@@ -749,10 +755,15 @@ void musb_g_rx(struct musb *musb, u8 epn + 	u16			csr; + 	struct usb_request	*request; + 	void __iomem		*mbase = musb->mregs; +-	struct musb_ep		*musb_ep = &musb->endpoints[epnum].ep_out; ++	struct musb_ep		*musb_ep = NULL; + 	void __iomem		*epio = musb->endpoints[epnum].regs; + 	struct dma_channel	*dma; +  ++	if (musb->endpoints[epnum].is_shared_fifo) ++		musb_ep = &musb->endpoints[epnum].ep_in; ++	else ++		musb_ep = &musb->endpoints[epnum].ep_out; ++ + 	musb_ep_select(mbase, epnum); +  + 	request = next_request(musb_ep); +@@ -1756,7 +1767,9 @@ int usb_gadget_register_driver(struct us + 			} + 		} + 	} +- ++#ifndef CONFIG_USB_MUSB_OTG ++	musb_pullup(musb, 1); ++#endif + 	return retval; + } + EXPORT_SYMBOL(usb_gadget_register_driver); +--- a/drivers/usb/musb/musb_gadget_ep0.c ++++ b/drivers/usb/musb/musb_gadget_ep0.c +@@ -241,14 +241,14 @@ __acquires(musb->lock) + 		case USB_REQ_SET_ADDRESS: + 			/* change it after the status stage */ + 			musb->set_address = true; +-			musb->address = (u8) (ctrlrequest->wValue & 0x7f); ++			musb->address = (u8) (le16_to_cpu(ctrlrequest->wValue) & 0x7f); + 			handled = 1; + 			break; +  + 		case USB_REQ_CLEAR_FEATURE: + 			switch (recip) { + 			case USB_RECIP_DEVICE: +-				if (ctrlrequest->wValue ++				if (le16_to_cpu(ctrlrequest->wValue) + 						!= USB_DEVICE_REMOTE_WAKEUP) + 					break; + 				musb->may_wakeup = 0; +@@ -262,8 +262,8 @@ __acquires(musb->lock) +  + 				if (num == 0 + 						|| num >= MUSB_C_NUM_EPS +-						|| ctrlrequest->wValue +-							!= USB_ENDPOINT_HALT) ++						|| le16_to_cpu(ctrlrequest->wValue ++							!= USB_ENDPOINT_HALT)) + 					break; +  + 				if (ctrlrequest->wIndex & USB_DIR_IN) +@@ -293,7 +293,7 @@ __acquires(musb->lock) + 			switch (recip) { + 			case USB_RECIP_DEVICE: + 				handled = 1; +-				switch (ctrlrequest->wValue) { ++				switch (le16_to_cpu(ctrlrequest->wValue)) { + 				case USB_DEVICE_REMOTE_WAKEUP: + 					musb->may_wakeup = 1; + 					break; +@@ -375,8 +375,8 @@ stall: +  + 				if (epnum == 0 + 						|| epnum >= MUSB_C_NUM_EPS +-						|| ctrlrequest->wValue +-							!= USB_ENDPOINT_HALT) ++						|| le16_to_cpu(ctrlrequest->wValue ++							!= USB_ENDPOINT_HALT)) + 					break; +  + 				ep = musb->endpoints + epnum; +--- a/drivers/usb/musb/musb_host.c ++++ b/drivers/usb/musb/musb_host.c +@@ -160,7 +160,11 @@ static inline void musb_h_tx_start(struc + 	/* NOTE: no locks here; caller should lock and select EP */ + 	if (ep->epnum) { + 		txcsr = musb_readw(ep->regs, MUSB_TXCSR); ++#ifndef CONFIG_UBICOM32 + 		txcsr |= MUSB_TXCSR_TXPKTRDY | MUSB_TXCSR_H_WZC_BITS; ++#else ++		txcsr |= (MUSB_TXCSR_TXPKTRDY & (~MUSB_TXCSR_H_WZC_BITS)); ++#endif + 		musb_writew(ep->regs, MUSB_TXCSR, txcsr); + 	} else { + 		txcsr = MUSB_CSR0_H_SETUPPKT | MUSB_CSR0_TXPKTRDY; +@@ -235,6 +239,8 @@ musb_start_urb(struct musb *musb, int is + 		break; + 	default:		/* bulk, interrupt */ + 		/* actual_length may be nonzero on retry paths */ ++		if (urb->actual_length) ++			DBG(3 ,"musb_start_urb: URB %p retried, len: %d\n", urb, urb->actual_length); + 		buf = urb->transfer_buffer + urb->actual_length; + 		len = urb->transfer_buffer_length - urb->actual_length; + 	} +@@ -532,7 +538,11 @@ musb_host_packet_rx(struct musb *musb, s + 	musb_read_fifo(hw_ep, length, buf); +  + 	csr = musb_readw(epio, MUSB_RXCSR); ++#ifndef CONFIG_UBICOM32 + 	csr |= MUSB_RXCSR_H_WZC_BITS; ++#else ++	csr &= ~MUSB_RXCSR_H_WZC_BITS; ++#endif + 	if (unlikely(do_flush)) + 		musb_h_flush_rxfifo(hw_ep, csr); + 	else { +@@ -566,6 +576,7 @@ musb_rx_reinit(struct musb *musb, struct +  + 	/* if programmed for Tx, put it in RX mode */ + 	if (ep->is_shared_fifo) { ++#ifndef  CONFIG_UBICOM32 + 		csr = musb_readw(ep->regs, MUSB_TXCSR); + 		if (csr & MUSB_TXCSR_MODE) { + 			musb_h_tx_flush_fifo(ep); +@@ -580,7 +591,18 @@ musb_rx_reinit(struct musb *musb, struct + 		 */ + 		if (csr & MUSB_TXCSR_DMAMODE) + 			musb_writew(ep->regs, MUSB_TXCSR, MUSB_TXCSR_DMAMODE); ++ ++#else ++		/* clear mode (and everything else) to enable Rx */ + 		musb_writew(ep->regs, MUSB_TXCSR, 0); ++		/* scrub all previous state, clearing toggle */ ++		csr = musb_readw(ep->regs, MUSB_RXCSR); ++		if (csr & MUSB_RXCSR_RXPKTRDY) ++			WARNING("rx%d, packet/%d ready?\n", ep->epnum, ++				musb_readw(ep->regs, MUSB_RXCOUNT)); ++ ++		musb_h_flush_rxfifo(ep, MUSB_RXCSR_CLRDATATOG); ++#endif +  + 	/* scrub all previous state, clearing toggle */ + 	} else { +@@ -1108,6 +1130,16 @@ void musb_host_tx(struct musb *musb, u8  + 	void __iomem		*mbase = musb->mregs; + 	struct dma_channel	*dma; +  ++#ifdef CONFIG_UBICOM32 ++	if (hw_ep->is_shared_fifo) { ++		qh = hw_ep->in_qh; ++	} ++#ifdef CONFIG_USB_SERIAL_SIERRAWIRELESS ++	printk(KERN_DEBUG "OUT/TX%d end, csr %04x%s\n", epnum, tx_csr, ++			dma ? ", dma" : ""); ++#endif ++#endif ++ + 	musb_ep_select(mbase, epnum); + 	tx_csr = musb_readw(epio, MUSB_TXCSR); +  +@@ -1148,9 +1180,14 @@ void musb_host_tx(struct musb *musb, u8  + 		 * we have a candidate... NAKing is *NOT* an error + 		 */ + 		musb_ep_select(mbase, epnum); ++#ifndef CONFIG_UBICOM32 + 		musb_writew(epio, MUSB_TXCSR, + 				MUSB_TXCSR_H_WZC_BITS + 				| MUSB_TXCSR_TXPKTRDY); ++#else ++		musb_writew(epio, MUSB_TXCSR, ++				 MUSB_TXCSR_TXPKTRDY); ++#endif + 		return; + 	} +  +@@ -1324,8 +1361,14 @@ void musb_host_tx(struct musb *musb, u8  + 	qh->segsize = length; +  + 	musb_ep_select(mbase, epnum); ++#ifndef CONFIG_UBICOM32 ++	musb_writew(epio, MUSB_TXCSR, ++		    MUSB_TXCSR_H_WZC_BITS | MUSB_TXCSR_TXPKTRDY); ++#else + 	musb_writew(epio, MUSB_TXCSR, +-			MUSB_TXCSR_H_WZC_BITS | MUSB_TXCSR_TXPKTRDY); ++		    MUSB_TXCSR_MODE | MUSB_TXCSR_TXPKTRDY); ++#endif ++ + } +  +  +@@ -1385,7 +1428,11 @@ static void musb_bulk_rx_nak_timeout(str +  + 	/* clear nak timeout bit */ + 	rx_csr = musb_readw(epio, MUSB_RXCSR); ++#ifndef CONFIG_UBICOM32 + 	rx_csr |= MUSB_RXCSR_H_WZC_BITS; ++#else ++	rx_csr &= ~MUSB_RXCSR_H_WZC_BITS; ++#endif + 	rx_csr &= ~MUSB_RXCSR_DATAERROR; + 	musb_writew(epio, MUSB_RXCSR, rx_csr); +  +@@ -1454,6 +1501,13 @@ void musb_host_rx(struct musb *musb, u8  +  + 	pipe = urb->pipe; +  ++#ifdef CONFIG_UBICOM32 ++#ifdef CONFIG_USB_SERIAL_SIERRAWIRELESS ++		printk(KERN_DEBUG  "RXCSR%d %04x, reqpkt, len %zu%s\n", epnum, rx_csr, ++				xfer_len, dma ? ", dma" : ""); ++#endif ++#endif ++ + 	DBG(5, "<== hw %d rxcsr %04x, urb actual %d (+dma %zu)\n", + 		epnum, rx_csr, urb->actual_length, + 		dma ? dma->actual_len : 0); +@@ -1492,8 +1546,15 @@ void musb_host_rx(struct musb *musb, u8  + 				return; + 			} + 			musb_ep_select(mbase, epnum); ++#ifndef CONFIG_UBICOM32 + 			rx_csr |= MUSB_RXCSR_H_WZC_BITS; + 			rx_csr &= ~MUSB_RXCSR_DATAERROR; ++#else ++			/* NEED TO EVALUATE CHANGE */ ++			rx_csr &= ~MUSB_RXCSR_H_WZC_BITS; ++			rx_csr &= ~MUSB_RXCSR_DATAERROR; ++//			musb_writew(epio, MUSB_RXCSR, (~(MUSB_RXCSR_H_WZC_BITS))| MUSB_RXCSR_H_REQPKT); ++#endif + 			musb_writew(epio, MUSB_RXCSR, rx_csr); +  + 			goto finish; +@@ -1554,8 +1615,13 @@ void musb_host_rx(struct musb *musb, u8  + 		rx_csr &= ~MUSB_RXCSR_H_REQPKT; +  + 		musb_ep_select(mbase, epnum); ++#ifndef CONFIG_UBICOM32 + 		musb_writew(epio, MUSB_RXCSR, + 				MUSB_RXCSR_H_WZC_BITS | rx_csr); ++#else ++		musb_writew(epio, MUSB_RXCSR, ++				(~MUSB_RXCSR_H_WZC_BITS) & rx_csr); ++#endif + 	} + #endif + 	if (dma && (rx_csr & MUSB_RXCSR_DMAENAB)) { +@@ -1585,7 +1651,7 @@ void musb_host_rx(struct musb *musb, u8  + 			else + 				done = false; +  +-		} else  { ++		} else { + 		/* done if urb buffer is full or short packet is recd */ + 		done = (urb->actual_length + xfer_len >= + 				urb->transfer_buffer_length +@@ -1799,7 +1865,11 @@ static int musb_schedule( + 		if (musb_ep_get_qh(hw_ep, is_in) != NULL) + 			continue; +  ++#ifndef CONFIG_UBICOM32 + 		if (hw_ep == musb->bulk_ep) ++#else ++		if ((hw_ep == musb->bulk_ep_in) || (hw_ep == musb->bulk_ep_out)) /* Ubicom */ ++#endif + 			continue; +  + 		if (is_in) +@@ -1813,7 +1883,14 @@ static int musb_schedule( + 			best_end = epnum; + 		} + 	} ++ ++#ifdef CONFIG_UBICOM32 ++	if (((best_diff >= qh->maxpacket)) && ((qh->type == USB_ENDPOINT_XFER_BULK) && (!is_in))) ++		best_end = -1; ++#endif ++ + 	/* use bulk reserved ep1 if no other ep is free */ ++#ifndef CONFIG_UBICOM32 + 	if (best_end < 0 && qh->type == USB_ENDPOINT_XFER_BULK) { + 		hw_ep = musb->bulk_ep; + 		if (is_in) +@@ -1835,6 +1912,22 @@ static int musb_schedule( + 	} else if (best_end < 0) { + 		return -ENOSPC; + 	} ++#else ++	if (best_end < 0 && qh->type == USB_ENDPOINT_XFER_BULK) { ++		/* hw_ep = musb->bulk_ep; */ ++		if (is_in) { ++			head = &musb->in_bulk; ++			hw_ep = musb->bulk_ep_in; /* UBICOM */ ++		} ++		else { ++			head = &musb->out_bulk; ++			hw_ep = musb->bulk_ep_out; /* UBICOM */ ++		} ++		goto success; ++	} else if (best_end < 0) { ++		return -ENOSPC; ++	} ++#endif +  + 	idle = 1; + 	qh->mux = 0; +@@ -1846,6 +1939,13 @@ success: + 		list_add_tail(&qh->ring, head); + 		qh->mux = 1; + 	} ++	/* ++	 * It's not make sense to set NAK timeout when qh->mux = 0, ++	 * There is nothing else to schedule ++	 */ ++	if ((qh->type == USB_ENDPOINT_XFER_BULK) && (qh->mux == 0)) ++		qh->intv_reg = 0; ++ + 	qh->hw_ep = hw_ep; + 	qh->hep->hcpriv = qh; + 	if (idle) +@@ -1964,6 +2064,15 @@ static int musb_urb_enqueue( + 		/* ISO always uses logarithmic encoding */ + 		interval = min_t(u8, epd->bInterval, 16); + 		break; ++#ifdef COMFIG_UBICOM32 ++	case USB_ENDPOINT_XFER_BULK: ++		 if (epd->bEndpointAddress & USB_ENDPOINT_DIR_MASK) ++			interval = (USB_SPEED_HIGH == urb->dev->speed) ? 16: 2; ++		 else ++			interval = 0; ++		 break; ++#endif ++ + 	default: + 		/* REVISIT we actually want to use NAK limits, hinting to the + 		 * transfer scheduling logic to try some other qh, e.g. try +--- a/drivers/usb/musb/musb_io.h ++++ b/drivers/usb/musb/musb_io.h +@@ -58,6 +58,7 @@ static inline void writesb(const void __ +  + #ifndef CONFIG_BLACKFIN +  ++#ifndef CONFIG_UBICOM32 + /* NOTE:  these offsets are all in bytes */ +  + static inline u16 musb_readw(const void __iomem *addr, unsigned offset) +@@ -72,7 +73,37 @@ static inline void musb_writew(void __io +  + static inline void musb_writel(void __iomem *addr, unsigned offset, u32 data) + 	{ __raw_writel(data, addr + offset); } ++#else ++#include <asm/ubicom32-tio.h> ++static inline u16 musb_readw(const void __iomem *addr, unsigned offset) ++{ ++        u16 data; ++        usb_tio_read_u16((u32)(addr + offset), &data); ++        return data; ++} +  ++static inline u8 musb_readb(const void __iomem *addr, unsigned offset) ++{ ++        u8 data; ++        usb_tio_read_u8((u32)(addr + offset), &data); ++        return data; ++} ++ ++static inline void musb_writew(void __iomem *addr, unsigned offset, u16 data) ++{ ++        usb_tio_write_u16((u32)(addr + offset), data); ++} ++ ++static inline void musb_writeb(void __iomem *addr, unsigned offset, u8 data) ++{ ++        usb_tio_write_u8((u32)(addr + offset), data); ++} ++ ++static inline void  musb_read_int_status(u8_t *int_usb, u16_t *int_tx, u16_t *int_rx) ++{ ++	return usb_tio_read_int_status(int_usb, int_tx, int_rx); ++} ++#endif /* CONFIG_UBICOM32 */ +  + #ifdef CONFIG_USB_TUSB6010 +  +@@ -106,7 +137,7 @@ static inline void musb_writeb(void __io + 	__raw_writew(tmp, addr + (offset & ~1)); + } +  +-#else ++#elif !defined(CONFIG_UBICOM32) +  + static inline u8 musb_readb(const void __iomem *addr, unsigned offset) + 	{ return __raw_readb(addr + offset); } +--- a/drivers/usb/musb/musb_regs.h ++++ b/drivers/usb/musb/musb_regs.h +@@ -167,6 +167,7 @@ + 	(MUSB_TXCSR_H_NAKTIMEOUT | MUSB_TXCSR_H_RXSTALL \ + 	| MUSB_TXCSR_H_ERROR | MUSB_TXCSR_FIFONOTEMPTY) +  ++ + /* RXCSR in Peripheral and Host mode */ + #define MUSB_RXCSR_AUTOCLEAR		0x8000 + #define MUSB_RXCSR_DMAENAB		0x2000 +--- a/drivers/video/backlight/Kconfig ++++ b/drivers/video/backlight/Kconfig +@@ -100,6 +100,63 @@ config LCD_HP700 + 	  If you have an HP Jornada 700 series handheld (710/720/728) + 	  say Y to enable LCD control driver. +  ++config LCD_UBICOM32POWER ++	tristate "Ubicom LCD power Driver" ++	depends on LCD_CLASS_DEVICE && UBICOM32 ++	default n ++	help ++	  If you have a Ubicom32 based system with an LCD panel that requires ++	  power control, say Y to enable the power control driver for it. ++ ++config LCD_UBICOM32 ++	tristate "Ubicom Backlight Driver" ++	depends on LCD_CLASS_DEVICE && UBICOM32 ++	default n ++	help ++	  This driver takes care of initialization of LCD panels with ++	  built in controllers. ++ ++menu "Ubicom32 LCD Panel Support" ++	depends on UBICOM32 && LCD_UBICOM32 ++ ++config LCD_UBICOM32_TFT2N0369E_P ++	bool "TFT2N0369E (Portrait)" ++	default n ++	help ++	  Support for TFT2N0369 in portrait mode ++ ++config LCD_UBICOM32_TFT2N0369E_L ++	bool "TFT2N0369E (Landscape)" ++	default n ++	help ++	  Support for TFT2N0369 in landscape mode ++ ++config LCD_UBICOM32_CFAF240320KTTS ++	bool "CFAF240320KTTS" ++	default n ++	help ++	  Support for CFAF240320KTTS ++ ++config LCD_UBICOM32_CFAF240320KTTS_180 ++	bool "CFAF240320KTTS (180 rotation)" ++	default n ++	help ++	  Support for CFAF240320KTTS rotated 180 degrees ++ ++config LCD_UBICOM32_CFAF240320D ++	bool "CFAF240320D" ++	default n ++	help ++	  Support for CFAF240320D ++ ++config LCD_UBICOM32_CFAF320240F ++	bool "CFAF320240F" ++	default n ++	help ++	  Support for CFAF320240F ++ ++endmenu ++ + # + # Backlight + # +@@ -262,3 +319,11 @@ config BACKLIGHT_ADP5520 + 	  To compile this driver as a module, choose M here: the module will + 	  be called adp5520_bl. +  ++config BACKLIGHT_UBICOM32 ++	tristate "Ubicom Backlight Driver" ++	depends on BACKLIGHT_CLASS_DEVICE && UBICOM32 ++	default n ++	help ++	  If you have a Ubicom32 based system with a backlight say Y to enable the ++	  backlight driver. ++ +--- a/drivers/video/backlight/Makefile ++++ b/drivers/video/backlight/Makefile +@@ -10,6 +10,9 @@ obj-$(CONFIG_LCD_PLATFORM)	   += platfor + obj-$(CONFIG_LCD_VGG2432A4)	   += vgg2432a4.o + obj-$(CONFIG_LCD_TDO24M)	   += tdo24m.o + obj-$(CONFIG_LCD_TOSA)		   += tosa_lcd.o ++obj-$(CONFIG_LCD_LTV350QV)	   += ltv350qv.o ++obj-$(CONFIG_LCD_UBICOM32POWER)	   += ubicom32lcdpower.o ++obj-$(CONFIG_LCD_UBICOM32)	   += ubicom32lcd.o +  + obj-$(CONFIG_BACKLIGHT_CLASS_DEVICE) += backlight.o + obj-$(CONFIG_BACKLIGHT_ATMEL_PWM)    += atmel-pwm-bl.o +@@ -28,4 +31,4 @@ obj-$(CONFIG_BACKLIGHT_SAHARA)	+= kb3886 + obj-$(CONFIG_BACKLIGHT_WM831X)	+= wm831x_bl.o + obj-$(CONFIG_BACKLIGHT_ADX)    += adx_bl.o + obj-$(CONFIG_BACKLIGHT_ADP5520)	+= adp5520_bl.o +- ++obj-$(CONFIG_BACKLIGHT_UBICOM32) += ubicom32bl.o +--- a/drivers/video/Kconfig ++++ b/drivers/video/Kconfig +@@ -611,6 +611,50 @@ config FB_BFIN_T350MCQB + 	 This display is a QVGA 320x240 24-bit RGB display interfaced by an 8-bit wide PPI + 	 It uses PPI[0..7] PPI_FS1, PPI_FS2 and PPI_CLK. +  ++config FB_UBICOM32 ++	tristate "Ubicom32 Frame Buffer driver" ++	depends on FB && UBICOM32 ++	select FB_CFB_FILLRECT ++	select FB_CFB_COPYAREA ++	select FB_CFB_IMAGEBLIT ++	select FONT_6x11 if FRAMEBUFFER_CONSOLE ++	help ++	 This is the framebuffer device driver for the Ubicom32 architecture. ++	 You can configure video memory by using kernel command line parameters, for example: ++		video=ubicomfb:vram_size=512,init_value=0xffff ++ ++config FB_UBICOM32_PLIO80 ++	tristate "Ubicom32 80 Bus PLIO Frame Buffer driver" ++	depends on FB && UBICOM32 ++	select FB_CFB_FILLRECT ++	select FB_CFB_COPYAREA ++	select FB_CFB_IMAGEBLIT ++	select FONT_6x11 if FRAMEBUFFER_CONSOLE ++	select UBICOM32_PLIO ++	help ++	 This is a framebuffer device driver for the Ubicom32 architecture. ++	 You can configure the xres, yres and vram size (in kilobytes) by using ++	 kernel command line parameters, for example: ++		video=ubicom32vfb:xres=320,yres=240,vram_size=512 ++ ++config FB_UBICOM32_VIRTUAL ++	tristate "Ubicom32 Virtual Frame Buffer driver" ++	depends on FB && UBICOM32 ++	select FB_CFB_FILLRECT ++	select FB_CFB_COPYAREA ++	select FB_CFB_IMAGEBLIT ++	select FONT_6x11 if FRAMEBUFFER_CONSOLE ++	help ++	 This is a virtual framebuffer device driver for the Ubicom32 architecture. ++	 You can configure the xres, yres and vram size (in kilobytes) by using ++	 kernel command line parameters, for example: ++		video=ubicom32vfb:xres=320,yres=240,vram_size=512 ++ ++config FB_UBICOM32_VIRTUAL_NOAUTO ++	bool "Do not automatically load" ++	depends on FB_UBICOM32_VIRTUAL ++	help ++	 Select this option to prevent the VFB from automatically loading at boot. +  + config FB_STI + 	tristate "HP STI frame buffer device support" +--- a/drivers/video/Makefile ++++ b/drivers/video/Makefile +@@ -140,6 +140,10 @@ obj-$(CONFIG_FB_BFIN_T350MCQB)	  += bfin + obj-$(CONFIG_FB_MX3)		  += mx3fb.o + obj-$(CONFIG_FB_DA8XX)		  += da8xx-fb.o +  ++obj-$(CONFIG_FB_UBICOM32)         += ubicom32fb.o ++obj-$(CONFIG_FB_UBICOM32_PLIO80)  += ubicom32plio80.o ++obj-$(CONFIG_FB_UBICOM32_VIRTUAL) += ubicom32vfb.o ++ + # the test framebuffer is last + obj-$(CONFIG_FB_VIRTUAL)          += vfb.o +  +--- a/drivers/watchdog/Kconfig ++++ b/drivers/watchdog/Kconfig +@@ -973,6 +973,19 @@ config WATCHDOG_RIO + 	  machines.  The watchdog timeout period is normally one minute but + 	  can be changed with a boot-time parameter. +  ++# Ubicom32 ++ ++config UBI32_WDT ++	tristate "Ubicom32 Hardware Watchdog support" ++	depends on UBICOM32 ++	---help--- ++	  If you say yes here you will get support for the Ubicom32 On-Chip ++	  Watchdog Timer. If you have one of these processors and wish to ++	  have watchdog support enabled, say Y, otherwise say N. ++ ++	  To compile this driver as a module, choose M here: the ++	  module will be called ubi32_wdt. ++ + # XTENSA Architecture +  + # +--- a/drivers/watchdog/Makefile ++++ b/drivers/watchdog/Makefile +@@ -139,6 +139,9 @@ obj-$(CONFIG_SH_WDT) += shwdt.o + obj-$(CONFIG_WATCHDOG_RIO)		+= riowd.o + obj-$(CONFIG_WATCHDOG_CP1XXX)		+= cpwd.o +  ++# Ubicom32 Architecture ++obj-$(CONFIG_UBI32_WDT)			+= ubi32_wdt.o ++ + # XTENSA Architecture +  + # Architecture Independant +--- a/fs/binfmt_flat.c ++++ b/fs/binfmt_flat.c +@@ -67,6 +67,11 @@ + #define FLAT_DATA_ALIGN	(sizeof(void *)) + #endif +  ++#ifndef ARCH_FLAT_ALIGN ++#undef FLAT_DATA_ALIGN ++#define FLAT_DATA_ALIGN	ARCH_FLAT_ALIGN ++#endif ++ + #define RELOC_FAILED 0xff00ff01		/* Relocation incorrect somewhere */ + #define UNLOADED_LIB 0x7ff000ff		/* Placeholder for unused library */ +  +@@ -434,6 +439,7 @@ static int load_flat_file(struct linux_b + 	loff_t fpos; + 	unsigned long start_code, end_code; + 	int ret; ++	int flush_happened = 0; +  + 	hdr = ((struct flat_hdr *) bprm->buf);		/* exec-header */ + 	inode = bprm->file->f_path.dentry->d_inode; +@@ -520,6 +526,7 @@ static int load_flat_file(struct linux_b + 		/* OK, This is the point of no return */ + 		set_personality(PER_LINUX_32BIT); + 		setup_new_exec(bprm); ++		flush_happened = 1; + 	} +  + 	/* +@@ -534,6 +541,12 @@ static int load_flat_file(struct linux_b + 	 * it all together. + 	 */ + 	if ((flags & (FLAT_FLAG_RAM|FLAT_FLAG_GZIP)) == 0) { ++ ++#ifdef ARCH_FLAT_ALIGN_TEXT ++		printk("Unable to mmap rom with ARCH alignment requirements\n"); ++		ret = -ENOEXEC; ++		goto err; ++#endif + 		/* + 		 * this should give us a ROM ptr,  but if it doesn't we don't + 		 * really care +@@ -552,7 +565,7 @@ static int load_flat_file(struct linux_b + 			goto err; + 		} +  +-		len = data_len + extra + MAX_SHARED_LIBS * sizeof(unsigned long); ++		len = data_len + extra + ALIGN(MAX_SHARED_LIBS * sizeof(unsigned long), FLAT_DATA_ALIGN); + 		len = PAGE_ALIGN(len); + 		down_write(¤t->mm->mmap_sem); + 		realdatastart = do_mmap(0, 0, len, +@@ -571,6 +584,7 @@ static int load_flat_file(struct linux_b + 		datapos = ALIGN(realdatastart + + 				MAX_SHARED_LIBS * sizeof(unsigned long), + 				FLAT_DATA_ALIGN); ++		//datapos = realdatastart + ALIGN(MAX_SHARED_LIBS * sizeof(unsigned long), ARCH_FLAT_ALIGN); +  + 		DBG_FLT("BINFMT_FLAT: Allocated data+bss+stack (%d bytes): %x\n", + 				(int)(data_len + bss_len + stack_len), (int)datapos); +@@ -599,7 +613,11 @@ static int load_flat_file(struct linux_b + 		memp_size = len; + 	} else { +  +-		len = text_len + data_len + extra + MAX_SHARED_LIBS * sizeof(unsigned long); ++		len = text_len + data_len + extra + ALIGN(MAX_SHARED_LIBS * sizeof(unsigned long), FLAT_DATA_ALIGN); ++#ifdef ARCH_FLAT_ALIGN_TEXT ++		/* Reserve space for the text alignment. */ ++		len += FLAT_DATA_ALIGN; ++#endif + 		len = PAGE_ALIGN(len); + 		down_write(¤t->mm->mmap_sem); + 		textpos = do_mmap(0, 0, len, +@@ -615,10 +633,17 @@ static int load_flat_file(struct linux_b + 			goto err; + 		} +  ++		memp = textpos; ++#ifdef ARCH_FLAT_ALIGN_TEXT ++		textpos = ALIGN(textpos + sizeof(struct flat_hdr), FLAT_DATA_ALIGN) - sizeof(struct flat_hdr); ++#endif + 		realdatastart = textpos + ntohl(hdr->data_start); + 		datapos = ALIGN(realdatastart + + 				MAX_SHARED_LIBS * sizeof(unsigned long), + 				FLAT_DATA_ALIGN); ++//		datapos = realdatastart + ALIGN(MAX_SHARED_LIBS * sizeof(unsigned long), ARCH_FLAT_ALIGN); ++//		reloc = (unsigned long *) (textpos + ntohl(hdr->reloc_start) + ++//					   ALIGN(MAX_SHARED_LIBS * sizeof(unsigned long), ARCH_FLAT_ALIGN)); +  + 		reloc = (unsigned long *) + 			(datapos + (ntohl(hdr->reloc_start) - text_len)); +@@ -658,7 +683,7 @@ static int load_flat_file(struct linux_b + 		} + 		if (IS_ERR_VALUE(result)) { + 			printk("Unable to read code+data+bss, errno %d\n",(int)-result); +-			do_munmap(current->mm, textpos, text_len + data_len + extra + ++			do_munmap(current->mm, memp, text_len + data_len + extra + + 				MAX_SHARED_LIBS * sizeof(unsigned long)); + 			ret = result; + 			goto err; +@@ -671,6 +696,9 @@ static int load_flat_file(struct linux_b +  + 	/* The main program needs a little extra setup in the task structure */ + 	start_code = textpos + sizeof (struct flat_hdr); ++#ifdef ARCH_FLAT_ALIGN_TEXT ++	BUG_ON(ALIGN(start_code, FLAT_DATA_ALIGN) != start_code); ++#endif + 	end_code = textpos + text_len; + 	if (id == 0) { + 		current->mm->start_code = start_code; +@@ -799,6 +827,13 @@ static int load_flat_file(struct linux_b +  + 	return 0; + err: ++	if (flush_happened) { ++		/* ++		 * The parent process has already started running. We cannot allow the child to return back to user space ++		 * as this child is still uning the parent stack and 2 will clobber each other. We are going to kill this child. ++		 */ ++		do_exit(SIGTERM); ++	} + 	return ret; + } +  +--- a/fs/Kconfig.binfmt ++++ b/fs/Kconfig.binfmt +@@ -30,7 +30,7 @@ config COMPAT_BINFMT_ELF + config BINFMT_ELF_FDPIC + 	bool "Kernel support for FDPIC ELF binaries" + 	default y +-	depends on (FRV || BLACKFIN || (SUPERH32 && !MMU)) ++	depends on (FRV || BLACKFIN || (SUPERH32 && !MMU) || UBICOM32) + 	help + 	  ELF FDPIC binaries are based on ELF, but allow the individual load + 	  segments of a binary to be located in memory independently of each +--- a/include/asm-generic/resource.h ++++ b/include/asm-generic/resource.h +@@ -69,13 +69,16 @@ + /* +  * boot-time rlimit defaults for the init task: +  */ ++#ifndef	CONFIG_ELF_CORE ++#define	CONFIG_USER_ELF_CORE_SIZE	0 ++#endif + #define INIT_RLIMITS							\ + {									\ + 	[RLIMIT_CPU]		= {  RLIM_INFINITY,  RLIM_INFINITY },	\ + 	[RLIMIT_FSIZE]		= {  RLIM_INFINITY,  RLIM_INFINITY },	\ + 	[RLIMIT_DATA]		= {  RLIM_INFINITY,  RLIM_INFINITY },	\ + 	[RLIMIT_STACK]		= {       _STK_LIM,   _STK_LIM_MAX },	\ +-	[RLIMIT_CORE]		= {              0,  RLIM_INFINITY },	\ ++	[RLIMIT_CORE]		= { CONFIG_USER_ELF_CORE_SIZE,  RLIM_INFINITY },	\ + 	[RLIMIT_RSS]		= {  RLIM_INFINITY,  RLIM_INFINITY },	\ + 	[RLIMIT_NPROC]		= {              0,              0 },	\ + 	[RLIMIT_NOFILE]		= {       INR_OPEN,       INR_OPEN },	\ +--- a/include/linux/elf-em.h ++++ b/include/linux/elf-em.h +@@ -41,6 +41,7 @@ +  * up with a final number. +  */ + #define EM_ALPHA	0x9026 ++#define EM_UBICOM32 	        0xde3d	/* Ubicom32; no ABI */ +  + /* Bogus old v850 magic number, used by old tools. */ + #define EM_CYGNUS_V850	0x9080 +--- a/include/linux/fb.h ++++ b/include/linux/fb.h +@@ -152,6 +152,10 @@ struct dentry; + #define FB_ACCEL_PROSAVAGE_DDR  0x8d	/* S3 ProSavage DDR             */ + #define FB_ACCEL_PROSAVAGE_DDRK 0x8e	/* S3 ProSavage DDR-K           */ +  ++#define FB_ACCEL_UBICOM32		0x0100	/* Ubicom32			*/ ++#define FB_ACCEL_UBICOM32_VFB		0x0101	/* Ubicom32 VFB			*/ ++#define FB_ACCEL_UBICOM32_PLIO80	0x0102	/* Ubicom32 PLIO80		*/ ++ + struct fb_fix_screeninfo { + 	char id[16];			/* identification string eg "TT Builtin" */ + 	unsigned long smem_start;	/* Start of frame buffer mem */ +--- a/include/linux/if_ppp.h ++++ b/include/linux/if_ppp.h +@@ -114,14 +114,14 @@ struct pppol2tp_ioc_stats { + 	__u16		tunnel_id;	/* redundant */ + 	__u16		session_id;	/* if zero, get tunnel stats */ + 	__u32		using_ipsec:1;	/* valid only for session_id == 0 */ +-	aligned_u64	tx_packets; +-	aligned_u64	tx_bytes; +-	aligned_u64	tx_errors; +-	aligned_u64	rx_packets; +-	aligned_u64	rx_bytes; +-	aligned_u64	rx_seq_discards; +-	aligned_u64	rx_oos_packets; +-	aligned_u64	rx_errors; ++	__u64	tx_packets; ++	__u64	tx_bytes; ++	__u64	tx_errors; ++	__u64	rx_packets; ++	__u64	rx_bytes; ++	__u64	rx_seq_discards; ++	__u64	rx_oos_packets; ++	__u64	rx_errors; + }; +  + #define ifr__name       b.ifr_ifrn.ifrn_name +--- a/include/linux/oprofile.h ++++ b/include/linux/oprofile.h +@@ -102,6 +102,8 @@ void oprofile_add_sample(struct pt_regs  +  */ + void oprofile_add_ext_sample(unsigned long pc, struct pt_regs * const regs, + 				unsigned long event, int is_kernel); ++void oprofile_add_ext_sample_cpu(unsigned long pc, struct pt_regs * const regs, ++				unsigned long event, int is_kernel, int cpu); +  + /* Use this instead when the PC value is not from the regs. Doesn't +  * backtrace. */ +--- a/include/linux/serial_core.h ++++ b/include/linux/serial_core.h +@@ -179,6 +179,9 @@ + /* BCM63xx family SoCs */ + #define PORT_BCM63XX	89 +  ++/* Ubicom32 */ ++#define PORT_UBI32_UARTTIO	87 ++ + #ifdef __KERNEL__ +  + #include <linux/compiler.h> +--- a/include/linux/slab.h ++++ b/include/linux/slab.h +@@ -328,4 +328,14 @@ static inline void *kzalloc_node(size_t  +  + void __init kmem_cache_init_late(void); +  ++struct kmem_cache_size_info { ++	unsigned short page; ++	unsigned short order; ++}; ++ ++/* ++ * get info on all the memory allocated by slab for this named cache ++ */ ++extern int kmem_cache_block_info(char *name, struct kmem_cache_size_info *data, int max_data); ++ + #endif	/* _LINUX_SLAB_H */ +--- a/init/Kconfig ++++ b/init/Kconfig +@@ -844,6 +844,12 @@ config ELF_CORE + 	help + 	  Enable support for generating core dumps. Disabling saves about 4k. +  ++config USER_ELF_CORE_SIZE ++	int "user core dump size (10MB to 32MB)" ++	range 10485760 33554432 ++	default 16777216 ++	depends on ELF_CORE ++ + config PCSPKR_PLATFORM + 	bool "Enable PC-Speaker support" if EMBEDDED + 	depends on ALPHA || X86 || MIPS || PPC_PREP || PPC_CHRP || PPC_PSERIES +--- a/kernel/module.c ++++ b/kernel/module.c +@@ -2945,6 +2945,9 @@ static int m_show(struct seq_file *m, vo + 	/* Used by oprofile and other similar tools. */ + 	seq_printf(m, " 0x%p", mod->module_core); +  ++#ifdef ARCH_PROC_MODULES_EXTRA ++	ARCH_PROC_MODULES_EXTRA(m, mod); ++#endif + 	/* Taints info */ + 	if (mod->taints) + 		seq_printf(m, " %s", module_flags(mod, buf)); +@@ -3097,8 +3100,12 @@ void print_modules(void) + 	printk(KERN_DEFAULT "Modules linked in:"); + 	/* Most callers should already have preempt disabled, but make sure */ + 	preempt_disable(); +-	list_for_each_entry_rcu(mod, &modules, list) ++	list_for_each_entry_rcu(mod, &modules, list) { + 		printk(" %s%s", mod->name, module_flags(mod, buf)); ++#ifdef ARCH_OOPS_MODULE_EXTRA ++		ARCH_OOPS_MODULE_EXTRA(mod); ++#endif ++	} + 	preempt_enable(); + 	if (last_unloaded_module[0]) + 		printk(" [last unloaded: %s]", last_unloaded_module); +--- a/kernel/sched_clock.c ++++ b/kernel/sched_clock.c +@@ -38,8 +38,7 @@ +  */ + unsigned long long __attribute__((weak)) sched_clock(void) + { +-	return (unsigned long long)(jiffies - INITIAL_JIFFIES) +-					* (NSEC_PER_SEC / HZ); ++	return (get_jiffies_64() - INITIAL_JIFFIES) * (NSEC_PER_SEC / HZ); + } +  + static __read_mostly int sched_clock_running; +--- a/lib/Kconfig.debug ++++ b/lib/Kconfig.debug +@@ -690,7 +690,7 @@ config FRAME_POINTER + 	bool "Compile the kernel with frame pointers" + 	depends on DEBUG_KERNEL && \ + 		(CRIS || M68K || M68KNOMMU || FRV || UML || \ +-		 AVR32 || SUPERH || BLACKFIN || MN10300) || \ ++		 AVR32 || SUPERH || BLACKFIN || MN10300 || UBICOM32) || \ + 		ARCH_WANT_FRAME_POINTERS + 	default y if (DEBUG_INFO && UML) || ARCH_WANT_FRAME_POINTERS + 	help +--- a/mm/Makefile ++++ b/mm/Makefile +@@ -45,3 +45,5 @@ obj-$(CONFIG_MEMORY_FAILURE) += memory-f + obj-$(CONFIG_HWPOISON_INJECT) += hwpoison-inject.o + obj-$(CONFIG_DEBUG_KMEMLEAK) += kmemleak.o + obj-$(CONFIG_DEBUG_KMEMLEAK_TEST) += kmemleak-test.o ++ ++CFLAGS_slab.o := $(PROFILING) -O2 +--- a/mm/slab.c ++++ b/mm/slab.c +@@ -4086,6 +4086,68 @@ out: +  + #ifdef CONFIG_SLABINFO +  ++ ++/* ++ * get info on all the memory allocated by slab for this named cache ++ */ ++int kmem_cache_block_info(char *name, struct kmem_cache_size_info *data, int max_data) ++{ ++	int res = 0; ++	int found = 0; ++	int node; ++	struct kmem_cache *cachep; ++	struct kmem_list3 *l3; ++	struct slab *slabp; ++ ++	/* Find the cache in the chain of caches. */ ++	mutex_lock(&cache_chain_mutex); ++	list_for_each_entry(cachep, &cache_chain, next) { ++		if (strcmp(cachep->name, name) == 0) { ++			found = 1; ++			break; ++		} ++	} ++	mutex_unlock(&cache_chain_mutex); ++	if (!found) { ++		return 0; ++	} ++	for_each_online_node(node) { ++		l3 = cachep->nodelists[node]; ++		if (!l3) ++			continue; ++		if (res >= max_data) ++			break; ++		check_irq_on(); ++		spin_lock_irq(&l3->list_lock); ++ ++		list_for_each_entry(slabp, &l3->slabs_full, list) { ++			if (res >= max_data) ++				break; ++			data[res].page = ((unsigned int)slabp->s_mem >> PAGE_SHIFT) & 0xffff; ++			data[res].order = cachep->gfporder; ++			res++; ++		} ++		list_for_each_entry(slabp, &l3->slabs_partial, list) { ++			if (res >= max_data) ++				break; ++			data[res].page = ((unsigned int)slabp->s_mem >> PAGE_SHIFT) & 0xffff; ++			data[res].order = cachep->gfporder; ++			res++; ++		} ++		list_for_each_entry(slabp, &l3->slabs_free, list) { ++			if (res >= max_data) ++				break; ++			data[res].page = ((unsigned int)slabp->s_mem >> PAGE_SHIFT) & 0xffff; ++			data[res].order = cachep->gfporder; ++			res++; ++		} ++ ++		spin_unlock_irq(&l3->list_lock); ++	} ++ ++	return res; ++} ++ + static void print_slabinfo_header(struct seq_file *m) + { + 	/* +--- a/scripts/mod/file2alias.c ++++ b/scripts/mod/file2alias.c +@@ -783,6 +783,15 @@ void handle_moddevtable(struct module *m + 			+ sym->st_value; + 	} +  ++	/* ++	 * somehow our gcc is not generating st_size correctly and set 0 for some symbols. ++	 * and 0 size will break do_table since it adjust size to (size - id_size) ++	 * this is to make sure st_size fall in range. ++	 */ ++	if (sym->st_size == 0 || sym->st_size > info->sechdrs[sym->st_shndx].sh_size) { ++		sym->st_size = info->sechdrs[sym->st_shndx].sh_size; ++	} ++ + 	if (sym_is(symname, "__mod_pci_device_table")) + 		do_table(symval, sym->st_size, + 			 sizeof(struct pci_device_id), "pci", +--- a/sound/Kconfig ++++ b/sound/Kconfig +@@ -110,6 +110,8 @@ source "sound/parisc/Kconfig" +  + source "sound/soc/Kconfig" +  ++source "sound/ubicom32/Kconfig" ++ + endif # SND +  + menuconfig SOUND_PRIME +--- a/sound/Makefile ++++ b/sound/Makefile +@@ -6,7 +6,7 @@ obj-$(CONFIG_SOUND_PRIME) += sound_firmw + obj-$(CONFIG_SOUND_PRIME) += oss/ + obj-$(CONFIG_DMASOUND) += oss/ + obj-$(CONFIG_SND) += core/ i2c/ drivers/ isa/ pci/ ppc/ arm/ sh/ synth/ usb/ \ +-	sparc/ spi/ parisc/ pcmcia/ mips/ soc/ atmel/ ++	sparc/ spi/ parisc/ pcmcia/ mips/ soc/ atmel/ ubicom32/ + obj-$(CONFIG_SND_AOA) += aoa/ +  + # This one must be compilable even if sound is configured out diff --git a/target/linux/ubicom32/patches-2.6.32/110-vmlinux_lds_fix.patch b/target/linux/ubicom32/patches-2.6.32/110-vmlinux_lds_fix.patch new file mode 100644 index 000000000..1a1430887 --- /dev/null +++ b/target/linux/ubicom32/patches-2.6.32/110-vmlinux_lds_fix.patch @@ -0,0 +1,150 @@ +--- a/arch/ubicom32/kernel/vmlinux.lds.S ++++ b/arch/ubicom32/kernel/vmlinux.lds.S +@@ -25,7 +25,6 @@ +  *   arch/blackfin +  *   arch/parisc +  */ +-#include <asm-generic/vmlinux.lds.h> + #include <asm/ocm_size.h> + #include <asm/memory_map.h> + #include <asm/thread_info.h> +@@ -201,94 +200,28 @@ SECTIONS { + 		*(__ex_table) + 		__stop___ex_table = .; +  +-		*(.rodata) *(.rodata.*) +-		*(__vermagic)		/* Kernel version magic */ +-		*(__markers_strings) +-		*(.rodata1) +-		*(.rodata.str1.1) +-		*(__tracepoints_strings) +- +-		 /* PCI quirks */ +-		__start_pci_fixups_early = . ; +-			*(.pci_fixup_early) +-		__end_pci_fixups_early = . ; +-		__start_pci_fixups_header = . ; +-			*(.pci_fixup_header) +-		__end_pci_fixups_header = . ; +-		__start_pci_fixups_final = . ; +-			*(.pci_fixup_final) +-		__end_pci_fixups_final = . ; +-		__start_pci_fixups_enable = . ; +-			*(.pci_fixup_enable) +-		__end_pci_fixups_enable = . ; +-		__start_pci_fixups_resume = . ; +-		       *(.pci_fixup_resume) +-		__end_pci_fixups_resume = . ; +-		__start_pci_fixups_resume_early = . ; +-		       *(.pci_fixup_resume_early) +-		__end_pci_fixups_resume_early = . ; +-		__start_pci_fixups_suspend  = . ; +-		       *(.pci_fixup_suspend) +-		__end_pci_fixups_suspend = . ; +- +-		__start_builtin_fw = . ; +-			*(.builtin_fw) +-		__end_builtin_fw = . ; +- +- +-		/* Kernel symbol table: Normal symbols */ +-		. = ALIGN(4); +-		__start___ksymtab = .; +-		*(__ksymtab) +-		__stop___ksymtab = .; +- +-		/* Kernel symbol table: GPL-only symbols */ +-		__start___ksymtab_gpl = .; +-		*(__ksymtab_gpl) +-		__stop___ksymtab_gpl = .; +- +-		/* Kernel symbol table: Normal unused symbols */ +-		__start___ksymtab_unused = .; +-		*(__ksymtab_unused) +-		__stop___ksymtab_unused = .; +- +-		/* Kernel symbol table: GPL-only unused symbols */ +-		__start___ksymtab_unused_gpl = .; +-		*(__ksymtab_unused_gpl) +-		__stop___ksymtab_unused_gpl = .; +- +-		/* Kernel symbol table: GPL-future symbols */ +-		__start___ksymtab_gpl_future = .; +-		*(__ksymtab_gpl_future) +-		__stop___ksymtab_gpl_future = .; +- +-		/* Kernel symbol table: Normal symbols */ +-		__start___kcrctab = .; +-		*(__kcrctab) +-		__stop___kcrctab = .; +- +-		/* Kernel symbol table: GPL-only symbols */ +-		__start___kcrctab_gpl = .; +-		*(__kcrctab_gpl) +-		__stop___kcrctab_gpl = .; +- +-		/* Kernel symbol table: GPL-future symbols */ +-		__start___kcrctab_gpl_future = .; +-		*(__kcrctab_gpl_future) +-		__stop___kcrctab_gpl_future = .; ++	} > TEXT +  +-		/* Kernel symbol table: strings */ +-		*(__ksymtab_strings) ++	RO_DATA(16) +  +-		/* Built-in module parameters */ +-		. = ALIGN(4) ; +-		__start___param = .; +-		*(__param) +-		__stop___param = .; ++	.rodata : {} > TEXT ++	.rodata1 : {} > TEXT ++	.pci_fixup : {} > TEXT ++	.builtin_fw : {} > TEXT ++	.rio_route : {} > TEXT ++	.tracedata : {} > TEXT ++	__ksymtab : {} > TEXT ++	__ksymtab_gpl : {} > TEXT ++	__ksymtab_gpl_future : {} > TEXT ++	__kcrctab_gpl : {} > TEXT ++	__kcrctab_unused : {} > TEXT ++	__kcrctab_unused_gpl : {} > TEXT ++	__kcrctab_gpl_future : {} > TEXT ++	__ksymtab_strings : {} > TEXT ++	__init_rodata : {} > TEXT ++	__param : {} > TEXT +  +-		. = ALIGN(4) ; +-		_etext = . ; +-	} > TEXT ++	_etext = .; +  + 	.data DATA_ADDR : { + 		. = ALIGN(4); +@@ -349,12 +282,6 @@ SECTIONS { + 	    PROVIDE (___eh_frame_end = .); + 	  } > INIT +  +-	/DISCARD/ : { +-		EXIT_TEXT +-		EXIT_DATA +-		*(.exitcall.exit) +-	} +- + 	.bss : { + 		. = ALIGN(4); + 		_sbss = . ; +@@ -365,6 +292,12 @@ SECTIONS { + 		_end = . ; + 	} > BSS +  ++	/DISCARD/ : { ++		EXIT_TEXT ++		EXIT_DATA ++		*(.exitcall.exit) ++	} ++ + 	NOTES > BSS +  + } diff --git a/target/linux/ubicom32/patches-2.6.32/120-libgcc_func.patch b/target/linux/ubicom32/patches-2.6.32/120-libgcc_func.patch new file mode 100644 index 000000000..fee4ece00 --- /dev/null +++ b/target/linux/ubicom32/patches-2.6.32/120-libgcc_func.patch @@ -0,0 +1,419 @@ +--- a/arch/ubicom32/Makefile ++++ b/arch/ubicom32/Makefile +@@ -60,9 +60,6 @@ cflags-$(CONFIG_UBICOM32_V4)		:= -march= + ldflags-$(CONFIG_LINKER_RELAXATION)	:= --relax + LDFLAGS_vmlinux := $(ldflags-y) +  +-GCCLIBDIR := $(dir $(shell $(CC) $(cflags-y) -print-libgcc-file-name)) +-GCC_LIBS := $(GCCLIBDIR)/libgcc.a +- + KBUILD_CFLAGS += $(cflags-y) -ffunction-sections + KBUILD_AFLAGS += $(cflags-y) +  +@@ -84,7 +81,6 @@ core-y	+= arch/$(ARCH)/kernel/ \ + drivers-$(CONFIG_OPROFILE)	+= arch/ubicom32/oprofile/ +  + libs-y	+= arch/$(ARCH)/lib/ +-libs-y	+= $(GCC_LIBS) +  + archclean: +  +--- a/arch/ubicom32/lib/Makefile ++++ b/arch/ubicom32/lib/Makefile +@@ -30,3 +30,4 @@ + # +  + lib-y	:= checksum.o delay.o mem_ubicom32.o ++lib-y	+= ashldi3.o ashrdi3.o divmod.o lshrdi3.o muldi3.o +--- /dev/null ++++ b/arch/ubicom32/lib/ashldi3.c +@@ -0,0 +1,62 @@ ++/* ashrdi3.c extracted from gcc-2.95.2/libgcc2.c which is: */ ++/* Copyright (C) 1989, 92-98, 1999 Free Software Foundation, Inc. ++ ++This file is part of GNU CC. ++ ++GNU CC 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, or (at your option) ++any later version. ++ ++GNU CC 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 GNU CC; see the file COPYING.  If not, write to ++the Free Software Foundation, 59 Temple Place - Suite 330, ++Boston, MA 02111-1307, USA.  */ ++ ++#define BITS_PER_UNIT 8 ++ ++typedef		 int SItype	__attribute__ ((mode (SI))); ++typedef unsigned int USItype	__attribute__ ((mode (SI))); ++typedef		 int DItype	__attribute__ ((mode (DI))); ++typedef int word_type __attribute__ ((mode (__word__))); ++ ++struct DIstruct {SItype high, low;}; ++ ++typedef union ++{ ++  struct DIstruct s; ++  DItype ll; ++} DIunion; ++ ++DItype ++__ashldi3 (DItype u, word_type b) ++{ ++  DIunion w; ++  word_type bm; ++  DIunion uu; ++ ++  if (b == 0) ++    return u; ++ ++  uu.ll = u; ++ ++  bm = (sizeof (SItype) * BITS_PER_UNIT) - b; ++  if (bm <= 0) ++    { ++      w.s.low = 0; ++      w.s.high = (USItype)uu.s.low << -bm; ++    } ++  else ++    { ++      USItype carries = (USItype)uu.s.low >> bm; ++      w.s.low = (USItype)uu.s.low << b; ++      w.s.high = ((USItype)uu.s.high << b) | carries; ++    } ++ ++  return w.ll; ++} +--- /dev/null ++++ b/arch/ubicom32/lib/ashrdi3.c +@@ -0,0 +1,63 @@ ++/* ashrdi3.c extracted from gcc-2.7.2/libgcc2.c which is: */ ++/* Copyright (C) 1989, 1992, 1993, 1994, 1995 Free Software Foundation, Inc. ++ ++This file is part of GNU CC. ++ ++GNU CC 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, or (at your option) ++any later version. ++ ++GNU CC 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 GNU CC; see the file COPYING.  If not, write to ++the Free Software Foundation, 59 Temple Place - Suite 330, ++Boston, MA 02111-1307, USA.  */ ++ ++#define BITS_PER_UNIT 8 ++ ++typedef		 int SItype	__attribute__ ((mode (SI))); ++typedef unsigned int USItype	__attribute__ ((mode (SI))); ++typedef		 int DItype	__attribute__ ((mode (DI))); ++typedef int word_type __attribute__ ((mode (__word__))); ++ ++struct DIstruct {SItype high, low;}; ++ ++typedef union ++{ ++  struct DIstruct s; ++  DItype ll; ++} DIunion; ++ ++DItype ++__ashrdi3 (DItype u, word_type b) ++{ ++  DIunion w; ++  word_type bm; ++  DIunion uu; ++ ++  if (b == 0) ++    return u; ++ ++  uu.ll = u; ++ ++  bm = (sizeof (SItype) * BITS_PER_UNIT) - b; ++  if (bm <= 0) ++    { ++      /* w.s.high = 1..1 or 0..0 */ ++      w.s.high = uu.s.high >> (sizeof (SItype) * BITS_PER_UNIT - 1); ++      w.s.low = uu.s.high >> -bm; ++    } ++  else ++    { ++      USItype carries = (USItype)uu.s.high << bm; ++      w.s.high = uu.s.high >> b; ++      w.s.low = ((USItype)uu.s.low >> b) | carries; ++    } ++ ++  return w.ll; ++} +--- /dev/null ++++ b/arch/ubicom32/lib/divmod.c +@@ -0,0 +1,85 @@ ++unsigned long ++udivmodsi4(unsigned long num, unsigned long den, int modwanted) ++{ ++  unsigned long bit = 1; ++  unsigned long res = 0; ++ ++  while (den < num && bit && !(den & (1L<<31))) ++    { ++      den <<=1; ++      bit <<=1; ++    } ++  while (bit) ++    { ++      if (num >= den) ++	{ ++	  num -= den; ++	  res |= bit; ++	} ++      bit >>=1; ++      den >>=1; ++    } ++  if (modwanted) return num; ++  return res; ++} ++ ++long ++__udivsi3 (long a, long b) ++{ ++  return udivmodsi4 (a, b, 0); ++} ++ ++long ++__umodsi3 (long a, long b) ++{ ++  return udivmodsi4 (a, b, 1); ++} ++ ++long ++__divsi3 (long a, long b) ++{ ++  int neg = 0; ++  long res; ++ ++  if (a < 0) ++    { ++      a = -a; ++      neg = !neg; ++    } ++ ++  if (b < 0) ++    { ++      b = -b; ++      neg = !neg; ++    } ++ ++  res = udivmodsi4 (a, b, 0); ++ ++  if (neg) ++    res = -res; ++ ++  return res; ++} ++ ++long ++__modsi3 (long a, long b) ++{ ++  int neg = 0; ++  long res; ++ ++  if (a < 0) ++    { ++      a = -a; ++      neg = 1; ++    } ++ ++  if (b < 0) ++    b = -b; ++ ++  res = udivmodsi4 (a, b, 1); ++ ++  if (neg) ++    res = -res; ++ ++  return res; ++} +--- /dev/null ++++ b/arch/ubicom32/lib/lshrdi3.c +@@ -0,0 +1,62 @@ ++/* lshrdi3.c extracted from gcc-2.7.2/libgcc2.c which is: */ ++/* Copyright (C) 1989, 1992, 1993, 1994, 1995 Free Software Foundation, Inc. ++ ++This file is part of GNU CC. ++ ++GNU CC 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, or (at your option) ++any later version. ++ ++GNU CC 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 GNU CC; see the file COPYING.  If not, write to ++the Free Software Foundation, 59 Temple Place - Suite 330, ++Boston, MA 02111-1307, USA.  */ ++ ++#define BITS_PER_UNIT 8 ++ ++typedef		 int SItype	__attribute__ ((mode (SI))); ++typedef unsigned int USItype	__attribute__ ((mode (SI))); ++typedef		 int DItype	__attribute__ ((mode (DI))); ++typedef int word_type __attribute__ ((mode (__word__))); ++ ++struct DIstruct {SItype high, low;}; ++ ++typedef union ++{ ++  struct DIstruct s; ++  DItype ll; ++} DIunion; ++ ++DItype ++__lshrdi3 (DItype u, word_type b) ++{ ++  DIunion w; ++  word_type bm; ++  DIunion uu; ++ ++  if (b == 0) ++    return u; ++ ++  uu.ll = u; ++ ++  bm = (sizeof (SItype) * BITS_PER_UNIT) - b; ++  if (bm <= 0) ++    { ++      w.s.high = 0; ++      w.s.low = (USItype)uu.s.high >> -bm; ++    } ++  else ++    { ++      USItype carries = (USItype)uu.s.high << bm; ++      w.s.high = (USItype)uu.s.high >> b; ++      w.s.low = ((USItype)uu.s.low >> b) | carries; ++    } ++ ++  return w.ll; ++} +--- /dev/null ++++ b/arch/ubicom32/lib/muldi3.c +@@ -0,0 +1,87 @@ ++/* muldi3.c extracted from gcc-2.7.2.3/libgcc2.c and ++			   gcc-2.7.2.3/longlong.h which is: */ ++/* Copyright (C) 1989, 1992, 1993, 1994, 1995 Free Software Foundation, Inc. ++ ++This file is part of GNU CC. ++ ++GNU CC 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, or (at your option) ++any later version. ++ ++GNU CC 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 GNU CC; see the file COPYING.  If not, write to ++the Free Software Foundation, 59 Temple Place - Suite 330, ++Boston, MA 02111-1307, USA.  */ ++ ++#define UWtype          USItype ++#define UHWtype         USItype ++#define W_TYPE_SIZE     32 ++#define __BITS4 (W_TYPE_SIZE / 4) ++#define __ll_B ((UWtype) 1 << (W_TYPE_SIZE / 2)) ++#define __ll_lowpart(t) ((UWtype) (t) & (__ll_B - 1)) ++#define __ll_highpart(t) ((UWtype) (t) >> (W_TYPE_SIZE / 2)) ++ ++#define umul_ppmm(w1, w0, u, v)                                         \ ++  do {                                                                  \ ++    UWtype __x0, __x1, __x2, __x3;                                      \ ++    UHWtype __ul, __vl, __uh, __vh;                                     \ ++                                                                        \ ++    __ul = __ll_lowpart (u);                                            \ ++    __uh = __ll_highpart (u);                                           \ ++    __vl = __ll_lowpart (v);                                            \ ++    __vh = __ll_highpart (v);                                           \ ++                                                                        \ ++    __x0 = (UWtype) __ul * __vl;                                        \ ++    __x1 = (UWtype) __ul * __vh;                                        \ ++    __x2 = (UWtype) __uh * __vl;                                        \ ++    __x3 = (UWtype) __uh * __vh;                                        \ ++                                                                        \ ++    __x1 += __ll_highpart (__x0);/* this can't give carry */            \ ++    __x1 += __x2;               /* but this indeed can */               \ ++    if (__x1 < __x2)            /* did we get it? */                    \ ++      __x3 += __ll_B;           /* yes, add it in the proper pos.  */   \ ++                                                                        \ ++    (w1) = __x3 + __ll_highpart (__x1);                                 \ ++    (w0) = __ll_lowpart (__x1) * __ll_B + __ll_lowpart (__x0);          \ ++  } while (0) ++ ++ ++#define __umulsidi3(u, v) \ ++  ({DIunion __w;							\ ++    umul_ppmm (__w.s.high, __w.s.low, u, v);				\ ++    __w.ll; }) ++ ++typedef		 int SItype	__attribute__ ((mode (SI))); ++typedef unsigned int USItype	__attribute__ ((mode (SI))); ++typedef		 int DItype	__attribute__ ((mode (DI))); ++typedef int word_type __attribute__ ((mode (__word__))); ++ ++struct DIstruct {SItype high, low;}; ++ ++typedef union ++{ ++  struct DIstruct s; ++  DItype ll; ++} DIunion; ++ ++DItype ++__muldi3 (DItype u, DItype v) ++{ ++  DIunion w; ++  DIunion uu, vv; ++ ++  uu.ll = u, ++  vv.ll = v; ++ ++  w.ll = __umulsidi3 (uu.s.low, vv.s.low); ++  w.s.high += ((USItype) uu.s.low * (USItype) vv.s.high ++	       + (USItype) uu.s.high * (USItype) vv.s.low); ++ ++  return w.ll; ++} +--- a/arch/ubicom32/kernel/ubicom32_ksyms.c ++++ b/arch/ubicom32/kernel/ubicom32_ksyms.c +@@ -72,7 +72,6 @@ EXPORT_SYMBOL(memmove); + extern void __ashldi3(void); + extern void __ashrdi3(void); + extern void __divsi3(void); +-extern void __divdi3(void); + extern void __lshrdi3(void); + extern void __modsi3(void); + extern void __muldi3(void); +@@ -83,7 +82,6 @@ extern void __umodsi3(void); + EXPORT_SYMBOL(__ashldi3); + EXPORT_SYMBOL(__ashrdi3); + EXPORT_SYMBOL(__divsi3); +-EXPORT_SYMBOL(__divdi3); + EXPORT_SYMBOL(__lshrdi3); + EXPORT_SYMBOL(__modsi3); + EXPORT_SYMBOL(__muldi3); diff --git a/target/linux/ubicom32/patches-2.6.32/130-flash_driver_fix.patch b/target/linux/ubicom32/patches-2.6.32/130-flash_driver_fix.patch new file mode 100644 index 000000000..95fa50807 --- /dev/null +++ b/target/linux/ubicom32/patches-2.6.32/130-flash_driver_fix.patch @@ -0,0 +1,13 @@ +--- a/drivers/mtd/devices/ubi32-m25p80.c ++++ b/drivers/mtd/devices/ubi32-m25p80.c +@@ -630,8 +630,8 @@ static int ubicom32_flash_driver_erase(s + 	/* sanity checks */ + 	if (instr->addr + instr->len > flash->mtd.size) + 		return -EINVAL; +-	if ((instr->addr % mtd->erasesize) != 0 +-			|| (instr->len % mtd->erasesize) != 0) { ++	if (((u32) instr->addr % mtd->erasesize) != 0 ++			|| ((u32) instr->len % mtd->erasesize) != 0) { + 		return -EINVAL; + 	} +  diff --git a/target/linux/ubicom32/patches-2.6.32/140-arch_cflags.patch b/target/linux/ubicom32/patches-2.6.32/140-arch_cflags.patch new file mode 100644 index 000000000..aa1396e41 --- /dev/null +++ b/target/linux/ubicom32/patches-2.6.32/140-arch_cflags.patch @@ -0,0 +1,13 @@ +--- a/arch/ubicom32/Makefile ++++ b/arch/ubicom32/Makefile +@@ -54,8 +54,8 @@ CFLAGS_MODULE    += -mno-fastcall + # + # Some CFLAG additions based on specific CPU type. + # +-cflags-$(CONFIG_UBICOM32_V3)		:= -march=ubicom32v3 -DIP5000 +-cflags-$(CONFIG_UBICOM32_V4)		:= -march=ubicom32v4 -DIP7000 ++cflags-$(CONFIG_UBICOM32_V3)		:= -march=ubicom32v3 -mno-fdpic -DIP5000 ++cflags-$(CONFIG_UBICOM32_V4)		:= -march=ubicom32v4 -mno-fdpic -DIP7000 +  + ldflags-$(CONFIG_LINKER_RELAXATION)	:= --relax + LDFLAGS_vmlinux := $(ldflags-y) | 
