Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
55fa11c5
Commit
55fa11c5
authored
May 02, 2002
by
David Mosberger
Committed by
David Mosberger
May 02, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ia64: Change local_irq_restore() to restore only psr.i, so that it
doesn't unexpectedly trample on the other psr bits.
parent
cde28bc5
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
44 additions
and
29 deletions
+44
-29
arch/ia64/kernel/efi.c
arch/ia64/kernel/efi.c
+7
-7
arch/ia64/mm/init.c
arch/ia64/mm/init.c
+3
-3
arch/ia64/sn/kernel/misctest.c
arch/ia64/sn/kernel/misctest.c
+3
-3
include/asm-ia64/processor.h
include/asm-ia64/processor.h
+14
-6
include/asm-ia64/system.h
include/asm-ia64/system.h
+17
-10
No files found.
arch/ia64/kernel/efi.c
View file @
55fa11c5
...
@@ -5,7 +5,7 @@
...
@@ -5,7 +5,7 @@
*
*
* Copyright (C) 1999 VA Linux Systems
* Copyright (C) 1999 VA Linux Systems
* Copyright (C) 1999 Walt Drummond <drummond@valinux.com>
* Copyright (C) 1999 Walt Drummond <drummond@valinux.com>
* Copyright (C) 1999-200
1
Hewlett-Packard Co.
* Copyright (C) 1999-200
2
Hewlett-Packard Co.
* David Mosberger-Tang <davidm@hpl.hp.com>
* David Mosberger-Tang <davidm@hpl.hp.com>
* Stephane Eranian <eranian@hpl.hp.com>
* Stephane Eranian <eranian@hpl.hp.com>
*
*
...
@@ -212,8 +212,8 @@ efi_map_pal_code (void)
...
@@ -212,8 +212,8 @@ efi_map_pal_code (void)
void
*
efi_map_start
,
*
efi_map_end
,
*
p
;
void
*
efi_map_start
,
*
efi_map_end
,
*
p
;
efi_memory_desc_t
*
md
;
efi_memory_desc_t
*
md
;
u64
efi_desc_size
;
u64
efi_desc_size
;
int
pal_code_count
=
0
;
int
pal_code_count
=
0
;
u64
mask
,
flags
;
u64
mask
,
psr
;
u64
vaddr
;
u64
vaddr
;
efi_map_start
=
__va
(
ia64_boot_param
->
efi_memmap
);
efi_map_start
=
__va
(
ia64_boot_param
->
efi_memmap
);
...
@@ -266,10 +266,10 @@ efi_map_pal_code (void)
...
@@ -266,10 +266,10 @@ efi_map_pal_code (void)
/*
/*
* Cannot write to CRx with PSR.ic=1
* Cannot write to CRx with PSR.ic=1
*/
*/
ia64_clear_ic
(
flags
);
psr
=
ia64_clear_ic
(
);
ia64_itr
(
0x1
,
IA64_TR_PALCODE
,
vaddr
&
mask
,
ia64_itr
(
0x1
,
IA64_TR_PALCODE
,
vaddr
&
mask
,
pte_val
(
mk_pte_phys
(
md
->
phys_addr
,
PAGE_KERNEL
)),
IA64_GRANULE_SHIFT
);
pte_val
(
mk_pte_phys
(
md
->
phys_addr
,
PAGE_KERNEL
)),
IA64_GRANULE_SHIFT
);
local_irq_restore
(
flags
);
ia64_set_psr
(
psr
);
ia64_srlz_i
();
ia64_srlz_i
();
}
}
}
}
...
@@ -485,7 +485,7 @@ efi_get_iobase (void)
...
@@ -485,7 +485,7 @@ efi_get_iobase (void)
}
}
u32
u32
efi_mem_type
(
u
64
phys_addr
)
efi_mem_type
(
u
nsigned
long
phys_addr
)
{
{
void
*
efi_map_start
,
*
efi_map_end
,
*
p
;
void
*
efi_map_start
,
*
efi_map_end
,
*
p
;
efi_memory_desc_t
*
md
;
efi_memory_desc_t
*
md
;
...
@@ -506,7 +506,7 @@ efi_mem_type (u64 phys_addr)
...
@@ -506,7 +506,7 @@ efi_mem_type (u64 phys_addr)
}
}
u64
u64
efi_mem_attributes
(
u
64
phys_addr
)
efi_mem_attributes
(
u
nsigned
long
phys_addr
)
{
{
void
*
efi_map_start
,
*
efi_map_end
,
*
p
;
void
*
efi_map_start
,
*
efi_map_end
,
*
p
;
efi_memory_desc_t
*
md
;
efi_memory_desc_t
*
md
;
...
...
arch/ia64/mm/init.c
View file @
55fa11c5
...
@@ -265,7 +265,7 @@ put_gate_page (struct page *page, unsigned long address)
...
@@ -265,7 +265,7 @@ put_gate_page (struct page *page, unsigned long address)
void
__init
void
__init
ia64_mmu_init
(
void
*
my_cpu_data
)
ia64_mmu_init
(
void
*
my_cpu_data
)
{
{
unsigned
long
flags
,
rid
,
pta
,
impl_va_bits
;
unsigned
long
psr
,
rid
,
pta
,
impl_va_bits
;
extern
void
__init
tlb_init
(
void
);
extern
void
__init
tlb_init
(
void
);
#ifdef CONFIG_DISABLE_VHPT
#ifdef CONFIG_DISABLE_VHPT
# define VHPT_ENABLE_BIT 0
# define VHPT_ENABLE_BIT 0
...
@@ -277,7 +277,7 @@ ia64_mmu_init (void *my_cpu_data)
...
@@ -277,7 +277,7 @@ ia64_mmu_init (void *my_cpu_data)
* Set up the kernel identity mapping for regions 6 and 5. The mapping for region
* Set up the kernel identity mapping for regions 6 and 5. The mapping for region
* 7 is setup up in _start().
* 7 is setup up in _start().
*/
*/
ia64_clear_ic
(
flags
);
psr
=
ia64_clear_ic
(
);
rid
=
ia64_rid
(
IA64_REGION_ID_KERNEL
,
__IA64_UNCACHED_OFFSET
);
rid
=
ia64_rid
(
IA64_REGION_ID_KERNEL
,
__IA64_UNCACHED_OFFSET
);
ia64_set_rr
(
__IA64_UNCACHED_OFFSET
,
(
rid
<<
8
)
|
(
IA64_GRANULE_SHIFT
<<
2
));
ia64_set_rr
(
__IA64_UNCACHED_OFFSET
,
(
rid
<<
8
)
|
(
IA64_GRANULE_SHIFT
<<
2
));
...
@@ -291,7 +291,7 @@ ia64_mmu_init (void *my_cpu_data)
...
@@ -291,7 +291,7 @@ ia64_mmu_init (void *my_cpu_data)
ia64_itr
(
0x2
,
IA64_TR_PERCPU_DATA
,
PERCPU_ADDR
,
ia64_itr
(
0x2
,
IA64_TR_PERCPU_DATA
,
PERCPU_ADDR
,
pte_val
(
mk_pte_phys
(
__pa
(
my_cpu_data
),
PAGE_KERNEL
)),
PAGE_SHIFT
);
pte_val
(
mk_pte_phys
(
__pa
(
my_cpu_data
),
PAGE_KERNEL
)),
PAGE_SHIFT
);
__restore_flags
(
flags
);
ia64_set_psr
(
psr
);
ia64_srlz_i
();
ia64_srlz_i
();
/*
/*
...
...
arch/ia64/sn/kernel/misctest.c
View file @
55fa11c5
...
@@ -75,7 +75,7 @@ sgi_mcatest(void)
...
@@ -75,7 +75,7 @@ sgi_mcatest(void)
if
(
mcatest
==
5
)
{
if
(
mcatest
==
5
)
{
int
zzzspec
(
long
);
int
zzzspec
(
long
);
int
i
;
int
i
;
long
flags
,
dcr
,
res
,
val
,
addr
=
0xff00000000UL
;
long
psr
,
dcr
,
res
,
val
,
addr
=
0xff00000000UL
;
dcr
=
ia64_get_dcr
();
dcr
=
ia64_get_dcr
();
for
(
i
=
0
;
i
<
5
;
i
++
)
{
for
(
i
=
0
;
i
<
5
;
i
++
)
{
...
@@ -87,11 +87,11 @@ sgi_mcatest(void)
...
@@ -87,11 +87,11 @@ sgi_mcatest(void)
ia64_set_dcr
(
dcr
);
ia64_set_dcr
(
dcr
);
res
=
ia64_sn_probe_io_slot
(
0xff00000000UL
,
8
,
&
val
);
res
=
ia64_sn_probe_io_slot
(
0xff00000000UL
,
8
,
&
val
);
printk
(
"zzzspec: probe %ld, 0x%lx
\n
"
,
res
,
val
);
printk
(
"zzzspec: probe %ld, 0x%lx
\n
"
,
res
,
val
);
ia64_clear_ic
(
flags
);
psr
=
ia64_clear_ic
(
);
ia64_itc
(
0x2
,
0xe00000ff00000000UL
,
ia64_itc
(
0x2
,
0xe00000ff00000000UL
,
pte_val
(
mk_pte_phys
(
0xff00000000UL
,
pte_val
(
mk_pte_phys
(
0xff00000000UL
,
__pgprot
(
__DIRTY_BITS
|
_PAGE_PL_0
|
_PAGE_AR_RW
))),
_PAGE_SIZE_256M
);
__pgprot
(
__DIRTY_BITS
|
_PAGE_PL_0
|
_PAGE_AR_RW
))),
_PAGE_SIZE_256M
);
local_irq_restore
(
flags
);
ia64_set_psr
(
psr
);
ia64_srlz_i
();
ia64_srlz_i
();
}
}
...
...
include/asm-ia64/processor.h
View file @
55fa11c5
...
@@ -632,14 +632,22 @@ ia64_invala (void)
...
@@ -632,14 +632,22 @@ ia64_invala (void)
asm
volatile
(
"invala"
:::
"memory"
);
asm
volatile
(
"invala"
:::
"memory"
);
}
}
static
inline
__u64
ia64_clear_ic
(
void
)
{
__u64
psr
;
asm
volatile
(
"mov %0=psr;; rsm psr.i | psr.ic;; srlz.i;;"
:
"=r"
(
psr
)
::
"memory"
);
return
psr
;
}
/*
/*
* Save the processor status flags in FLAGS and then clear the interrupt collection and
* Restore the psr.
* interrupt enable bits. Don't trigger any mandatory RSE references while this bit is
* off!
*/
*/
#define ia64_clear_ic(flags) \
static
inline
void
asm volatile ("mov %0=psr;; rsm psr.i | psr.ic;; srlz.i;;" \
ia64_set_psr
(
__u64
psr
)
: "=r"(flags) :: "memory");
{
asm
volatile
(
";; mov psr.l=%0;; srlz.d"
::
"r"
(
psr
)
:
"memory"
);
}
/*
/*
* Insert a translation into an instruction and/or data translation
* Insert a translation into an instruction and/or data translation
...
...
include/asm-ia64/system.h
View file @
55fa11c5
...
@@ -139,9 +139,13 @@ do { \
...
@@ -139,9 +139,13 @@ do { \
do { \
do { \
unsigned long ip, old_psr, psr = (x); \
unsigned long ip, old_psr, psr = (x); \
\
\
__asm__ __volatile__ (";;mov %0=psr; mov psr.l=%1;; srlz.d" \
__asm__ __volatile__ ("mov %0=psr;" \
: "=&r" (old_psr) : "r" (psr) : "memory"); \
"cmp.ne p6,p7=%1,r0;;" \
if ((old_psr & (1UL << 14)) && !(psr & (1UL << 14))) { \
"(p6) ssm psr.i;" \
"(p7) rsm psr.i;;" \
"srlz.d" \
: "=&r" (old_psr) : "r"((psr) & IA64_PSR_I) : "memory"); \
if ((old_psr & IA64_PSR_I) && !(psr & IA64_PSR_I)) { \
__asm__ ("mov %0=ip" : "=r"(ip)); \
__asm__ ("mov %0=ip" : "=r"(ip)); \
last_cli_ip = ip; \
last_cli_ip = ip; \
} \
} \
...
@@ -153,8 +157,11 @@ do { \
...
@@ -153,8 +157,11 @@ do { \
: "=r" (x) :: "memory")
: "=r" (x) :: "memory")
# define local_irq_disable() __asm__ __volatile__ (";; rsm psr.i;;" ::: "memory")
# define local_irq_disable() __asm__ __volatile__ (";; rsm psr.i;;" ::: "memory")
/* (potentially) setting psr.i requires data serialization: */
/* (potentially) setting psr.i requires data serialization: */
# define local_irq_restore(x) __asm__ __volatile__ (";; mov psr.l=%0;; srlz.d" \
# define local_irq_restore(x) __asm__ __volatile__ ("cmp.ne p6,p7=%0,r0;;" \
:: "r" (x) : "memory")
"(p6) ssm psr.i;" \
"(p7) rsm psr.i;;" \
"srlz.d" \
:: "r"((x) & IA64_PSR_I) : "memory")
#endif
/* !CONFIG_IA64_DEBUG_IRQ */
#endif
/* !CONFIG_IA64_DEBUG_IRQ */
#define local_irq_enable() __asm__ __volatile__ (";; ssm psr.i;; srlz.d" ::: "memory")
#define local_irq_enable() __asm__ __volatile__ (";; ssm psr.i;; srlz.d" ::: "memory")
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment