diff options
| author | Ingo Molnar <mingo@kernel.org> | 2013-12-17 09:27:08 -0500 |
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2013-12-17 09:27:08 -0500 |
| commit | bb799d3b980eb803ca2da4a4eefbd9308f8d988a (patch) | |
| tree | 69fbe0cd6d47b23a50f5e1d87bf7489532fae149 /arch/parisc | |
| parent | 919fc6e34831d1c2b58bfb5ae261dc3facc9b269 (diff) | |
| parent | 319e2e3f63c348a9b66db4667efa73178e18b17d (diff) | |
Merge tag 'v3.13-rc4' into core/locking
Merge Linux 3.13-rc4, to refresh this rather old tree with the latest fixes.
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'arch/parisc')
| -rw-r--r-- | arch/parisc/configs/c3000_defconfig | 2 | ||||
| -rw-r--r-- | arch/parisc/configs/c8000_defconfig | 36 | ||||
| -rw-r--r-- | arch/parisc/configs/generic-64bit_defconfig | 39 | ||||
| -rw-r--r-- | arch/parisc/include/asm/serial.h | 2 | ||||
| -rw-r--r-- | arch/parisc/include/asm/socket.h | 11 | ||||
| -rw-r--r-- | arch/parisc/include/asm/uaccess.h | 46 | ||||
| -rw-r--r-- | arch/parisc/include/uapi/asm/socket.h | 11 | ||||
| -rw-r--r-- | arch/parisc/kernel/hardware.c | 7 | ||||
| -rw-r--r-- | arch/parisc/kernel/head.S | 6 | ||||
| -rw-r--r-- | arch/parisc/kernel/sys_parisc.c | 25 | ||||
| -rw-r--r-- | arch/parisc/kernel/unwind.c | 9 | ||||
| -rw-r--r-- | arch/parisc/kernel/vmlinux.lds.S | 138 | ||||
| -rw-r--r-- | arch/parisc/lib/memcpy.c | 6 | ||||
| -rw-r--r-- | arch/parisc/mm/fault.c | 22 | ||||
| -rw-r--r-- | arch/parisc/mm/init.c | 19 |
15 files changed, 151 insertions, 228 deletions
diff --git a/arch/parisc/configs/c3000_defconfig b/arch/parisc/configs/c3000_defconfig index ec1b014952b6..acacd348df89 100644 --- a/arch/parisc/configs/c3000_defconfig +++ b/arch/parisc/configs/c3000_defconfig | |||
| @@ -50,7 +50,7 @@ CONFIG_BLK_DEV_CRYPTOLOOP=m | |||
| 50 | CONFIG_IDE=y | 50 | CONFIG_IDE=y |
| 51 | CONFIG_BLK_DEV_IDECD=y | 51 | CONFIG_BLK_DEV_IDECD=y |
| 52 | CONFIG_BLK_DEV_NS87415=y | 52 | CONFIG_BLK_DEV_NS87415=y |
| 53 | CONFIG_BLK_DEV_SIIMAGE=m | 53 | CONFIG_PATA_SIL680=m |
| 54 | CONFIG_SCSI=y | 54 | CONFIG_SCSI=y |
| 55 | CONFIG_BLK_DEV_SD=y | 55 | CONFIG_BLK_DEV_SD=y |
| 56 | CONFIG_CHR_DEV_ST=y | 56 | CONFIG_CHR_DEV_ST=y |
diff --git a/arch/parisc/configs/c8000_defconfig b/arch/parisc/configs/c8000_defconfig index e1c8d2015c89..8249ac9d9cfc 100644 --- a/arch/parisc/configs/c8000_defconfig +++ b/arch/parisc/configs/c8000_defconfig | |||
| @@ -20,7 +20,6 @@ CONFIG_MODULE_FORCE_UNLOAD=y | |||
| 20 | CONFIG_MODVERSIONS=y | 20 | CONFIG_MODVERSIONS=y |
| 21 | CONFIG_BLK_DEV_INTEGRITY=y | 21 | CONFIG_BLK_DEV_INTEGRITY=y |
| 22 | CONFIG_PA8X00=y | 22 | CONFIG_PA8X00=y |
| 23 | CONFIG_MLONGCALLS=y | ||
| 24 | CONFIG_64BIT=y | 23 | CONFIG_64BIT=y |
| 25 | CONFIG_SMP=y | 24 | CONFIG_SMP=y |
| 26 | CONFIG_PREEMPT=y | 25 | CONFIG_PREEMPT=y |
| @@ -81,8 +80,6 @@ CONFIG_IDE=y | |||
| 81 | CONFIG_BLK_DEV_IDECD=y | 80 | CONFIG_BLK_DEV_IDECD=y |
| 82 | CONFIG_BLK_DEV_PLATFORM=y | 81 | CONFIG_BLK_DEV_PLATFORM=y |
| 83 | CONFIG_BLK_DEV_GENERIC=y | 82 | CONFIG_BLK_DEV_GENERIC=y |
| 84 | CONFIG_BLK_DEV_SIIMAGE=y | ||
| 85 | CONFIG_SCSI=y | ||
| 86 | CONFIG_BLK_DEV_SD=y | 83 | CONFIG_BLK_DEV_SD=y |
| 87 | CONFIG_CHR_DEV_ST=m | 84 | CONFIG_CHR_DEV_ST=m |
| 88 | CONFIG_BLK_DEV_SR=m | 85 | CONFIG_BLK_DEV_SR=m |
| @@ -94,6 +91,8 @@ CONFIG_SCSI_FC_ATTRS=y | |||
| 94 | CONFIG_SCSI_SAS_LIBSAS=m | 91 | CONFIG_SCSI_SAS_LIBSAS=m |
| 95 | CONFIG_ISCSI_TCP=m | 92 | CONFIG_ISCSI_TCP=m |
| 96 | CONFIG_ISCSI_BOOT_SYSFS=m | 93 | CONFIG_ISCSI_BOOT_SYSFS=m |
| 94 | CONFIG_ATA=y | ||
| 95 | CONFIG_PATA_SIL680=y | ||
| 97 | CONFIG_FUSION=y | 96 | CONFIG_FUSION=y |
| 98 | CONFIG_FUSION_SPI=y | 97 | CONFIG_FUSION_SPI=y |
| 99 | CONFIG_FUSION_SAS=y | 98 | CONFIG_FUSION_SAS=y |
| @@ -114,9 +113,8 @@ CONFIG_INPUT_FF_MEMLESS=m | |||
| 114 | # CONFIG_KEYBOARD_ATKBD is not set | 113 | # CONFIG_KEYBOARD_ATKBD is not set |
| 115 | # CONFIG_KEYBOARD_HIL_OLD is not set | 114 | # CONFIG_KEYBOARD_HIL_OLD is not set |
| 116 | # CONFIG_KEYBOARD_HIL is not set | 115 | # CONFIG_KEYBOARD_HIL is not set |
| 117 | CONFIG_MOUSE_PS2=m | 116 | # CONFIG_MOUSE_PS2 is not set |
| 118 | CONFIG_INPUT_MISC=y | 117 | CONFIG_INPUT_MISC=y |
| 119 | CONFIG_INPUT_CM109=m | ||
| 120 | CONFIG_SERIO_SERPORT=m | 118 | CONFIG_SERIO_SERPORT=m |
| 121 | CONFIG_SERIO_PARKBD=m | 119 | CONFIG_SERIO_PARKBD=m |
| 122 | CONFIG_SERIO_GSCPS2=m | 120 | CONFIG_SERIO_GSCPS2=m |
| @@ -167,34 +165,6 @@ CONFIG_SND_VERBOSE_PRINTK=y | |||
| 167 | CONFIG_SND_AD1889=m | 165 | CONFIG_SND_AD1889=m |
| 168 | # CONFIG_SND_USB is not set | 166 | # CONFIG_SND_USB is not set |
| 169 | # CONFIG_SND_GSC is not set | 167 | # CONFIG_SND_GSC is not set |
| 170 | CONFIG_HID_A4TECH=m | ||
| 171 | CONFIG_HID_APPLE=m | ||
| 172 | CONFIG_HID_BELKIN=m | ||
| 173 | CONFIG_HID_CHERRY=m | ||
| 174 | CONFIG_HID_CHICONY=m | ||
| 175 | CONFIG_HID_CYPRESS=m | ||
| 176 | CONFIG_HID_DRAGONRISE=m | ||
| 177 | CONFIG_HID_EZKEY=m | ||
| 178 | CONFIG_HID_KYE=m | ||
| 179 | CONFIG_HID_GYRATION=m | ||
| 180 | CONFIG_HID_TWINHAN=m | ||
| 181 | CONFIG_HID_KENSINGTON=m | ||
| 182 | CONFIG_HID_LOGITECH=m | ||
| 183 | CONFIG_HID_LOGITECH_DJ=m | ||
| 184 | CONFIG_HID_MICROSOFT=m | ||
| 185 | CONFIG_HID_MONTEREY=m | ||
| 186 | CONFIG_HID_NTRIG=m | ||
| 187 | CONFIG_HID_ORTEK=m | ||
| 188 | CONFIG_HID_PANTHERLORD=m | ||
| 189 | CONFIG_HID_PETALYNX=m | ||
| 190 | CONFIG_HID_SAMSUNG=m | ||
| 191 | CONFIG_HID_SUNPLUS=m | ||
| 192 | CONFIG_HID_GREENASIA=m | ||
| 193 | CONFIG_HID_SMARTJOYPLUS=m | ||
| 194 | CONFIG_HID_TOPSEED=m | ||
| 195 | CONFIG_HID_THRUSTMASTER=m | ||
| 196 | CONFIG_HID_ZEROPLUS=m | ||
| 197 | CONFIG_USB_HID=m | ||
| 198 | CONFIG_USB=y | 168 | CONFIG_USB=y |
| 199 | CONFIG_USB_OHCI_HCD=y | 169 | CONFIG_USB_OHCI_HCD=y |
| 200 | CONFIG_USB_STORAGE=y | 170 | CONFIG_USB_STORAGE=y |
diff --git a/arch/parisc/configs/generic-64bit_defconfig b/arch/parisc/configs/generic-64bit_defconfig index 5874cebee077..28c1b5de044e 100644 --- a/arch/parisc/configs/generic-64bit_defconfig +++ b/arch/parisc/configs/generic-64bit_defconfig | |||
| @@ -24,7 +24,6 @@ CONFIG_MODVERSIONS=y | |||
| 24 | CONFIG_BLK_DEV_INTEGRITY=y | 24 | CONFIG_BLK_DEV_INTEGRITY=y |
| 25 | # CONFIG_IOSCHED_DEADLINE is not set | 25 | # CONFIG_IOSCHED_DEADLINE is not set |
| 26 | CONFIG_PA8X00=y | 26 | CONFIG_PA8X00=y |
| 27 | CONFIG_MLONGCALLS=y | ||
| 28 | CONFIG_64BIT=y | 27 | CONFIG_64BIT=y |
| 29 | CONFIG_SMP=y | 28 | CONFIG_SMP=y |
| 30 | # CONFIG_COMPACTION is not set | 29 | # CONFIG_COMPACTION is not set |
| @@ -68,7 +67,6 @@ CONFIG_IDE_GD=m | |||
| 68 | CONFIG_IDE_GD_ATAPI=y | 67 | CONFIG_IDE_GD_ATAPI=y |
| 69 | CONFIG_BLK_DEV_IDECD=m | 68 | CONFIG_BLK_DEV_IDECD=m |
| 70 | CONFIG_BLK_DEV_NS87415=y | 69 | CONFIG_BLK_DEV_NS87415=y |
| 71 | CONFIG_BLK_DEV_SIIMAGE=y | ||
| 72 | # CONFIG_SCSI_PROC_FS is not set | 70 | # CONFIG_SCSI_PROC_FS is not set |
| 73 | CONFIG_BLK_DEV_SD=y | 71 | CONFIG_BLK_DEV_SD=y |
| 74 | CONFIG_BLK_DEV_SR=y | 72 | CONFIG_BLK_DEV_SR=y |
| @@ -82,6 +80,7 @@ CONFIG_SCSI_ZALON=y | |||
| 82 | CONFIG_SCSI_QLA_ISCSI=m | 80 | CONFIG_SCSI_QLA_ISCSI=m |
| 83 | CONFIG_SCSI_DH=y | 81 | CONFIG_SCSI_DH=y |
| 84 | CONFIG_ATA=y | 82 | CONFIG_ATA=y |
| 83 | CONFIG_PATA_SIL680=y | ||
| 85 | CONFIG_ATA_GENERIC=y | 84 | CONFIG_ATA_GENERIC=y |
| 86 | CONFIG_MD=y | 85 | CONFIG_MD=y |
| 87 | CONFIG_MD_LINEAR=m | 86 | CONFIG_MD_LINEAR=m |
| @@ -162,7 +161,7 @@ CONFIG_SLIP_MODE_SLIP6=y | |||
| 162 | CONFIG_INPUT_EVDEV=y | 161 | CONFIG_INPUT_EVDEV=y |
| 163 | # CONFIG_KEYBOARD_HIL_OLD is not set | 162 | # CONFIG_KEYBOARD_HIL_OLD is not set |
| 164 | # CONFIG_KEYBOARD_HIL is not set | 163 | # CONFIG_KEYBOARD_HIL is not set |
| 165 | # CONFIG_INPUT_MOUSE is not set | 164 | # CONFIG_MOUSE_PS2 is not set |
| 166 | CONFIG_INPUT_MISC=y | 165 | CONFIG_INPUT_MISC=y |
| 167 | CONFIG_SERIO_SERPORT=m | 166 | CONFIG_SERIO_SERPORT=m |
| 168 | # CONFIG_HP_SDC is not set | 167 | # CONFIG_HP_SDC is not set |
| @@ -216,32 +215,7 @@ CONFIG_BACKLIGHT_LCD_SUPPORT=y | |||
| 216 | CONFIG_FRAMEBUFFER_CONSOLE_ROTATION=y | 215 | CONFIG_FRAMEBUFFER_CONSOLE_ROTATION=y |
| 217 | CONFIG_LOGO=y | 216 | CONFIG_LOGO=y |
| 218 | # CONFIG_LOGO_LINUX_MONO is not set | 217 | # CONFIG_LOGO_LINUX_MONO is not set |
| 219 | CONFIG_HID=m | ||
| 220 | CONFIG_HIDRAW=y | 218 | CONFIG_HIDRAW=y |
| 221 | CONFIG_HID_DRAGONRISE=m | ||
| 222 | CONFIG_DRAGONRISE_FF=y | ||
| 223 | CONFIG_HID_KYE=m | ||
| 224 | CONFIG_HID_GYRATION=m | ||
| 225 | CONFIG_HID_TWINHAN=m | ||
| 226 | CONFIG_LOGITECH_FF=y | ||
| 227 | CONFIG_LOGIRUMBLEPAD2_FF=y | ||
| 228 | CONFIG_HID_NTRIG=m | ||
| 229 | CONFIG_HID_PANTHERLORD=m | ||
| 230 | CONFIG_PANTHERLORD_FF=y | ||
| 231 | CONFIG_HID_PETALYNX=m | ||
| 232 | CONFIG_HID_SAMSUNG=m | ||
| 233 | CONFIG_HID_SONY=m | ||
| 234 | CONFIG_HID_SUNPLUS=m | ||
| 235 | CONFIG_HID_GREENASIA=m | ||
| 236 | CONFIG_GREENASIA_FF=y | ||
| 237 | CONFIG_HID_SMARTJOYPLUS=m | ||
| 238 | CONFIG_SMARTJOYPLUS_FF=y | ||
| 239 | CONFIG_HID_TOPSEED=m | ||
| 240 | CONFIG_HID_THRUSTMASTER=m | ||
| 241 | CONFIG_THRUSTMASTER_FF=y | ||
| 242 | CONFIG_HID_ZEROPLUS=m | ||
| 243 | CONFIG_ZEROPLUS_FF=y | ||
| 244 | CONFIG_USB_HID=m | ||
| 245 | CONFIG_HID_PID=y | 219 | CONFIG_HID_PID=y |
| 246 | CONFIG_USB_HIDDEV=y | 220 | CONFIG_USB_HIDDEV=y |
| 247 | CONFIG_USB=y | 221 | CONFIG_USB=y |
| @@ -251,13 +225,8 @@ CONFIG_USB_DYNAMIC_MINORS=y | |||
| 251 | CONFIG_USB_MON=m | 225 | CONFIG_USB_MON=m |
| 252 | CONFIG_USB_WUSB_CBAF=m | 226 | CONFIG_USB_WUSB_CBAF=m |
| 253 | CONFIG_USB_XHCI_HCD=m | 227 | CONFIG_USB_XHCI_HCD=m |
| 254 | CONFIG_USB_EHCI_HCD=m | 228 | CONFIG_USB_EHCI_HCD=y |
| 255 | CONFIG_USB_OHCI_HCD=m | 229 | CONFIG_USB_OHCI_HCD=y |
| 256 | CONFIG_USB_R8A66597_HCD=m | ||
| 257 | CONFIG_USB_ACM=m | ||
| 258 | CONFIG_USB_PRINTER=m | ||
| 259 | CONFIG_USB_WDM=m | ||
| 260 | CONFIG_USB_TMC=m | ||
| 261 | CONFIG_NEW_LEDS=y | 230 | CONFIG_NEW_LEDS=y |
| 262 | CONFIG_LEDS_CLASS=y | 231 | CONFIG_LEDS_CLASS=y |
| 263 | CONFIG_LEDS_TRIGGERS=y | 232 | CONFIG_LEDS_TRIGGERS=y |
diff --git a/arch/parisc/include/asm/serial.h b/arch/parisc/include/asm/serial.h index d7e3cc60dbc3..77e9b67c87ee 100644 --- a/arch/parisc/include/asm/serial.h +++ b/arch/parisc/include/asm/serial.h | |||
| @@ -6,5 +6,3 @@ | |||
| 6 | * This is used for 16550-compatible UARTs | 6 | * This is used for 16550-compatible UARTs |
| 7 | */ | 7 | */ |
| 8 | #define BASE_BAUD ( 1843200 / 16 ) | 8 | #define BASE_BAUD ( 1843200 / 16 ) |
| 9 | |||
| 10 | #define SERIAL_PORT_DFNS | ||
diff --git a/arch/parisc/include/asm/socket.h b/arch/parisc/include/asm/socket.h new file mode 100644 index 000000000000..748016cb122d --- /dev/null +++ b/arch/parisc/include/asm/socket.h | |||
| @@ -0,0 +1,11 @@ | |||
| 1 | #ifndef _ASM_SOCKET_H | ||
| 2 | #define _ASM_SOCKET_H | ||
| 3 | |||
| 4 | #include <uapi/asm/socket.h> | ||
| 5 | |||
| 6 | /* O_NONBLOCK clashes with the bits used for socket types. Therefore we | ||
| 7 | * have to define SOCK_NONBLOCK to a different value here. | ||
| 8 | */ | ||
| 9 | #define SOCK_NONBLOCK 0x40000000 | ||
| 10 | |||
| 11 | #endif /* _ASM_SOCKET_H */ | ||
diff --git a/arch/parisc/include/asm/uaccess.h b/arch/parisc/include/asm/uaccess.h index 63f4dd0b49c2..4006964d8e12 100644 --- a/arch/parisc/include/asm/uaccess.h +++ b/arch/parisc/include/asm/uaccess.h | |||
| @@ -4,14 +4,11 @@ | |||
| 4 | /* | 4 | /* |
| 5 | * User space memory access functions | 5 | * User space memory access functions |
| 6 | */ | 6 | */ |
| 7 | #include <asm/processor.h> | ||
| 8 | #include <asm/page.h> | 7 | #include <asm/page.h> |
| 9 | #include <asm/cache.h> | 8 | #include <asm/cache.h> |
| 10 | #include <asm/errno.h> | 9 | #include <asm/errno.h> |
| 11 | #include <asm-generic/uaccess-unaligned.h> | 10 | #include <asm-generic/uaccess-unaligned.h> |
| 12 | 11 | ||
| 13 | #include <linux/sched.h> | ||
| 14 | |||
| 15 | #define VERIFY_READ 0 | 12 | #define VERIFY_READ 0 |
| 16 | #define VERIFY_WRITE 1 | 13 | #define VERIFY_WRITE 1 |
| 17 | 14 | ||
| @@ -36,43 +33,12 @@ extern int __get_user_bad(void); | |||
| 36 | extern int __put_kernel_bad(void); | 33 | extern int __put_kernel_bad(void); |
| 37 | extern int __put_user_bad(void); | 34 | extern int __put_user_bad(void); |
| 38 | 35 | ||
| 39 | 36 | static inline long access_ok(int type, const void __user * addr, | |
| 40 | /* | 37 | unsigned long size) |
| 41 | * Test whether a block of memory is a valid user space address. | ||
| 42 | * Returns 0 if the range is valid, nonzero otherwise. | ||
| 43 | */ | ||
| 44 | static inline int __range_not_ok(unsigned long addr, unsigned long size, | ||
| 45 | unsigned long limit) | ||
| 46 | { | 38 | { |
| 47 | unsigned long __newaddr = addr + size; | 39 | return 1; |
| 48 | return (__newaddr < addr || __newaddr > limit || size > limit); | ||
| 49 | } | 40 | } |
| 50 | 41 | ||
| 51 | /** | ||
| 52 | * access_ok: - Checks if a user space pointer is valid | ||
| 53 | * @type: Type of access: %VERIFY_READ or %VERIFY_WRITE. Note that | ||
| 54 | * %VERIFY_WRITE is a superset of %VERIFY_READ - if it is safe | ||
| 55 | * to write to a block, it is always safe to read from it. | ||
| 56 | * @addr: User space pointer to start of block to check | ||
| 57 | * @size: Size of block to check | ||
| 58 | * | ||
| 59 | * Context: User context only. This function may sleep. | ||
| 60 | * | ||
| 61 | * Checks if a pointer to a block of memory in user space is valid. | ||
| 62 | * | ||
| 63 | * Returns true (nonzero) if the memory block may be valid, false (zero) | ||
| 64 | * if it is definitely invalid. | ||
| 65 | * | ||
| 66 | * Note that, depending on architecture, this function probably just | ||
| 67 | * checks that the pointer is in the user space range - after calling | ||
| 68 | * this function, memory access functions may still return -EFAULT. | ||
| 69 | */ | ||
| 70 | #define access_ok(type, addr, size) \ | ||
| 71 | ( __chk_user_ptr(addr), \ | ||
| 72 | !__range_not_ok((unsigned long) (__force void *) (addr), \ | ||
| 73 | size, user_addr_max()) \ | ||
| 74 | ) | ||
| 75 | |||
| 76 | #define put_user __put_user | 42 | #define put_user __put_user |
| 77 | #define get_user __get_user | 43 | #define get_user __get_user |
| 78 | 44 | ||
| @@ -253,11 +219,7 @@ extern long lstrnlen_user(const char __user *,long); | |||
| 253 | /* | 219 | /* |
| 254 | * Complex access routines -- macros | 220 | * Complex access routines -- macros |
| 255 | */ | 221 | */ |
| 256 | #ifdef CONFIG_COMPAT | 222 | #define user_addr_max() (~0UL) |
| 257 | #define user_addr_max() (TASK_SIZE) | ||
| 258 | #else | ||
| 259 | #define user_addr_max() (DEFAULT_TASK_SIZE) | ||
| 260 | #endif | ||
| 261 | 223 | ||
| 262 | #define strnlen_user lstrnlen_user | 224 | #define strnlen_user lstrnlen_user |
| 263 | #define strlen_user(str) lstrnlen_user(str, 0x7fffffffL) | 225 | #define strlen_user(str) lstrnlen_user(str, 0x7fffffffL) |
diff --git a/arch/parisc/include/uapi/asm/socket.h b/arch/parisc/include/uapi/asm/socket.h index 7c614d01f1fa..f33113a6141e 100644 --- a/arch/parisc/include/uapi/asm/socket.h +++ b/arch/parisc/include/uapi/asm/socket.h | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | #ifndef _ASM_SOCKET_H | 1 | #ifndef _UAPI_ASM_SOCKET_H |
| 2 | #define _ASM_SOCKET_H | 2 | #define _UAPI_ASM_SOCKET_H |
| 3 | 3 | ||
| 4 | #include <asm/sockios.h> | 4 | #include <asm/sockios.h> |
| 5 | 5 | ||
| @@ -77,9 +77,4 @@ | |||
| 77 | 77 | ||
| 78 | #define SO_MAX_PACING_RATE 0x4048 | 78 | #define SO_MAX_PACING_RATE 0x4048 |
| 79 | 79 | ||
| 80 | /* O_NONBLOCK clashes with the bits used for socket types. Therefore we | 80 | #endif /* _UAPI_ASM_SOCKET_H */ |
| 81 | * have to define SOCK_NONBLOCK to a different value here. | ||
| 82 | */ | ||
| 83 | #define SOCK_NONBLOCK 0x40000000 | ||
| 84 | |||
| 85 | #endif /* _ASM_SOCKET_H */ | ||
diff --git a/arch/parisc/kernel/hardware.c b/arch/parisc/kernel/hardware.c index 06cb3992907e..608716f8496b 100644 --- a/arch/parisc/kernel/hardware.c +++ b/arch/parisc/kernel/hardware.c | |||
| @@ -36,6 +36,9 @@ | |||
| 36 | * HP PARISC Hardware Database | 36 | * HP PARISC Hardware Database |
| 37 | * Access to this database is only possible during bootup | 37 | * Access to this database is only possible during bootup |
| 38 | * so don't reference this table after starting the init process | 38 | * so don't reference this table after starting the init process |
| 39 | * | ||
| 40 | * NOTE: Product names which are listed here and ends with a '?' | ||
| 41 | * are guessed. If you know the correct name, please let us know. | ||
| 39 | */ | 42 | */ |
| 40 | 43 | ||
| 41 | static struct hp_hardware hp_hardware_list[] = { | 44 | static struct hp_hardware hp_hardware_list[] = { |
| @@ -222,7 +225,7 @@ static struct hp_hardware hp_hardware_list[] = { | |||
| 222 | {HPHW_NPROC,0x5DD,0x4,0x81,"Duet W2"}, | 225 | {HPHW_NPROC,0x5DD,0x4,0x81,"Duet W2"}, |
| 223 | {HPHW_NPROC,0x5DE,0x4,0x81,"Piccolo W+"}, | 226 | {HPHW_NPROC,0x5DE,0x4,0x81,"Piccolo W+"}, |
| 224 | {HPHW_NPROC,0x5DF,0x4,0x81,"Cantata W2"}, | 227 | {HPHW_NPROC,0x5DF,0x4,0x81,"Cantata W2"}, |
| 225 | {HPHW_NPROC,0x5DF,0x0,0x00,"Marcato W+? (rp5470)"}, | 228 | {HPHW_NPROC,0x5DF,0x0,0x00,"Marcato W+ (rp5470)?"}, |
| 226 | {HPHW_NPROC,0x5E0,0x4,0x91,"Cantata DC- W2"}, | 229 | {HPHW_NPROC,0x5E0,0x4,0x91,"Cantata DC- W2"}, |
| 227 | {HPHW_NPROC,0x5E1,0x4,0x91,"Crescendo DC- W2"}, | 230 | {HPHW_NPROC,0x5E1,0x4,0x91,"Crescendo DC- W2"}, |
| 228 | {HPHW_NPROC,0x5E2,0x4,0x91,"Crescendo 650 W2"}, | 231 | {HPHW_NPROC,0x5E2,0x4,0x91,"Crescendo 650 W2"}, |
| @@ -276,9 +279,11 @@ static struct hp_hardware hp_hardware_list[] = { | |||
| 276 | {HPHW_NPROC,0x888,0x4,0x91,"Storm Peak Fast DC-"}, | 279 | {HPHW_NPROC,0x888,0x4,0x91,"Storm Peak Fast DC-"}, |
| 277 | {HPHW_NPROC,0x889,0x4,0x91,"Storm Peak Fast"}, | 280 | {HPHW_NPROC,0x889,0x4,0x91,"Storm Peak Fast"}, |
| 278 | {HPHW_NPROC,0x88A,0x4,0x91,"Crestone Peak Slow"}, | 281 | {HPHW_NPROC,0x88A,0x4,0x91,"Crestone Peak Slow"}, |
| 282 | {HPHW_NPROC,0x88B,0x4,0x91,"Crestone Peak Fast?"}, | ||
| 279 | {HPHW_NPROC,0x88C,0x4,0x91,"Orca Mako+"}, | 283 | {HPHW_NPROC,0x88C,0x4,0x91,"Orca Mako+"}, |
| 280 | {HPHW_NPROC,0x88D,0x4,0x91,"Rainier/Medel Mako+ Slow"}, | 284 | {HPHW_NPROC,0x88D,0x4,0x91,"Rainier/Medel Mako+ Slow"}, |
| 281 | {HPHW_NPROC,0x88E,0x4,0x91,"Rainier/Medel Mako+ Fast"}, | 285 | {HPHW_NPROC,0x88E,0x4,0x91,"Rainier/Medel Mako+ Fast"}, |
| 286 | {HPHW_NPROC,0x892,0x4,0x91,"Mt. Hamilton Slow Mako+?"}, | ||
| 282 | {HPHW_NPROC,0x894,0x4,0x91,"Mt. Hamilton Fast Mako+"}, | 287 | {HPHW_NPROC,0x894,0x4,0x91,"Mt. Hamilton Fast Mako+"}, |
| 283 | {HPHW_NPROC,0x895,0x4,0x91,"Storm Peak Slow Mako+"}, | 288 | {HPHW_NPROC,0x895,0x4,0x91,"Storm Peak Slow Mako+"}, |
| 284 | {HPHW_NPROC,0x896,0x4,0x91,"Storm Peak Fast Mako+"}, | 289 | {HPHW_NPROC,0x896,0x4,0x91,"Storm Peak Fast Mako+"}, |
diff --git a/arch/parisc/kernel/head.S b/arch/parisc/kernel/head.S index d2d58258aea6..d4dc588c0dc1 100644 --- a/arch/parisc/kernel/head.S +++ b/arch/parisc/kernel/head.S | |||
| @@ -41,9 +41,7 @@ END(boot_args) | |||
| 41 | .import fault_vector_11,code /* IVA parisc 1.1 32 bit */ | 41 | .import fault_vector_11,code /* IVA parisc 1.1 32 bit */ |
| 42 | .import $global$ /* forward declaration */ | 42 | .import $global$ /* forward declaration */ |
| 43 | #endif /*!CONFIG_64BIT*/ | 43 | #endif /*!CONFIG_64BIT*/ |
| 44 | .export _stext,data /* Kernel want it this way! */ | 44 | ENTRY(parisc_kernel_start) |
| 45 | _stext: | ||
| 46 | ENTRY(stext) | ||
| 47 | .proc | 45 | .proc |
| 48 | .callinfo | 46 | .callinfo |
| 49 | 47 | ||
| @@ -347,7 +345,7 @@ smp_slave_stext: | |||
| 347 | .procend | 345 | .procend |
| 348 | #endif /* CONFIG_SMP */ | 346 | #endif /* CONFIG_SMP */ |
| 349 | 347 | ||
| 350 | ENDPROC(stext) | 348 | ENDPROC(parisc_kernel_start) |
| 351 | 349 | ||
| 352 | #ifndef CONFIG_64BIT | 350 | #ifndef CONFIG_64BIT |
| 353 | .section .data..read_mostly | 351 | .section .data..read_mostly |
diff --git a/arch/parisc/kernel/sys_parisc.c b/arch/parisc/kernel/sys_parisc.c index 5dfd248e3f1a..0d3a9d4927b5 100644 --- a/arch/parisc/kernel/sys_parisc.c +++ b/arch/parisc/kernel/sys_parisc.c | |||
| @@ -61,8 +61,15 @@ static int get_offset(struct address_space *mapping) | |||
| 61 | return (unsigned long) mapping >> 8; | 61 | return (unsigned long) mapping >> 8; |
| 62 | } | 62 | } |
| 63 | 63 | ||
| 64 | static unsigned long get_shared_area(struct address_space *mapping, | 64 | static unsigned long shared_align_offset(struct file *filp, unsigned long pgoff) |
| 65 | unsigned long addr, unsigned long len, unsigned long pgoff) | 65 | { |
| 66 | struct address_space *mapping = filp ? filp->f_mapping : NULL; | ||
| 67 | |||
| 68 | return (get_offset(mapping) + pgoff) << PAGE_SHIFT; | ||
| 69 | } | ||
| 70 | |||
| 71 | static unsigned long get_shared_area(struct file *filp, unsigned long addr, | ||
| 72 | unsigned long len, unsigned long pgoff) | ||
| 66 | { | 73 | { |
| 67 | struct vm_unmapped_area_info info; | 74 | struct vm_unmapped_area_info info; |
| 68 | 75 | ||
| @@ -71,7 +78,7 @@ static unsigned long get_shared_area(struct address_space *mapping, | |||
| 71 | info.low_limit = PAGE_ALIGN(addr); | 78 | info.low_limit = PAGE_ALIGN(addr); |
| 72 | info.high_limit = TASK_SIZE; | 79 | info.high_limit = TASK_SIZE; |
| 73 | info.align_mask = PAGE_MASK & (SHMLBA - 1); | 80 | info.align_mask = PAGE_MASK & (SHMLBA - 1); |
| 74 | info.align_offset = (get_offset(mapping) + pgoff) << PAGE_SHIFT; | 81 | info.align_offset = shared_align_offset(filp, pgoff); |
| 75 | return vm_unmapped_area(&info); | 82 | return vm_unmapped_area(&info); |
| 76 | } | 83 | } |
| 77 | 84 | ||
| @@ -82,20 +89,18 @@ unsigned long arch_get_unmapped_area(struct file *filp, unsigned long addr, | |||
| 82 | return -ENOMEM; | 89 | return -ENOMEM; |
| 83 | if (flags & MAP_FIXED) { | 90 | if (flags & MAP_FIXED) { |
| 84 | if ((flags & MAP_SHARED) && | 91 | if ((flags & MAP_SHARED) && |
| 85 | (addr - (pgoff << PAGE_SHIFT)) & (SHMLBA - 1)) | 92 | (addr - shared_align_offset(filp, pgoff)) & (SHMLBA - 1)) |
| 86 | return -EINVAL; | 93 | return -EINVAL; |
| 87 | return addr; | 94 | return addr; |
| 88 | } | 95 | } |
| 89 | if (!addr) | 96 | if (!addr) |
| 90 | addr = TASK_UNMAPPED_BASE; | 97 | addr = TASK_UNMAPPED_BASE; |
| 91 | 98 | ||
| 92 | if (filp) { | 99 | if (filp || (flags & MAP_SHARED)) |
| 93 | addr = get_shared_area(filp->f_mapping, addr, len, pgoff); | 100 | addr = get_shared_area(filp, addr, len, pgoff); |
| 94 | } else if(flags & MAP_SHARED) { | 101 | else |
| 95 | addr = get_shared_area(NULL, addr, len, pgoff); | ||
| 96 | } else { | ||
| 97 | addr = get_unshared_area(addr, len); | 102 | addr = get_unshared_area(addr, len); |
| 98 | } | 103 | |
| 99 | return addr; | 104 | return addr; |
| 100 | } | 105 | } |
| 101 | 106 | ||
diff --git a/arch/parisc/kernel/unwind.c b/arch/parisc/kernel/unwind.c index 76ed62ed785b..ddd988b267a9 100644 --- a/arch/parisc/kernel/unwind.c +++ b/arch/parisc/kernel/unwind.c | |||
| @@ -168,7 +168,7 @@ void unwind_table_remove(struct unwind_table *table) | |||
| 168 | } | 168 | } |
| 169 | 169 | ||
| 170 | /* Called from setup_arch to import the kernel unwind info */ | 170 | /* Called from setup_arch to import the kernel unwind info */ |
| 171 | int unwind_init(void) | 171 | int __init unwind_init(void) |
| 172 | { | 172 | { |
| 173 | long start, stop; | 173 | long start, stop; |
| 174 | register unsigned long gp __asm__ ("r27"); | 174 | register unsigned long gp __asm__ ("r27"); |
| @@ -233,7 +233,6 @@ static void unwind_frame_regs(struct unwind_frame_info *info) | |||
| 233 | e = find_unwind_entry(info->ip); | 233 | e = find_unwind_entry(info->ip); |
| 234 | if (e == NULL) { | 234 | if (e == NULL) { |
| 235 | unsigned long sp; | 235 | unsigned long sp; |
| 236 | extern char _stext[], _etext[]; | ||
| 237 | 236 | ||
| 238 | dbg("Cannot find unwind entry for 0x%lx; forced unwinding\n", info->ip); | 237 | dbg("Cannot find unwind entry for 0x%lx; forced unwinding\n", info->ip); |
| 239 | 238 | ||
| @@ -281,8 +280,7 @@ static void unwind_frame_regs(struct unwind_frame_info *info) | |||
| 281 | break; | 280 | break; |
| 282 | info->prev_ip = tmp; | 281 | info->prev_ip = tmp; |
| 283 | sp = info->prev_sp; | 282 | sp = info->prev_sp; |
| 284 | } while (info->prev_ip < (unsigned long)_stext || | 283 | } while (!kernel_text_address(info->prev_ip)); |
| 285 | info->prev_ip > (unsigned long)_etext); | ||
| 286 | 284 | ||
| 287 | info->rp = 0; | 285 | info->rp = 0; |
| 288 | 286 | ||
| @@ -435,9 +433,8 @@ unsigned long return_address(unsigned int level) | |||
| 435 | do { | 433 | do { |
| 436 | if (unwind_once(&info) < 0 || info.ip == 0) | 434 | if (unwind_once(&info) < 0 || info.ip == 0) |
| 437 | return 0; | 435 | return 0; |
| 438 | if (!__kernel_text_address(info.ip)) { | 436 | if (!kernel_text_address(info.ip)) |
| 439 | return 0; | 437 | return 0; |
| 440 | } | ||
| 441 | } while (info.ip && level--); | 438 | } while (info.ip && level--); |
| 442 | 439 | ||
| 443 | return info.ip; | 440 | return info.ip; |
diff --git a/arch/parisc/kernel/vmlinux.lds.S b/arch/parisc/kernel/vmlinux.lds.S index 4bb095a2f6fc..0dacc5ca555a 100644 --- a/arch/parisc/kernel/vmlinux.lds.S +++ b/arch/parisc/kernel/vmlinux.lds.S | |||
| @@ -6,24 +6,19 @@ | |||
| 6 | * Copyright (C) 2000 Michael Ang <mang with subcarrier.org> | 6 | * Copyright (C) 2000 Michael Ang <mang with subcarrier.org> |
| 7 | * Copyright (C) 2002 Randolph Chung <tausq with parisc-linux.org> | 7 | * Copyright (C) 2002 Randolph Chung <tausq with parisc-linux.org> |
| 8 | * Copyright (C) 2003 James Bottomley <jejb with parisc-linux.org> | 8 | * Copyright (C) 2003 James Bottomley <jejb with parisc-linux.org> |
| 9 | * Copyright (C) 2006 Helge Deller <deller@gmx.de> | 9 | * Copyright (C) 2006-2013 Helge Deller <deller@gmx.de> |
| 10 | * | 10 | */ |
| 11 | * | 11 | |
| 12 | * This program is free software; you can redistribute it and/or modify | 12 | /* |
| 13 | * it under the terms of the GNU General Public License as published by | 13 | * Put page table entries (swapper_pg_dir) as the first thing in .bss. This |
| 14 | * the Free Software Foundation; either version 2 of the License, or | 14 | * will ensure that it has .bss alignment (PAGE_SIZE). |
| 15 | * (at your option) any later version. | ||
| 16 | * | ||
| 17 | * This program is distributed in the hope that it will be useful, | ||
| 18 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 19 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 20 | * GNU General Public License for more details. | ||
| 21 | * | ||
| 22 | * You should have received a copy of the GNU General Public License | ||
| 23 | * along with this program; if not, write to the Free Software | ||
| 24 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 25 | */ | 15 | */ |
| 16 | #define BSS_FIRST_SECTIONS *(.data..vm0.pmd) \ | ||
| 17 | *(.data..vm0.pgd) \ | ||
| 18 | *(.data..vm0.pte) | ||
| 19 | |||
| 26 | #include <asm-generic/vmlinux.lds.h> | 20 | #include <asm-generic/vmlinux.lds.h> |
| 21 | |||
| 27 | /* needed for the processor specific cache alignment size */ | 22 | /* needed for the processor specific cache alignment size */ |
| 28 | #include <asm/cache.h> | 23 | #include <asm/cache.h> |
| 29 | #include <asm/page.h> | 24 | #include <asm/page.h> |
| @@ -39,7 +34,7 @@ OUTPUT_FORMAT("elf64-hppa-linux") | |||
| 39 | OUTPUT_ARCH(hppa:hppa2.0w) | 34 | OUTPUT_ARCH(hppa:hppa2.0w) |
| 40 | #endif | 35 | #endif |
| 41 | 36 | ||
| 42 | ENTRY(_stext) | 37 | ENTRY(parisc_kernel_start) |
| 43 | #ifndef CONFIG_64BIT | 38 | #ifndef CONFIG_64BIT |
| 44 | jiffies = jiffies_64 + 4; | 39 | jiffies = jiffies_64 + 4; |
| 45 | #else | 40 | #else |
| @@ -49,11 +44,29 @@ SECTIONS | |||
| 49 | { | 44 | { |
| 50 | . = KERNEL_BINARY_TEXT_START; | 45 | . = KERNEL_BINARY_TEXT_START; |
| 51 | 46 | ||
| 47 | __init_begin = .; | ||
| 48 | HEAD_TEXT_SECTION | ||
| 49 | INIT_TEXT_SECTION(8) | ||
| 50 | |||
| 51 | . = ALIGN(PAGE_SIZE); | ||
| 52 | INIT_DATA_SECTION(PAGE_SIZE) | ||
| 53 | /* we have to discard exit text and such at runtime, not link time */ | ||
| 54 | .exit.text : | ||
| 55 | { | ||
| 56 | EXIT_TEXT | ||
| 57 | } | ||
| 58 | .exit.data : | ||
| 59 | { | ||
| 60 | EXIT_DATA | ||
| 61 | } | ||
| 62 | PERCPU_SECTION(8) | ||
| 63 | . = ALIGN(PAGE_SIZE); | ||
| 64 | __init_end = .; | ||
| 65 | /* freed after init ends here */ | ||
| 66 | |||
| 52 | _text = .; /* Text and read-only data */ | 67 | _text = .; /* Text and read-only data */ |
| 53 | .head ALIGN(16) : { | 68 | _stext = .; |
| 54 | HEAD_TEXT | 69 | .text ALIGN(PAGE_SIZE) : { |
| 55 | } = 0 | ||
| 56 | .text ALIGN(16) : { | ||
| 57 | TEXT_TEXT | 70 | TEXT_TEXT |
| 58 | SCHED_TEXT | 71 | SCHED_TEXT |
| 59 | LOCK_TEXT | 72 | LOCK_TEXT |
| @@ -68,21 +81,28 @@ SECTIONS | |||
| 68 | *(.lock.text) /* out-of-line lock text */ | 81 | *(.lock.text) /* out-of-line lock text */ |
| 69 | *(.gnu.warning) | 82 | *(.gnu.warning) |
| 70 | } | 83 | } |
| 71 | /* End of text section */ | 84 | . = ALIGN(PAGE_SIZE); |
| 72 | _etext = .; | 85 | _etext = .; |
| 86 | /* End of text section */ | ||
| 73 | 87 | ||
| 74 | /* Start of data section */ | 88 | /* Start of data section */ |
| 75 | _sdata = .; | 89 | _sdata = .; |
| 76 | 90 | ||
| 77 | RODATA | 91 | RO_DATA_SECTION(8) |
| 78 | 92 | ||
| 79 | /* writeable */ | 93 | #ifdef CONFIG_64BIT |
| 80 | /* Make sure this is page aligned so | 94 | . = ALIGN(16); |
| 81 | * that we can properly leave these | 95 | /* Linkage tables */ |
| 82 | * as writable | 96 | .opd : { |
| 83 | */ | 97 | *(.opd) |
| 84 | . = ALIGN(PAGE_SIZE); | 98 | } PROVIDE (__gp = .); |
| 85 | data_start = .; | 99 | .plt : { |
| 100 | *(.plt) | ||
| 101 | } | ||
| 102 | .dlt : { | ||
| 103 | *(.dlt) | ||
| 104 | } | ||
| 105 | #endif | ||
| 86 | 106 | ||
| 87 | /* unwind info */ | 107 | /* unwind info */ |
| 88 | .PARISC.unwind : { | 108 | .PARISC.unwind : { |
| @@ -91,7 +111,15 @@ SECTIONS | |||
| 91 | __stop___unwind = .; | 111 | __stop___unwind = .; |
| 92 | } | 112 | } |
| 93 | 113 | ||
| 94 | EXCEPTION_TABLE(16) | 114 | /* writeable */ |
| 115 | /* Make sure this is page aligned so | ||
| 116 | * that we can properly leave these | ||
| 117 | * as writable | ||
| 118 | */ | ||
| 119 | . = ALIGN(PAGE_SIZE); | ||
| 120 | data_start = .; | ||
| 121 | |||
| 122 | EXCEPTION_TABLE(8) | ||
| 95 | NOTES | 123 | NOTES |
| 96 | 124 | ||
| 97 | /* Data */ | 125 | /* Data */ |
| @@ -107,54 +135,8 @@ SECTIONS | |||
| 107 | _edata = .; | 135 | _edata = .; |
| 108 | 136 | ||
| 109 | /* BSS */ | 137 | /* BSS */ |
| 110 | __bss_start = .; | 138 | BSS_SECTION(PAGE_SIZE, PAGE_SIZE, 8) |
| 111 | /* page table entries need to be PAGE_SIZE aligned */ | ||
| 112 | . = ALIGN(PAGE_SIZE); | ||
| 113 | .data..vmpages : { | ||
| 114 | *(.data..vm0.pmd) | ||
| 115 | *(.data..vm0.pgd) | ||
| 116 | *(.data..vm0.pte) | ||
| 117 | } | ||
| 118 | .bss : { | ||
| 119 | *(.bss) | ||
| 120 | *(COMMON) | ||
| 121 | } | ||
| 122 | __bss_stop = .; | ||
| 123 | |||
| 124 | #ifdef CONFIG_64BIT | ||
| 125 | . = ALIGN(16); | ||
| 126 | /* Linkage tables */ | ||
| 127 | .opd : { | ||
| 128 | *(.opd) | ||
| 129 | } PROVIDE (__gp = .); | ||
| 130 | .plt : { | ||
| 131 | *(.plt) | ||
| 132 | } | ||
| 133 | .dlt : { | ||
| 134 | *(.dlt) | ||
| 135 | } | ||
| 136 | #endif | ||
| 137 | 139 | ||
| 138 | /* reserve space for interrupt stack by aligning __init* to 16k */ | ||
| 139 | . = ALIGN(16384); | ||
| 140 | __init_begin = .; | ||
| 141 | INIT_TEXT_SECTION(16384) | ||
| 142 | . = ALIGN(PAGE_SIZE); | ||
| 143 | INIT_DATA_SECTION(16) | ||
| 144 | /* we have to discard exit text and such at runtime, not link time */ | ||
| 145 | .exit.text : | ||
| 146 | { | ||
| 147 | EXIT_TEXT | ||
| 148 | } | ||
| 149 | .exit.data : | ||
| 150 | { | ||
| 151 | EXIT_DATA | ||
| 152 | } | ||
| 153 | |||
| 154 | PERCPU_SECTION(L1_CACHE_BYTES) | ||
| 155 | . = ALIGN(PAGE_SIZE); | ||
| 156 | __init_end = .; | ||
| 157 | /* freed after init ends here */ | ||
| 158 | _end = . ; | 140 | _end = . ; |
| 159 | 141 | ||
| 160 | STABS_DEBUG | 142 | STABS_DEBUG |
diff --git a/arch/parisc/lib/memcpy.c b/arch/parisc/lib/memcpy.c index b5507ec06b84..413dc1769299 100644 --- a/arch/parisc/lib/memcpy.c +++ b/arch/parisc/lib/memcpy.c | |||
| @@ -161,7 +161,7 @@ static inline void prefetch_dst(const void *addr) | |||
| 161 | /* Copy from a not-aligned src to an aligned dst, using shifts. Handles 4 words | 161 | /* Copy from a not-aligned src to an aligned dst, using shifts. Handles 4 words |
| 162 | * per loop. This code is derived from glibc. | 162 | * per loop. This code is derived from glibc. |
| 163 | */ | 163 | */ |
| 164 | static inline unsigned long copy_dstaligned(unsigned long dst, | 164 | static noinline unsigned long copy_dstaligned(unsigned long dst, |
| 165 | unsigned long src, unsigned long len) | 165 | unsigned long src, unsigned long len) |
| 166 | { | 166 | { |
| 167 | /* gcc complains that a2 and a3 may be uninitialized, but actually | 167 | /* gcc complains that a2 and a3 may be uninitialized, but actually |
| @@ -276,7 +276,7 @@ handle_store_error: | |||
| 276 | /* Returns PA_MEMCPY_OK, PA_MEMCPY_LOAD_ERROR or PA_MEMCPY_STORE_ERROR. | 276 | /* Returns PA_MEMCPY_OK, PA_MEMCPY_LOAD_ERROR or PA_MEMCPY_STORE_ERROR. |
| 277 | * In case of an access fault the faulty address can be read from the per_cpu | 277 | * In case of an access fault the faulty address can be read from the per_cpu |
| 278 | * exception data struct. */ | 278 | * exception data struct. */ |
| 279 | static unsigned long pa_memcpy_internal(void *dstp, const void *srcp, | 279 | static noinline unsigned long pa_memcpy_internal(void *dstp, const void *srcp, |
| 280 | unsigned long len) | 280 | unsigned long len) |
| 281 | { | 281 | { |
| 282 | register unsigned long src, dst, t1, t2, t3; | 282 | register unsigned long src, dst, t1, t2, t3; |
| @@ -529,7 +529,7 @@ long probe_kernel_read(void *dst, const void *src, size_t size) | |||
| 529 | { | 529 | { |
| 530 | unsigned long addr = (unsigned long)src; | 530 | unsigned long addr = (unsigned long)src; |
| 531 | 531 | ||
| 532 | if (size < 0 || addr < PAGE_SIZE) | 532 | if (addr < PAGE_SIZE) |
| 533 | return -EFAULT; | 533 | return -EFAULT; |
| 534 | 534 | ||
| 535 | /* check for I/O space F_EXTEND(0xfff00000) access as well? */ | 535 | /* check for I/O space F_EXTEND(0xfff00000) access as well? */ |
diff --git a/arch/parisc/mm/fault.c b/arch/parisc/mm/fault.c index 7584a5df0fa4..9d08c71a967e 100644 --- a/arch/parisc/mm/fault.c +++ b/arch/parisc/mm/fault.c | |||
| @@ -282,16 +282,34 @@ bad_area: | |||
| 282 | #endif | 282 | #endif |
| 283 | switch (code) { | 283 | switch (code) { |
| 284 | case 15: /* Data TLB miss fault/Data page fault */ | 284 | case 15: /* Data TLB miss fault/Data page fault */ |
| 285 | /* send SIGSEGV when outside of vma */ | ||
| 286 | if (!vma || | ||
| 287 | address < vma->vm_start || address > vma->vm_end) { | ||
| 288 | si.si_signo = SIGSEGV; | ||
| 289 | si.si_code = SEGV_MAPERR; | ||
| 290 | break; | ||
| 291 | } | ||
| 292 | |||
| 293 | /* send SIGSEGV for wrong permissions */ | ||
| 294 | if ((vma->vm_flags & acc_type) != acc_type) { | ||
| 295 | si.si_signo = SIGSEGV; | ||
| 296 | si.si_code = SEGV_ACCERR; | ||
| 297 | break; | ||
| 298 | } | ||
| 299 | |||
| 300 | /* probably address is outside of mapped file */ | ||
| 301 | /* fall through */ | ||
| 285 | case 17: /* NA data TLB miss / page fault */ | 302 | case 17: /* NA data TLB miss / page fault */ |
| 286 | case 18: /* Unaligned access - PCXS only */ | 303 | case 18: /* Unaligned access - PCXS only */ |
| 287 | si.si_signo = SIGBUS; | 304 | si.si_signo = SIGBUS; |
| 288 | si.si_code = BUS_ADRERR; | 305 | si.si_code = (code == 18) ? BUS_ADRALN : BUS_ADRERR; |
| 289 | break; | 306 | break; |
| 290 | case 16: /* Non-access instruction TLB miss fault */ | 307 | case 16: /* Non-access instruction TLB miss fault */ |
| 291 | case 26: /* PCXL: Data memory access rights trap */ | 308 | case 26: /* PCXL: Data memory access rights trap */ |
| 292 | default: | 309 | default: |
| 293 | si.si_signo = SIGSEGV; | 310 | si.si_signo = SIGSEGV; |
| 294 | si.si_code = SEGV_MAPERR; | 311 | si.si_code = (code == 26) ? SEGV_ACCERR : SEGV_MAPERR; |
| 312 | break; | ||
| 295 | } | 313 | } |
| 296 | si.si_errno = 0; | 314 | si.si_errno = 0; |
| 297 | si.si_addr = (void __user *) address; | 315 | si.si_addr = (void __user *) address; |
diff --git a/arch/parisc/mm/init.c b/arch/parisc/mm/init.c index b0f96c0e6316..96f8168cf4ec 100644 --- a/arch/parisc/mm/init.c +++ b/arch/parisc/mm/init.c | |||
| @@ -32,6 +32,7 @@ | |||
| 32 | #include <asm/sections.h> | 32 | #include <asm/sections.h> |
| 33 | 33 | ||
| 34 | extern int data_start; | 34 | extern int data_start; |
| 35 | extern void parisc_kernel_start(void); /* Kernel entry point in head.S */ | ||
| 35 | 36 | ||
| 36 | #if PT_NLEVELS == 3 | 37 | #if PT_NLEVELS == 3 |
| 37 | /* NOTE: This layout exactly conforms to the hybrid L2/L3 page table layout | 38 | /* NOTE: This layout exactly conforms to the hybrid L2/L3 page table layout |
| @@ -324,8 +325,9 @@ static void __init setup_bootmem(void) | |||
| 324 | reserve_bootmem_node(NODE_DATA(0), 0UL, | 325 | reserve_bootmem_node(NODE_DATA(0), 0UL, |
| 325 | (unsigned long)(PAGE0->mem_free + | 326 | (unsigned long)(PAGE0->mem_free + |
| 326 | PDC_CONSOLE_IO_IODC_SIZE), BOOTMEM_DEFAULT); | 327 | PDC_CONSOLE_IO_IODC_SIZE), BOOTMEM_DEFAULT); |
| 327 | reserve_bootmem_node(NODE_DATA(0), __pa((unsigned long)_text), | 328 | reserve_bootmem_node(NODE_DATA(0), __pa(KERNEL_BINARY_TEXT_START), |
| 328 | (unsigned long)(_end - _text), BOOTMEM_DEFAULT); | 329 | (unsigned long)(_end - KERNEL_BINARY_TEXT_START), |
| 330 | BOOTMEM_DEFAULT); | ||
| 329 | reserve_bootmem_node(NODE_DATA(0), (bootmap_start_pfn << PAGE_SHIFT), | 331 | reserve_bootmem_node(NODE_DATA(0), (bootmap_start_pfn << PAGE_SHIFT), |
| 330 | ((bootmap_pfn - bootmap_start_pfn) << PAGE_SHIFT), | 332 | ((bootmap_pfn - bootmap_start_pfn) << PAGE_SHIFT), |
| 331 | BOOTMEM_DEFAULT); | 333 | BOOTMEM_DEFAULT); |
| @@ -378,6 +380,17 @@ static void __init setup_bootmem(void) | |||
| 378 | request_resource(&sysram_resources[0], &pdcdata_resource); | 380 | request_resource(&sysram_resources[0], &pdcdata_resource); |
| 379 | } | 381 | } |
| 380 | 382 | ||
| 383 | static int __init parisc_text_address(unsigned long vaddr) | ||
| 384 | { | ||
| 385 | static unsigned long head_ptr __initdata; | ||
| 386 | |||
| 387 | if (!head_ptr) | ||
| 388 | head_ptr = PAGE_MASK & (unsigned long) | ||
| 389 | dereference_function_descriptor(&parisc_kernel_start); | ||
| 390 | |||
| 391 | return core_kernel_text(vaddr) || vaddr == head_ptr; | ||
| 392 | } | ||
| 393 | |||
| 381 | static void __init map_pages(unsigned long start_vaddr, | 394 | static void __init map_pages(unsigned long start_vaddr, |
| 382 | unsigned long start_paddr, unsigned long size, | 395 | unsigned long start_paddr, unsigned long size, |
| 383 | pgprot_t pgprot, int force) | 396 | pgprot_t pgprot, int force) |
| @@ -466,7 +479,7 @@ static void __init map_pages(unsigned long start_vaddr, | |||
| 466 | */ | 479 | */ |
| 467 | if (force) | 480 | if (force) |
| 468 | pte = __mk_pte(address, pgprot); | 481 | pte = __mk_pte(address, pgprot); |
| 469 | else if (core_kernel_text(vaddr) && | 482 | else if (parisc_text_address(vaddr) && |
| 470 | address != fv_addr) | 483 | address != fv_addr) |
| 471 | pte = __mk_pte(address, PAGE_KERNEL_EXEC); | 484 | pte = __mk_pte(address, PAGE_KERNEL_EXEC); |
| 472 | else | 485 | else |
