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