diff options
Diffstat (limited to 'include/asm-ia64')
| -rw-r--r-- | include/asm-ia64/compat.h | 2 | ||||
| -rw-r--r-- | include/asm-ia64/fb.h | 23 | ||||
| -rw-r--r-- | include/asm-ia64/ioctls.h | 4 | ||||
| -rw-r--r-- | include/asm-ia64/page.h | 13 | ||||
| -rw-r--r-- | include/asm-ia64/pgtable.h | 26 | ||||
| -rw-r--r-- | include/asm-ia64/termbits.h | 5 | ||||
| -rw-r--r-- | include/asm-ia64/termios.h | 6 |
7 files changed, 48 insertions, 31 deletions
diff --git a/include/asm-ia64/compat.h b/include/asm-ia64/compat.h index 40d01d80610d..0f6e5264ab8f 100644 --- a/include/asm-ia64/compat.h +++ b/include/asm-ia64/compat.h | |||
| @@ -31,8 +31,10 @@ typedef s32 compat_timer_t; | |||
| 31 | 31 | ||
| 32 | typedef s32 compat_int_t; | 32 | typedef s32 compat_int_t; |
| 33 | typedef s32 compat_long_t; | 33 | typedef s32 compat_long_t; |
| 34 | typedef s64 __attribute__((aligned(4))) compat_s64; | ||
| 34 | typedef u32 compat_uint_t; | 35 | typedef u32 compat_uint_t; |
| 35 | typedef u32 compat_ulong_t; | 36 | typedef u32 compat_ulong_t; |
| 37 | typedef u64 __attribute__((aligned(4))) compat_u64; | ||
| 36 | 38 | ||
| 37 | struct compat_timespec { | 39 | struct compat_timespec { |
| 38 | compat_time_t tv_sec; | 40 | compat_time_t tv_sec; |
diff --git a/include/asm-ia64/fb.h b/include/asm-ia64/fb.h new file mode 100644 index 000000000000..89a397cee90a --- /dev/null +++ b/include/asm-ia64/fb.h | |||
| @@ -0,0 +1,23 @@ | |||
| 1 | #ifndef _ASM_FB_H_ | ||
| 2 | #define _ASM_FB_H_ | ||
| 3 | |||
| 4 | #include <linux/fb.h> | ||
| 5 | #include <linux/fs.h> | ||
| 6 | #include <linux/efi.h> | ||
| 7 | #include <asm/page.h> | ||
| 8 | |||
| 9 | static inline void fb_pgprotect(struct file *file, struct vm_area_struct *vma, | ||
| 10 | unsigned long off) | ||
| 11 | { | ||
| 12 | if (efi_range_is_wc(vma->vm_start, vma->vm_end - vma->vm_start)) | ||
| 13 | vma->vm_page_prot = pgprot_writecombine(vma->vm_page_prot); | ||
| 14 | else | ||
| 15 | vma->vm_page_prot = pgprot_noncached(vma->vm_page_prot); | ||
| 16 | } | ||
| 17 | |||
| 18 | static inline int fb_is_primary_device(struct fb_info *info) | ||
| 19 | { | ||
| 20 | return 0; | ||
| 21 | } | ||
| 22 | |||
| 23 | #endif /* _ASM_FB_H_ */ | ||
diff --git a/include/asm-ia64/ioctls.h b/include/asm-ia64/ioctls.h index 31ee521aeb7a..f41b636a0bf6 100644 --- a/include/asm-ia64/ioctls.h +++ b/include/asm-ia64/ioctls.h | |||
| @@ -53,6 +53,10 @@ | |||
| 53 | #define TIOCSBRK 0x5427 /* BSD compatibility */ | 53 | #define TIOCSBRK 0x5427 /* BSD compatibility */ |
| 54 | #define TIOCCBRK 0x5428 /* BSD compatibility */ | 54 | #define TIOCCBRK 0x5428 /* BSD compatibility */ |
| 55 | #define TIOCGSID 0x5429 /* Return the session ID of FD */ | 55 | #define TIOCGSID 0x5429 /* Return the session ID of FD */ |
| 56 | #define TCGETS2 _IOR('T',0x2A, struct termios2) | ||
| 57 | #define TCSETS2 _IOW('T',0x2B, struct termios2) | ||
| 58 | #define TCSETSW2 _IOW('T',0x2C, struct termios2) | ||
| 59 | #define TCSETSF2 _IOW('T',0x2D, struct termios2) | ||
| 56 | #define TIOCGPTN _IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */ | 60 | #define TIOCGPTN _IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */ |
| 57 | #define TIOCSPTLCK _IOW('T',0x31, int) /* Lock/unlock Pty */ | 61 | #define TIOCSPTLCK _IOW('T',0x31, int) /* Lock/unlock Pty */ |
| 58 | 62 | ||
diff --git a/include/asm-ia64/page.h b/include/asm-ia64/page.h index 485759ba9e36..d6345464a2b3 100644 --- a/include/asm-ia64/page.h +++ b/include/asm-ia64/page.h | |||
| @@ -87,12 +87,13 @@ do { \ | |||
| 87 | } while (0) | 87 | } while (0) |
| 88 | 88 | ||
| 89 | 89 | ||
| 90 | #define alloc_zeroed_user_highpage(vma, vaddr) \ | 90 | #define __alloc_zeroed_user_highpage(movableflags, vma, vaddr) \ |
| 91 | ({ \ | 91 | ({ \ |
| 92 | struct page *page = alloc_page_vma(GFP_HIGHUSER | __GFP_ZERO, vma, vaddr); \ | 92 | struct page *page = alloc_page_vma( \ |
| 93 | if (page) \ | 93 | GFP_HIGHUSER | __GFP_ZERO | movableflags, vma, vaddr); \ |
| 94 | flush_dcache_page(page); \ | 94 | if (page) \ |
| 95 | page; \ | 95 | flush_dcache_page(page); \ |
| 96 | page; \ | ||
| 96 | }) | 97 | }) |
| 97 | 98 | ||
| 98 | #define __HAVE_ARCH_ALLOC_ZEROED_USER_HIGHPAGE | 99 | #define __HAVE_ARCH_ALLOC_ZEROED_USER_HIGHPAGE |
diff --git a/include/asm-ia64/pgtable.h b/include/asm-ia64/pgtable.h index 6580f31b3135..de6d01e24dd0 100644 --- a/include/asm-ia64/pgtable.h +++ b/include/asm-ia64/pgtable.h | |||
| @@ -297,8 +297,6 @@ ia64_phys_addr_valid (unsigned long addr) | |||
| 297 | /* | 297 | /* |
| 298 | * The following have defined behavior only work if pte_present() is true. | 298 | * The following have defined behavior only work if pte_present() is true. |
| 299 | */ | 299 | */ |
| 300 | #define pte_user(pte) ((pte_val(pte) & _PAGE_PL_MASK) == _PAGE_PL_3) | ||
| 301 | #define pte_read(pte) (((pte_val(pte) & _PAGE_AR_MASK) >> _PAGE_AR_SHIFT) < 6) | ||
| 302 | #define pte_write(pte) ((unsigned) (((pte_val(pte) & _PAGE_AR_MASK) >> _PAGE_AR_SHIFT) - 2) <= 4) | 300 | #define pte_write(pte) ((unsigned) (((pte_val(pte) & _PAGE_AR_MASK) >> _PAGE_AR_SHIFT) - 2) <= 4) |
| 303 | #define pte_exec(pte) ((pte_val(pte) & _PAGE_AR_RX) != 0) | 301 | #define pte_exec(pte) ((pte_val(pte) & _PAGE_AR_RX) != 0) |
| 304 | #define pte_dirty(pte) ((pte_val(pte) & _PAGE_D) != 0) | 302 | #define pte_dirty(pte) ((pte_val(pte) & _PAGE_D) != 0) |
| @@ -310,7 +308,6 @@ ia64_phys_addr_valid (unsigned long addr) | |||
| 310 | */ | 308 | */ |
| 311 | #define pte_wrprotect(pte) (__pte(pte_val(pte) & ~_PAGE_AR_RW)) | 309 | #define pte_wrprotect(pte) (__pte(pte_val(pte) & ~_PAGE_AR_RW)) |
| 312 | #define pte_mkwrite(pte) (__pte(pte_val(pte) | _PAGE_AR_RW)) | 310 | #define pte_mkwrite(pte) (__pte(pte_val(pte) | _PAGE_AR_RW)) |
| 313 | #define pte_mkexec(pte) (__pte(pte_val(pte) | _PAGE_AR_RX)) | ||
| 314 | #define pte_mkold(pte) (__pte(pte_val(pte) & ~_PAGE_A)) | 311 | #define pte_mkold(pte) (__pte(pte_val(pte) & ~_PAGE_A)) |
| 315 | #define pte_mkyoung(pte) (__pte(pte_val(pte) | _PAGE_A)) | 312 | #define pte_mkyoung(pte) (__pte(pte_val(pte) | _PAGE_A)) |
| 316 | #define pte_mkclean(pte) (__pte(pte_val(pte) & ~_PAGE_D)) | 313 | #define pte_mkclean(pte) (__pte(pte_val(pte) & ~_PAGE_D)) |
| @@ -398,22 +395,6 @@ ptep_test_and_clear_young (struct vm_area_struct *vma, unsigned long addr, pte_t | |||
| 398 | #endif | 395 | #endif |
| 399 | } | 396 | } |
| 400 | 397 | ||
| 401 | static inline int | ||
| 402 | ptep_test_and_clear_dirty (struct vm_area_struct *vma, unsigned long addr, pte_t *ptep) | ||
| 403 | { | ||
| 404 | #ifdef CONFIG_SMP | ||
| 405 | if (!pte_dirty(*ptep)) | ||
| 406 | return 0; | ||
| 407 | return test_and_clear_bit(_PAGE_D_BIT, ptep); | ||
| 408 | #else | ||
| 409 | pte_t pte = *ptep; | ||
| 410 | if (!pte_dirty(pte)) | ||
| 411 | return 0; | ||
| 412 | set_pte_at(vma->vm_mm, addr, ptep, pte_mkclean(pte)); | ||
| 413 | return 1; | ||
| 414 | #endif | ||
| 415 | } | ||
| 416 | |||
| 417 | static inline pte_t | 398 | static inline pte_t |
| 418 | ptep_get_and_clear(struct mm_struct *mm, unsigned long addr, pte_t *ptep) | 399 | ptep_get_and_clear(struct mm_struct *mm, unsigned long addr, pte_t *ptep) |
| 419 | { | 400 | { |
| @@ -546,8 +527,10 @@ extern void lazy_mmu_prot_update (pte_t pte); | |||
| 546 | # define ptep_set_access_flags(__vma, __addr, __ptep, __entry, __safely_writable) \ | 527 | # define ptep_set_access_flags(__vma, __addr, __ptep, __entry, __safely_writable) \ |
| 547 | ({ \ | 528 | ({ \ |
| 548 | int __changed = !pte_same(*(__ptep), __entry); \ | 529 | int __changed = !pte_same(*(__ptep), __entry); \ |
| 549 | if (__changed) \ | 530 | if (__changed) { \ |
| 550 | ptep_establish(__vma, __addr, __ptep, __entry); \ | 531 | set_pte_at((__vma)->vm_mm, (__addr), __ptep, __entry); \ |
| 532 | flush_tlb_page(__vma, __addr); \ | ||
| 533 | } \ | ||
| 551 | __changed; \ | 534 | __changed; \ |
| 552 | }) | 535 | }) |
| 553 | #endif | 536 | #endif |
| @@ -591,7 +574,6 @@ extern void lazy_mmu_prot_update (pte_t pte); | |||
| 591 | #endif | 574 | #endif |
| 592 | 575 | ||
| 593 | #define __HAVE_ARCH_PTEP_TEST_AND_CLEAR_YOUNG | 576 | #define __HAVE_ARCH_PTEP_TEST_AND_CLEAR_YOUNG |
| 594 | #define __HAVE_ARCH_PTEP_TEST_AND_CLEAR_DIRTY | ||
| 595 | #define __HAVE_ARCH_PTEP_GET_AND_CLEAR | 577 | #define __HAVE_ARCH_PTEP_GET_AND_CLEAR |
| 596 | #define __HAVE_ARCH_PTEP_SET_WRPROTECT | 578 | #define __HAVE_ARCH_PTEP_SET_WRPROTECT |
| 597 | #define __HAVE_ARCH_PTE_SAME | 579 | #define __HAVE_ARCH_PTE_SAME |
diff --git a/include/asm-ia64/termbits.h b/include/asm-ia64/termbits.h index 7fae3109ef47..9f162e0089ad 100644 --- a/include/asm-ia64/termbits.h +++ b/include/asm-ia64/termbits.h | |||
| @@ -149,6 +149,7 @@ struct ktermios { | |||
| 149 | #define HUPCL 0002000 | 149 | #define HUPCL 0002000 |
| 150 | #define CLOCAL 0004000 | 150 | #define CLOCAL 0004000 |
| 151 | #define CBAUDEX 0010000 | 151 | #define CBAUDEX 0010000 |
| 152 | #define BOTHER 0010000 | ||
| 152 | #define B57600 0010001 | 153 | #define B57600 0010001 |
| 153 | #define B115200 0010002 | 154 | #define B115200 0010002 |
| 154 | #define B230400 0010003 | 155 | #define B230400 0010003 |
| @@ -164,10 +165,12 @@ struct ktermios { | |||
| 164 | #define B3000000 0010015 | 165 | #define B3000000 0010015 |
| 165 | #define B3500000 0010016 | 166 | #define B3500000 0010016 |
| 166 | #define B4000000 0010017 | 167 | #define B4000000 0010017 |
| 167 | #define CIBAUD 002003600000 /* input baud rate (not used) */ | 168 | #define CIBAUD 002003600000 /* input baud rate */ |
| 168 | #define CMSPAR 010000000000 /* mark or space (stick) parity */ | 169 | #define CMSPAR 010000000000 /* mark or space (stick) parity */ |
| 169 | #define CRTSCTS 020000000000 /* flow control */ | 170 | #define CRTSCTS 020000000000 /* flow control */ |
| 170 | 171 | ||
| 172 | #define IBSHIFT 16 /* Shift from CBAUD to CIBAUD */ | ||
| 173 | |||
| 171 | /* c_lflag bits */ | 174 | /* c_lflag bits */ |
| 172 | #define ISIG 0000001 | 175 | #define ISIG 0000001 |
| 173 | #define ICANON 0000002 | 176 | #define ICANON 0000002 |
diff --git a/include/asm-ia64/termios.h b/include/asm-ia64/termios.h index 08750c2d3607..689d218c0c28 100644 --- a/include/asm-ia64/termios.h +++ b/include/asm-ia64/termios.h | |||
| @@ -87,8 +87,10 @@ struct termio { | |||
| 87 | copy_to_user((termio)->c_cc, (termios)->c_cc, NCC); \ | 87 | copy_to_user((termio)->c_cc, (termios)->c_cc, NCC); \ |
| 88 | }) | 88 | }) |
| 89 | 89 | ||
| 90 | #define user_termios_to_kernel_termios(k, u) copy_from_user(k, u, sizeof(struct termios)) | 90 | #define user_termios_to_kernel_termios(k, u) copy_from_user(k, u, sizeof(struct termios2)) |
| 91 | #define kernel_termios_to_user_termios(u, k) copy_to_user(u, k, sizeof(struct termios)) | 91 | #define kernel_termios_to_user_termios(u, k) copy_to_user(u, k, sizeof(struct termios2)) |
| 92 | #define user_termios_to_kernel_termios_1(k, u) copy_from_user(k, u, sizeof(struct termios)) | ||
| 93 | #define kernel_termios_to_user_termios_1(u, k) copy_to_user(u, k, sizeof(struct termios)) | ||
| 92 | 94 | ||
| 93 | # endif /* __KERNEL__ */ | 95 | # endif /* __KERNEL__ */ |
| 94 | 96 | ||
