mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-25 19:14:26 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			1742 lines
		
	
	
		
			51 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			1742 lines
		
	
	
		
			51 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| --- a/drivers/char/hw_random/Kconfig
 | |
| +++ b/drivers/char/hw_random/Kconfig
 | |
| @@ -148,3 +148,16 @@ config HW_RANDOM_VIRTIO
 | |
|  
 | |
|  	  To compile this driver as a module, choose M here: the
 | |
|  	  module will be called virtio-rng.  If unsure, say N.
 | |
| +
 | |
| +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
 | |
| @@ -15,3 +15,4 @@ obj-$(CONFIG_HW_RANDOM_IXP4XX) += ixp4xx
 | |
|  obj-$(CONFIG_HW_RANDOM_OMAP) += omap-rng.o
 | |
|  obj-$(CONFIG_HW_RANDOM_PASEMI) += pasemi-rng.o
 | |
|  obj-$(CONFIG_HW_RANDOM_VIRTIO) += virtio-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
 | |
| @@ -266,3 +266,10 @@ config GPIOMMC_CONFIGFS
 | |
|  	help
 | |
|  	  This option automatically enables configfs support for gpiommc
 | |
|  	  if configfs is available.
 | |
| +
 | |
| +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
 | |
| @@ -30,4 +30,5 @@ obj-$(CONFIG_MMC_S3C)   	+= s3cmci.o
 | |
|  obj-$(CONFIG_MMC_SDRICOH_CS)	+= sdricoh_cs.o
 | |
|  obj-$(CONFIG_MMC_TMIO)		+= tmio_mmc.o
 | |
|  obj-$(CONFIG_GPIOMMC)		+= gpiommc.o
 | |
| +obj-$(CONFIG_MMC_UBICOM32)	+= ubicom32sd.o
 | |
|  
 | |
| --- a/drivers/mtd/devices/Kconfig
 | |
| +++ b/drivers/mtd/devices/Kconfig
 | |
| @@ -104,6 +104,31 @@ config M25PXX_USE_FAST_READ
 | |
|  	help
 | |
|  	  This option enables FAST_READ access supported by ST M25Pxx.
 | |
|  
 | |
| +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
 | |
| @@ -16,3 +16,6 @@ obj-$(CONFIG_MTD_LART)		+= lart.o
 | |
|  obj-$(CONFIG_MTD_BLOCK2MTD)	+= block2mtd.o
 | |
|  obj-$(CONFIG_MTD_DATAFLASH)	+= mtd_dataflash.o
 | |
|  obj-$(CONFIG_MTD_M25P80)	+= m25p80.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
 | |
| @@ -2540,6 +2540,19 @@ config JME
 | |
|  	  To compile this driver as a module, choose M here. The module
 | |
|  	  will be called jme.
 | |
|  
 | |
| +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
 | |
| @@ -272,3 +272,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
 | |
| @@ -328,10 +328,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;
 | |
|  
 | |
|  	/*
 | |
| @@ -353,7 +353,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)
 | |
| @@ -361,7 +362,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
 | |
| @@ -44,8 +44,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
 | |
| @@ -871,6 +871,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
 | |
| @@ -77,3 +77,6 @@ obj-$(CONFIG_SERIAL_OF_PLATFORM_NWPSERIA
 | |
|  obj-$(CONFIG_SERIAL_KS8695) += serial_ks8695.o
 | |
|  obj-$(CONFIG_KGDB_SERIAL_CONSOLE) += kgdboc.o
 | |
|  obj-$(CONFIG_SERIAL_QE) += ucc_uart.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
 | |
| @@ -196,6 +196,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
 | |
| @@ -27,6 +27,7 @@ obj-$(CONFIG_SPI_ORION)			+= orion_spi.o
 | |
|  obj-$(CONFIG_SPI_MPC52xx_PSC)		+= mpc52xx_psc_spi.o
 | |
|  obj-$(CONFIG_SPI_MPC83xx)		+= spi_mpc83xx.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
 | |
| @@ -89,4 +89,12 @@ config UIO_SERCOS3
 | |
|  
 | |
|  	  If you compile this as a module, it will be called uio_sercos3.
 | |
|  
 | |
| +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
 | |
| @@ -5,3 +5,4 @@ obj-$(CONFIG_UIO_PDRV_GENIRQ)	+= uio_pdr
 | |
|  obj-$(CONFIG_UIO_SMX)	+= uio_smx.o
 | |
|  obj-$(CONFIG_UIO_AEC)	+= uio_aec.o
 | |
|  obj-$(CONFIG_UIO_SERCOS3)	+= uio_sercos3.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
 | |
| @@ -12,7 +12,7 @@ config USB_MUSB_HDRC
 | |
|  	depends on !SUPERH
 | |
|  	select TWL4030_USB if MACH_OMAP_3430SDP
 | |
|  	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"
 | |
|  
 | |
|  
 | |
| @@ -147,8 +154,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
 | |
| @@ -227,8 +263,7 @@ void musb_read_fifo(struct musb_hw_ep *h
 | |
|  		readsb(fifo, dst, len);
 | |
|  	}
 | |
|  }
 | |
| -
 | |
| -#endif	/* normal PIO */
 | |
| +#endif /* !T6010 && !BLACKFIN */
 | |
|  
 | |
|  
 | |
|  /*-------------------------------------------------------------------------*/
 | |
| @@ -874,12 +909,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);
 | |
| @@ -1081,6 +1123,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.
 | |
| @@ -1240,7 +1283,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
 | |
| @@ -1256,6 +1299,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);
 | |
| @@ -1276,14 +1324,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;
 | |
|  	}
 | |
| @@ -1393,12 +1454,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);
 | |
| @@ -1462,8 +1527,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;
 | |
| @@ -1472,10 +1537,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);
 | |
|  
 | |
| @@ -2210,6 +2282,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
 | |
| @@ -326,7 +326,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
 | |
| @@ -432,7 +432,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);
 | |
|  			if (dma_channel_status(dma) == MUSB_DMA_STATUS_BUSY) {
 | |
| @@ -448,7 +448,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);
 | |
| @@ -584,10 +584,16 @@ static void rxstate(struct musb *musb, s
 | |
|  	u16			csr = 0;
 | |
|  	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;
 | |
| +
 | |
| +	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;
 | |
|  
 | |
|  	csr = musb_readw(epio, MUSB_RXCSR);
 | |
|  
 | |
| @@ -726,7 +732,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);
 | |
|  		}
 | |
| @@ -745,10 +751,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);
 | |
| @@ -1769,7 +1780,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
 | |
| @@ -240,14 +240,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;
 | |
| @@ -261,8 +261,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)
 | |
| @@ -292,7 +292,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;
 | |
| @@ -374,8 +374,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;
 | |
| @@ -223,6 +227,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;
 | |
|  	}
 | |
| @@ -342,13 +348,13 @@ musb_save_toggle(struct musb_hw_ep *ep, 
 | |
|  	if (!is_in) {
 | |
|  		csr = musb_readw(epio, MUSB_TXCSR);
 | |
|  		usb_settoggle(udev, qh->epnum, 1,
 | |
| -			(csr & MUSB_TXCSR_H_DATATOGGLE)
 | |
| -				? 1 : 0);
 | |
| +			((csr & MUSB_TXCSR_H_DATATOGGLE)
 | |
| +				? 1 : 0));
 | |
|  	} else {
 | |
|  		csr = musb_readw(epio, MUSB_RXCSR);
 | |
|  		usb_settoggle(udev, qh->epnum, 0,
 | |
| -			(csr & MUSB_RXCSR_H_DATATOGGLE)
 | |
| -				? 1 : 0);
 | |
| +			((csr & MUSB_RXCSR_H_DATATOGGLE)
 | |
| +				? 1 : 0));
 | |
|  	}
 | |
|  }
 | |
|  
 | |
| @@ -556,7 +562,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 {
 | |
| @@ -590,6 +600,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);
 | |
| @@ -604,7 +615,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 {
 | |
| @@ -1138,8 +1160,18 @@ 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
 | |
|  	urb = next_urb(qh);
 | |
|  
 | |
| +
 | |
|  	musb_ep_select(mbase, epnum);
 | |
|  	tx_csr = musb_readw(epio, MUSB_TXCSR);
 | |
|  
 | |
| @@ -1180,9 +1212,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;
 | |
|  	}
 | |
|  
 | |
| @@ -1353,8 +1390,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
 | |
| +
 | |
|  }
 | |
|  
 | |
|  
 | |
| @@ -1414,7 +1457,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);
 | |
|  
 | |
| @@ -1483,6 +1530,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);
 | |
| @@ -1521,8 +1575,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;
 | |
| @@ -1579,8 +1640,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)) {
 | |
| @@ -1610,7 +1676,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
 | |
| @@ -1823,7 +1889,11 @@ static int musb_schedule(
 | |
|  		} else	if (hw_ep->out_qh != 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)
 | |
| @@ -1836,7 +1906,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)
 | |
| @@ -1858,6 +1935,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;
 | |
| @@ -1869,6 +1962,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)
 | |
| @@ -1975,6 +2075,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
 | |
| @@ -93,6 +93,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
 | |
|  #
 | |
| @@ -229,3 +286,11 @@ config BACKLIGHT_SAHARA
 | |
|  	help
 | |
|  	  If you have a Tabletkiosk Sahara Touch-iT, say y to enable the
 | |
|  	  backlight driver.
 | |
| +
 | |
| +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
 | |
| @@ -9,6 +9,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
 | |
| @@ -24,4 +27,4 @@ obj-$(CONFIG_BACKLIGHT_DA903X)	+= da903x
 | |
|  obj-$(CONFIG_BACKLIGHT_MBP_NVIDIA) += mbp_nvidia_bl.o
 | |
|  obj-$(CONFIG_BACKLIGHT_TOSA)	+= tosa_bl.o
 | |
|  obj-$(CONFIG_BACKLIGHT_SAHARA)	+= kb3886_bl.o
 | |
| -
 | |
| +obj-$(CONFIG_BACKLIGHT_UBICOM32) += ubicom32bl.o
 | |
| --- a/drivers/video/Kconfig
 | |
| +++ b/drivers/video/Kconfig
 | |
| @@ -609,6 +609,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
 | |
| @@ -136,6 +136,10 @@ obj-$(CONFIG_FB_BF54X_LQ043)	  += bf54x-
 | |
|  obj-$(CONFIG_FB_BFIN_T350MCQB)	  += bfin-t350mcqb-fb.o
 | |
|  obj-$(CONFIG_FB_MX3)		  += mx3fb.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
 | |
| @@ -887,6 +887,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
 | |
| @@ -131,6 +131,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 */
 | |
|  
 | |
| @@ -436,6 +441,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;
 | |
| @@ -521,6 +527,7 @@ static int load_flat_file(struct linux_b
 | |
|  
 | |
|  		/* OK, This is the point of no return */
 | |
|  		set_personality(PER_LINUX_32BIT);
 | |
| +		flush_happened = 1;
 | |
|  	}
 | |
|  
 | |
|  	/*
 | |
| @@ -535,6 +542,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
 | |
| @@ -553,7 +566,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,
 | |
| @@ -572,6 +585,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);
 | |
| @@ -600,7 +614,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,
 | |
| @@ -616,10 +634,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));
 | |
| @@ -659,7 +684,7 @@ static int load_flat_file(struct linux_b
 | |
|  		}
 | |
|  		if (result >= (unsigned long)-4096) {
 | |
|  			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;
 | |
| @@ -672,6 +697,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;
 | |
| @@ -800,6 +828,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
 | |
| @@ -151,6 +151,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
 | |
| @@ -99,6 +99,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
 | |
| @@ -167,6 +167,9 @@
 | |
|  /* MAX3100 */
 | |
|  #define PORT_MAX3100    86
 | |
|  
 | |
| +/* Ubicom32 */
 | |
| +#define PORT_UBI32_UARTTIO	87
 | |
| +
 | |
|  #ifdef __KERNEL__
 | |
|  
 | |
|  #include <linux/compiler.h>
 | |
| --- a/include/linux/slab.h
 | |
| +++ b/include/linux/slab.h
 | |
| @@ -317,4 +317,14 @@ static inline void *kzalloc_node(size_t 
 | |
|  	return kmalloc_node(size, flags | __GFP_ZERO, node);
 | |
|  }
 | |
|  
 | |
| +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
 | |
| @@ -865,6 +865,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
 | |
| @@ -2688,6 +2688,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));
 | |
| @@ -2840,8 +2843,12 @@ void print_modules(void)
 | |
|  	printk("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
 | |
| @@ -621,7 +621,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
 | |
| @@ -38,3 +38,5 @@ obj-$(CONFIG_SMP) += allocpercpu.o
 | |
|  endif
 | |
|  obj-$(CONFIG_QUICKLIST) += quicklist.o
 | |
|  obj-$(CONFIG_CGROUP_MEM_RES_CTLR) += memcontrol.o page_cgroup.o
 | |
| +
 | |
| +CFLAGS_slab.o := $(PROFILING) -O2
 | |
| --- a/mm/slab.c
 | |
| +++ b/mm/slab.c
 | |
| @@ -4100,6 +4100,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
 | |
| @@ -774,6 +774,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
 | |
| @@ -82,6 +82,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
 |