diff options
| -rw-r--r-- | arch/s390/include/asm/pgtable.h | 4 | ||||
| -rw-r--r-- | arch/s390/lib/uaccess_pt.c | 83 | ||||
| -rw-r--r-- | drivers/dma/Kconfig | 1 | ||||
| -rw-r--r-- | drivers/media/platform/Kconfig | 2 | ||||
| -rw-r--r-- | drivers/s390/block/scm_blk.c | 11 | ||||
| -rw-r--r-- | drivers/s390/block/scm_drv.c | 2 | ||||
| -rw-r--r-- | drivers/s390/char/tty3270.c | 16 | ||||
| -rw-r--r-- | drivers/spi/Kconfig | 3 |
8 files changed, 79 insertions, 43 deletions
diff --git a/arch/s390/include/asm/pgtable.h b/arch/s390/include/asm/pgtable.h index 4a2930844d43..4a5443118cfb 100644 --- a/arch/s390/include/asm/pgtable.h +++ b/arch/s390/include/asm/pgtable.h | |||
| @@ -344,6 +344,7 @@ extern unsigned long MODULES_END; | |||
| 344 | #define _REGION3_ENTRY_CO 0x100 /* change-recording override */ | 344 | #define _REGION3_ENTRY_CO 0x100 /* change-recording override */ |
| 345 | 345 | ||
| 346 | /* Bits in the segment table entry */ | 346 | /* Bits in the segment table entry */ |
| 347 | #define _SEGMENT_ENTRY_ORIGIN_LARGE ~0xfffffUL /* large page address */ | ||
| 347 | #define _SEGMENT_ENTRY_ORIGIN ~0x7ffUL/* segment table origin */ | 348 | #define _SEGMENT_ENTRY_ORIGIN ~0x7ffUL/* segment table origin */ |
| 348 | #define _SEGMENT_ENTRY_RO 0x200 /* page protection bit */ | 349 | #define _SEGMENT_ENTRY_RO 0x200 /* page protection bit */ |
| 349 | #define _SEGMENT_ENTRY_INV 0x20 /* invalid segment table entry */ | 350 | #define _SEGMENT_ENTRY_INV 0x20 /* invalid segment table entry */ |
| @@ -1531,7 +1532,8 @@ extern int s390_enable_sie(void); | |||
| 1531 | /* | 1532 | /* |
| 1532 | * No page table caches to initialise | 1533 | * No page table caches to initialise |
| 1533 | */ | 1534 | */ |
| 1534 | #define pgtable_cache_init() do { } while (0) | 1535 | static inline void pgtable_cache_init(void) { } |
| 1536 | static inline void check_pgt_cache(void) { } | ||
| 1535 | 1537 | ||
| 1536 | #include <asm-generic/pgtable.h> | 1538 | #include <asm-generic/pgtable.h> |
| 1537 | 1539 | ||
diff --git a/arch/s390/lib/uaccess_pt.c b/arch/s390/lib/uaccess_pt.c index dff631d34b45..466fb3383960 100644 --- a/arch/s390/lib/uaccess_pt.c +++ b/arch/s390/lib/uaccess_pt.c | |||
| @@ -77,42 +77,69 @@ static size_t copy_in_kernel(size_t count, void __user *to, | |||
| 77 | * >= -4095 (IS_ERR_VALUE(x) returns true), a fault has occured and the address | 77 | * >= -4095 (IS_ERR_VALUE(x) returns true), a fault has occured and the address |
| 78 | * contains the (negative) exception code. | 78 | * contains the (negative) exception code. |
| 79 | */ | 79 | */ |
| 80 | static __always_inline unsigned long follow_table(struct mm_struct *mm, | 80 | #ifdef CONFIG_64BIT |
| 81 | unsigned long addr, int write) | 81 | static unsigned long follow_table(struct mm_struct *mm, |
| 82 | unsigned long address, int write) | ||
| 82 | { | 83 | { |
| 83 | pgd_t *pgd; | 84 | unsigned long *table = (unsigned long *)__pa(mm->pgd); |
| 84 | pud_t *pud; | 85 | |
| 85 | pmd_t *pmd; | 86 | switch (mm->context.asce_bits & _ASCE_TYPE_MASK) { |
| 86 | pte_t *ptep; | 87 | case _ASCE_TYPE_REGION1: |
| 88 | table = table + ((address >> 53) & 0x7ff); | ||
| 89 | if (unlikely(*table & _REGION_ENTRY_INV)) | ||
| 90 | return -0x39UL; | ||
| 91 | table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); | ||
| 92 | case _ASCE_TYPE_REGION2: | ||
| 93 | table = table + ((address >> 42) & 0x7ff); | ||
| 94 | if (unlikely(*table & _REGION_ENTRY_INV)) | ||
| 95 | return -0x3aUL; | ||
| 96 | table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); | ||
| 97 | case _ASCE_TYPE_REGION3: | ||
| 98 | table = table + ((address >> 31) & 0x7ff); | ||
| 99 | if (unlikely(*table & _REGION_ENTRY_INV)) | ||
| 100 | return -0x3bUL; | ||
| 101 | table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); | ||
| 102 | case _ASCE_TYPE_SEGMENT: | ||
| 103 | table = table + ((address >> 20) & 0x7ff); | ||
| 104 | if (unlikely(*table & _SEGMENT_ENTRY_INV)) | ||
| 105 | return -0x10UL; | ||
| 106 | if (unlikely(*table & _SEGMENT_ENTRY_LARGE)) { | ||
| 107 | if (write && (*table & _SEGMENT_ENTRY_RO)) | ||
| 108 | return -0x04UL; | ||
| 109 | return (*table & _SEGMENT_ENTRY_ORIGIN_LARGE) + | ||
| 110 | (address & ~_SEGMENT_ENTRY_ORIGIN_LARGE); | ||
| 111 | } | ||
| 112 | table = (unsigned long *)(*table & _SEGMENT_ENTRY_ORIGIN); | ||
| 113 | } | ||
| 114 | table = table + ((address >> 12) & 0xff); | ||
| 115 | if (unlikely(*table & _PAGE_INVALID)) | ||
| 116 | return -0x11UL; | ||
| 117 | if (write && (*table & _PAGE_RO)) | ||
| 118 | return -0x04UL; | ||
| 119 | return (*table & PAGE_MASK) + (address & ~PAGE_MASK); | ||
| 120 | } | ||
| 87 | 121 | ||
| 88 | pgd = pgd_offset(mm, addr); | 122 | #else /* CONFIG_64BIT */ |
| 89 | if (pgd_none(*pgd) || unlikely(pgd_bad(*pgd))) | ||
| 90 | return -0x3aUL; | ||
| 91 | 123 | ||
| 92 | pud = pud_offset(pgd, addr); | 124 | static unsigned long follow_table(struct mm_struct *mm, |
| 93 | if (pud_none(*pud) || unlikely(pud_bad(*pud))) | 125 | unsigned long address, int write) |
| 94 | return -0x3bUL; | 126 | { |
| 127 | unsigned long *table = (unsigned long *)__pa(mm->pgd); | ||
| 95 | 128 | ||
| 96 | pmd = pmd_offset(pud, addr); | 129 | table = table + ((address >> 20) & 0x7ff); |
| 97 | if (pmd_none(*pmd)) | 130 | if (unlikely(*table & _SEGMENT_ENTRY_INV)) |
| 98 | return -0x10UL; | 131 | return -0x10UL; |
| 99 | if (pmd_large(*pmd)) { | 132 | table = (unsigned long *)(*table & _SEGMENT_ENTRY_ORIGIN); |
| 100 | if (write && (pmd_val(*pmd) & _SEGMENT_ENTRY_RO)) | 133 | table = table + ((address >> 12) & 0xff); |
| 101 | return -0x04UL; | 134 | if (unlikely(*table & _PAGE_INVALID)) |
| 102 | return (pmd_val(*pmd) & HPAGE_MASK) + (addr & ~HPAGE_MASK); | ||
| 103 | } | ||
| 104 | if (unlikely(pmd_bad(*pmd))) | ||
| 105 | return -0x10UL; | ||
| 106 | |||
| 107 | ptep = pte_offset_map(pmd, addr); | ||
| 108 | if (!pte_present(*ptep)) | ||
| 109 | return -0x11UL; | 135 | return -0x11UL; |
| 110 | if (write && (!pte_write(*ptep) || !pte_dirty(*ptep))) | 136 | if (write && (*table & _PAGE_RO)) |
| 111 | return -0x04UL; | 137 | return -0x04UL; |
| 112 | 138 | return (*table & PAGE_MASK) + (address & ~PAGE_MASK); | |
| 113 | return (pte_val(*ptep) & PAGE_MASK) + (addr & ~PAGE_MASK); | ||
| 114 | } | 139 | } |
| 115 | 140 | ||
| 141 | #endif /* CONFIG_64BIT */ | ||
| 142 | |||
| 116 | static __always_inline size_t __user_copy_pt(unsigned long uaddr, void *kptr, | 143 | static __always_inline size_t __user_copy_pt(unsigned long uaddr, void *kptr, |
| 117 | size_t n, int write_user) | 144 | size_t n, int write_user) |
| 118 | { | 145 | { |
| @@ -197,7 +224,7 @@ size_t copy_to_user_pt(size_t n, void __user *to, const void *from) | |||
| 197 | 224 | ||
| 198 | static size_t clear_user_pt(size_t n, void __user *to) | 225 | static size_t clear_user_pt(size_t n, void __user *to) |
| 199 | { | 226 | { |
| 200 | void *zpage = &empty_zero_page; | 227 | void *zpage = (void *) empty_zero_page; |
| 201 | long done, size, ret; | 228 | long done, size, ret; |
| 202 | 229 | ||
| 203 | done = 0; | 230 | done = 0; |
diff --git a/drivers/dma/Kconfig b/drivers/dma/Kconfig index 80b69971cf28..aeaea32bcfda 100644 --- a/drivers/dma/Kconfig +++ b/drivers/dma/Kconfig | |||
| @@ -83,6 +83,7 @@ config INTEL_IOP_ADMA | |||
| 83 | 83 | ||
| 84 | config DW_DMAC | 84 | config DW_DMAC |
| 85 | tristate "Synopsys DesignWare AHB DMA support" | 85 | tristate "Synopsys DesignWare AHB DMA support" |
| 86 | depends on GENERIC_HARDIRQS | ||
| 86 | select DMA_ENGINE | 87 | select DMA_ENGINE |
| 87 | default y if CPU_AT32AP7000 | 88 | default y if CPU_AT32AP7000 |
| 88 | help | 89 | help |
diff --git a/drivers/media/platform/Kconfig b/drivers/media/platform/Kconfig index 05d7b6333461..a0639e779973 100644 --- a/drivers/media/platform/Kconfig +++ b/drivers/media/platform/Kconfig | |||
| @@ -204,7 +204,7 @@ config VIDEO_SAMSUNG_EXYNOS_GSC | |||
| 204 | 204 | ||
| 205 | config VIDEO_SH_VEU | 205 | config VIDEO_SH_VEU |
| 206 | tristate "SuperH VEU mem2mem video processing driver" | 206 | tristate "SuperH VEU mem2mem video processing driver" |
| 207 | depends on VIDEO_DEV && VIDEO_V4L2 | 207 | depends on VIDEO_DEV && VIDEO_V4L2 && GENERIC_HARDIRQS |
| 208 | select VIDEOBUF2_DMA_CONTIG | 208 | select VIDEOBUF2_DMA_CONTIG |
| 209 | select V4L2_MEM2MEM_DEV | 209 | select V4L2_MEM2MEM_DEV |
| 210 | help | 210 | help |
diff --git a/drivers/s390/block/scm_blk.c b/drivers/s390/block/scm_blk.c index 5ac9c935c151..e9b9c8392832 100644 --- a/drivers/s390/block/scm_blk.c +++ b/drivers/s390/block/scm_blk.c | |||
| @@ -307,7 +307,7 @@ static void scm_blk_handle_error(struct scm_request *scmrq) | |||
| 307 | case EQC_WR_PROHIBIT: | 307 | case EQC_WR_PROHIBIT: |
| 308 | spin_lock_irqsave(&bdev->lock, flags); | 308 | spin_lock_irqsave(&bdev->lock, flags); |
| 309 | if (bdev->state != SCM_WR_PROHIBIT) | 309 | if (bdev->state != SCM_WR_PROHIBIT) |
| 310 | pr_info("%lu: Write access to the SCM increment is suspended\n", | 310 | pr_info("%lx: Write access to the SCM increment is suspended\n", |
| 311 | (unsigned long) bdev->scmdev->address); | 311 | (unsigned long) bdev->scmdev->address); |
| 312 | bdev->state = SCM_WR_PROHIBIT; | 312 | bdev->state = SCM_WR_PROHIBIT; |
| 313 | spin_unlock_irqrestore(&bdev->lock, flags); | 313 | spin_unlock_irqrestore(&bdev->lock, flags); |
| @@ -445,7 +445,7 @@ void scm_blk_set_available(struct scm_blk_dev *bdev) | |||
| 445 | 445 | ||
| 446 | spin_lock_irqsave(&bdev->lock, flags); | 446 | spin_lock_irqsave(&bdev->lock, flags); |
| 447 | if (bdev->state == SCM_WR_PROHIBIT) | 447 | if (bdev->state == SCM_WR_PROHIBIT) |
| 448 | pr_info("%lu: Write access to the SCM increment is restored\n", | 448 | pr_info("%lx: Write access to the SCM increment is restored\n", |
| 449 | (unsigned long) bdev->scmdev->address); | 449 | (unsigned long) bdev->scmdev->address); |
| 450 | bdev->state = SCM_OPER; | 450 | bdev->state = SCM_OPER; |
| 451 | spin_unlock_irqrestore(&bdev->lock, flags); | 451 | spin_unlock_irqrestore(&bdev->lock, flags); |
| @@ -463,12 +463,15 @@ static int __init scm_blk_init(void) | |||
| 463 | goto out; | 463 | goto out; |
| 464 | 464 | ||
| 465 | scm_major = ret; | 465 | scm_major = ret; |
| 466 | if (scm_alloc_rqs(nr_requests)) | 466 | ret = scm_alloc_rqs(nr_requests); |
| 467 | if (ret) | ||
| 467 | goto out_unreg; | 468 | goto out_unreg; |
| 468 | 469 | ||
| 469 | scm_debug = debug_register("scm_log", 16, 1, 16); | 470 | scm_debug = debug_register("scm_log", 16, 1, 16); |
| 470 | if (!scm_debug) | 471 | if (!scm_debug) { |
| 472 | ret = -ENOMEM; | ||
| 471 | goto out_free; | 473 | goto out_free; |
| 474 | } | ||
| 472 | 475 | ||
| 473 | debug_register_view(scm_debug, &debug_hex_ascii_view); | 476 | debug_register_view(scm_debug, &debug_hex_ascii_view); |
| 474 | debug_set_level(scm_debug, 2); | 477 | debug_set_level(scm_debug, 2); |
diff --git a/drivers/s390/block/scm_drv.c b/drivers/s390/block/scm_drv.c index 5f6180d6ff08..c98cf52d78d1 100644 --- a/drivers/s390/block/scm_drv.c +++ b/drivers/s390/block/scm_drv.c | |||
| @@ -19,7 +19,7 @@ static void scm_notify(struct scm_device *scmdev, enum scm_event event) | |||
| 19 | 19 | ||
| 20 | switch (event) { | 20 | switch (event) { |
| 21 | case SCM_CHANGE: | 21 | case SCM_CHANGE: |
| 22 | pr_info("%lu: The capabilities of the SCM increment changed\n", | 22 | pr_info("%lx: The capabilities of the SCM increment changed\n", |
| 23 | (unsigned long) scmdev->address); | 23 | (unsigned long) scmdev->address); |
| 24 | SCM_LOG(2, "State changed"); | 24 | SCM_LOG(2, "State changed"); |
| 25 | SCM_LOG_STATE(2, scmdev); | 25 | SCM_LOG_STATE(2, scmdev); |
diff --git a/drivers/s390/char/tty3270.c b/drivers/s390/char/tty3270.c index b907dba24025..cee69dac3e18 100644 --- a/drivers/s390/char/tty3270.c +++ b/drivers/s390/char/tty3270.c | |||
| @@ -915,7 +915,7 @@ static int tty3270_install(struct tty_driver *driver, struct tty_struct *tty) | |||
| 915 | int i, rc; | 915 | int i, rc; |
| 916 | 916 | ||
| 917 | /* Check if the tty3270 is already there. */ | 917 | /* Check if the tty3270 is already there. */ |
| 918 | view = raw3270_find_view(&tty3270_fn, tty->index); | 918 | view = raw3270_find_view(&tty3270_fn, tty->index + RAW3270_FIRSTMINOR); |
| 919 | if (!IS_ERR(view)) { | 919 | if (!IS_ERR(view)) { |
| 920 | tp = container_of(view, struct tty3270, view); | 920 | tp = container_of(view, struct tty3270, view); |
| 921 | tty->driver_data = tp; | 921 | tty->driver_data = tp; |
| @@ -927,15 +927,16 @@ static int tty3270_install(struct tty_driver *driver, struct tty_struct *tty) | |||
| 927 | tp->inattr = TF_INPUT; | 927 | tp->inattr = TF_INPUT; |
| 928 | return tty_port_install(&tp->port, driver, tty); | 928 | return tty_port_install(&tp->port, driver, tty); |
| 929 | } | 929 | } |
| 930 | if (tty3270_max_index < tty->index) | 930 | if (tty3270_max_index < tty->index + 1) |
| 931 | tty3270_max_index = tty->index; | 931 | tty3270_max_index = tty->index + 1; |
| 932 | 932 | ||
| 933 | /* Allocate tty3270 structure on first open. */ | 933 | /* Allocate tty3270 structure on first open. */ |
| 934 | tp = tty3270_alloc_view(); | 934 | tp = tty3270_alloc_view(); |
| 935 | if (IS_ERR(tp)) | 935 | if (IS_ERR(tp)) |
| 936 | return PTR_ERR(tp); | 936 | return PTR_ERR(tp); |
| 937 | 937 | ||
| 938 | rc = raw3270_add_view(&tp->view, &tty3270_fn, tty->index); | 938 | rc = raw3270_add_view(&tp->view, &tty3270_fn, |
| 939 | tty->index + RAW3270_FIRSTMINOR); | ||
| 939 | if (rc) { | 940 | if (rc) { |
| 940 | tty3270_free_view(tp); | 941 | tty3270_free_view(tp); |
| 941 | return rc; | 942 | return rc; |
| @@ -1846,12 +1847,12 @@ static const struct tty_operations tty3270_ops = { | |||
| 1846 | 1847 | ||
| 1847 | void tty3270_create_cb(int minor) | 1848 | void tty3270_create_cb(int minor) |
| 1848 | { | 1849 | { |
| 1849 | tty_register_device(tty3270_driver, minor, NULL); | 1850 | tty_register_device(tty3270_driver, minor - RAW3270_FIRSTMINOR, NULL); |
| 1850 | } | 1851 | } |
| 1851 | 1852 | ||
| 1852 | void tty3270_destroy_cb(int minor) | 1853 | void tty3270_destroy_cb(int minor) |
| 1853 | { | 1854 | { |
| 1854 | tty_unregister_device(tty3270_driver, minor); | 1855 | tty_unregister_device(tty3270_driver, minor - RAW3270_FIRSTMINOR); |
| 1855 | } | 1856 | } |
| 1856 | 1857 | ||
| 1857 | struct raw3270_notifier tty3270_notifier = | 1858 | struct raw3270_notifier tty3270_notifier = |
| @@ -1884,7 +1885,8 @@ static int __init tty3270_init(void) | |||
| 1884 | driver->driver_name = "tty3270"; | 1885 | driver->driver_name = "tty3270"; |
| 1885 | driver->name = "3270/tty"; | 1886 | driver->name = "3270/tty"; |
| 1886 | driver->major = IBM_TTY3270_MAJOR; | 1887 | driver->major = IBM_TTY3270_MAJOR; |
| 1887 | driver->minor_start = 0; | 1888 | driver->minor_start = RAW3270_FIRSTMINOR; |
| 1889 | driver->name_base = RAW3270_FIRSTMINOR; | ||
| 1888 | driver->type = TTY_DRIVER_TYPE_SYSTEM; | 1890 | driver->type = TTY_DRIVER_TYPE_SYSTEM; |
| 1889 | driver->subtype = SYSTEM_TYPE_TTY; | 1891 | driver->subtype = SYSTEM_TYPE_TTY; |
| 1890 | driver->init_termios = tty_std_termios; | 1892 | driver->init_termios = tty_std_termios; |
diff --git a/drivers/spi/Kconfig b/drivers/spi/Kconfig index f80eee74a311..2be0de920d67 100644 --- a/drivers/spi/Kconfig +++ b/drivers/spi/Kconfig | |||
| @@ -55,6 +55,7 @@ comment "SPI Master Controller Drivers" | |||
| 55 | 55 | ||
| 56 | config SPI_ALTERA | 56 | config SPI_ALTERA |
| 57 | tristate "Altera SPI Controller" | 57 | tristate "Altera SPI Controller" |
| 58 | depends on GENERIC_HARDIRQS | ||
| 58 | select SPI_BITBANG | 59 | select SPI_BITBANG |
| 59 | help | 60 | help |
| 60 | This is the driver for the Altera SPI Controller. | 61 | This is the driver for the Altera SPI Controller. |
| @@ -310,7 +311,7 @@ config SPI_PXA2XX_DMA | |||
| 310 | 311 | ||
| 311 | config SPI_PXA2XX | 312 | config SPI_PXA2XX |
| 312 | tristate "PXA2xx SSP SPI master" | 313 | tristate "PXA2xx SSP SPI master" |
| 313 | depends on ARCH_PXA || PCI || ACPI | 314 | depends on (ARCH_PXA || PCI || ACPI) && GENERIC_HARDIRQS |
| 314 | select PXA_SSP if ARCH_PXA | 315 | select PXA_SSP if ARCH_PXA |
| 315 | help | 316 | help |
| 316 | This enables using a PXA2xx or Sodaville SSP port as a SPI master | 317 | This enables using a PXA2xx or Sodaville SSP port as a SPI master |
