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
40122150
Commit
40122150
authored
Nov 11, 2005
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'release' of
git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux-2.6
parents
63f45b80
ff51224c
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
303 additions
and
37 deletions
+303
-37
arch/ia64/Kconfig
arch/ia64/Kconfig
+13
-0
arch/ia64/configs/sn2_defconfig
arch/ia64/configs/sn2_defconfig
+2
-0
arch/ia64/defconfig
arch/ia64/defconfig
+2
-0
arch/ia64/kernel/ivt.S
arch/ia64/kernel/ivt.S
+48
-15
arch/ia64/sn/kernel/setup.c
arch/ia64/sn/kernel/setup.c
+153
-4
include/asm-ia64/page.h
include/asm-ia64/page.h
+6
-2
include/asm-ia64/pgalloc.h
include/asm-ia64/pgalloc.h
+19
-0
include/asm-ia64/pgtable.h
include/asm-ia64/pgtable.h
+60
-16
No files found.
arch/ia64/Kconfig
View file @
40122150
...
@@ -164,6 +164,19 @@ config IA64_PAGE_SIZE_64KB
...
@@ -164,6 +164,19 @@ config IA64_PAGE_SIZE_64KB
endchoice
endchoice
choice
prompt "Page Table Levels"
default PGTABLE_3
config PGTABLE_3
bool "3 Levels"
config PGTABLE_4
depends on !IA64_PAGE_SIZE_64KB
bool "4 Levels"
endchoice
source kernel/Kconfig.hz
source kernel/Kconfig.hz
config IA64_BRL_EMU
config IA64_BRL_EMU
...
...
arch/ia64/configs/sn2_defconfig
View file @
40122150
...
@@ -80,6 +80,8 @@ CONFIG_MCKINLEY=y
...
@@ -80,6 +80,8 @@ CONFIG_MCKINLEY=y
# CONFIG_IA64_PAGE_SIZE_8KB is not set
# CONFIG_IA64_PAGE_SIZE_8KB is not set
CONFIG_IA64_PAGE_SIZE_16KB=y
CONFIG_IA64_PAGE_SIZE_16KB=y
# CONFIG_IA64_PAGE_SIZE_64KB is not set
# CONFIG_IA64_PAGE_SIZE_64KB is not set
# CONFIG_PGTABLE_3 is not set
CONFIG_PGTABLE_4=y
# CONFIG_HZ_100 is not set
# CONFIG_HZ_100 is not set
CONFIG_HZ_250=y
CONFIG_HZ_250=y
# CONFIG_HZ_1000 is not set
# CONFIG_HZ_1000 is not set
...
...
arch/ia64/defconfig
View file @
40122150
...
@@ -82,6 +82,8 @@ CONFIG_MCKINLEY=y
...
@@ -82,6 +82,8 @@ CONFIG_MCKINLEY=y
# CONFIG_IA64_PAGE_SIZE_8KB is not set
# CONFIG_IA64_PAGE_SIZE_8KB is not set
CONFIG_IA64_PAGE_SIZE_16KB=y
CONFIG_IA64_PAGE_SIZE_16KB=y
# CONFIG_IA64_PAGE_SIZE_64KB is not set
# CONFIG_IA64_PAGE_SIZE_64KB is not set
CONFIG_PGTABLE_3=y
# CONFIG_PGTABLE_4 is not set
# CONFIG_HZ_100 is not set
# CONFIG_HZ_100 is not set
CONFIG_HZ_250=y
CONFIG_HZ_250=y
# CONFIG_HZ_1000 is not set
# CONFIG_HZ_1000 is not set
...
...
arch/ia64/kernel/ivt.S
View file @
40122150
...
@@ -114,7 +114,7 @@ ENTRY(vhpt_miss)
...
@@ -114,7 +114,7 @@ ENTRY(vhpt_miss)
shl
r21
=
r16
,
3
//
shift
bit
60
into
sign
bit
shl
r21
=
r16
,
3
//
shift
bit
60
into
sign
bit
shr.u
r17
=
r16
,
61
//
get
the
region
number
into
r17
shr.u
r17
=
r16
,
61
//
get
the
region
number
into
r17
;;
;;
shr
r22
=
r21
,
3
shr
.u
r22
=
r21
,
3
#ifdef CONFIG_HUGETLB_PAGE
#ifdef CONFIG_HUGETLB_PAGE
extr.u
r26
=
r25
,
2
,
6
extr.u
r26
=
r25
,
2
,
6
;;
;;
...
@@ -140,20 +140,34 @@ ENTRY(vhpt_miss)
...
@@ -140,20 +140,34 @@ ENTRY(vhpt_miss)
(
p6
)
dep
r17
=
r18
,
r19
,
3
,(
PAGE_SHIFT
-
3
)
//
r17
=
PTA
+
IFA
(
33
,
42
)*
8
(
p6
)
dep
r17
=
r18
,
r19
,
3
,(
PAGE_SHIFT
-
3
)
//
r17
=
PTA
+
IFA
(
33
,
42
)*
8
(
p7
)
dep
r17
=
r18
,
r17
,
3
,(
PAGE_SHIFT
-
6
)
//
r17
=
PTA
+
(((
IFA
(
61
,
63
)
<<
7
)
|
IFA
(
33
,
39
))*
8
)
(
p7
)
dep
r17
=
r18
,
r17
,
3
,(
PAGE_SHIFT
-
6
)
//
r17
=
PTA
+
(((
IFA
(
61
,
63
)
<<
7
)
|
IFA
(
33
,
39
))*
8
)
cmp.eq
p7
,
p6
=
0
,
r21
//
unused
address
bits
all
zeroes
?
cmp.eq
p7
,
p6
=
0
,
r21
//
unused
address
bits
all
zeroes
?
shr.u
r18
=
r22
,
PMD_SHIFT
//
shift
L2
index
into
position
#ifdef CONFIG_PGTABLE_4
shr.u
r28
=
r22
,
PUD_SHIFT
//
shift
L2
index
into
position
#else
shr.u
r18
=
r22
,
PMD_SHIFT
//
shift
L3
index
into
position
#endif
;;
;;
ld8
r17
=[
r17
]
//
fetch
the
L1
entry
(
may
be
0
)
ld8
r17
=[
r17
]
//
fetch
the
L1
entry
(
may
be
0
)
;;
;;
(
p7
)
cmp.eq
p6
,
p7
=
r17
,
r0
//
was
L1
entry
NULL
?
(
p7
)
cmp.eq
p6
,
p7
=
r17
,
r0
//
was
L1
entry
NULL
?
dep
r17
=
r18
,
r17
,
3
,(
PAGE_SHIFT
-
3
)
//
compute
address
of
L2
page
table
entry
#ifdef CONFIG_PGTABLE_4
dep
r28
=
r28
,
r17
,
3
,(
PAGE_SHIFT
-
3
)
//
compute
address
of
L2
page
table
entry
;;
shr.u
r18
=
r22
,
PMD_SHIFT
//
shift
L3
index
into
position
(
p7
)
ld8
r29
=[
r28
]
//
fetch
the
L2
entry
(
may
be
0
)
;;
;;
(
p7
)
ld8
r20
=[
r17
]
//
fetch
the
L2
entry
(
may
be
0
)
(
p7
)
cmp.eq.or.andcm
p6
,
p7
=
r29
,
r0
//
was
L2
entry
NULL
?
shr.u
r19
=
r22
,
PAGE_SHIFT
//
shift
L3
index
into
position
dep
r17
=
r18
,
r29
,
3
,(
PAGE_SHIFT
-
3
)
//
compute
address
of
L3
page
table
entry
#else
dep
r17
=
r18
,
r17
,
3
,(
PAGE_SHIFT
-
3
)
//
compute
address
of
L3
page
table
entry
#endif
;;
;;
(
p7
)
cmp.eq.or.andcm
p6
,
p7
=
r20
,
r0
//
was
L2
entry
NULL
?
(
p7
)
ld8
r20
=[
r17
]
//
fetch
the
L3
entry
(
may
be
0
)
dep
r21
=
r19
,
r20
,
3
,(
PAGE_SHIFT
-
3
)
//
compute
address
of
L3
page
table
entry
shr.u
r19
=
r22
,
PAGE_SHIFT
//
shift
L4
index
into
position
;;
;;
(
p7
)
ld8
r18
=[
r21
]
//
read
the
L3
PTE
(
p7
)
cmp.eq.or.andcm
p6
,
p7
=
r20
,
r0
//
was
L3
entry
NULL
?
dep
r21
=
r19
,
r20
,
3
,(
PAGE_SHIFT
-
3
)
//
compute
address
of
L4
page
table
entry
;;
(
p7
)
ld8
r18
=[
r21
]
//
read
the
L4
PTE
mov
r19
=
cr
.
isr
//
cr
.
isr
bit
0
tells
us
if
this
is
an
insn
miss
mov
r19
=
cr
.
isr
//
cr
.
isr
bit
0
tells
us
if
this
is
an
insn
miss
;;
;;
(
p7
)
tbit.z
p6
,
p7
=
r18
,
_PAGE_P_BIT
//
page
present
bit
cleared
?
(
p7
)
tbit.z
p6
,
p7
=
r18
,
_PAGE_P_BIT
//
page
present
bit
cleared
?
...
@@ -192,14 +206,21 @@ ENTRY(vhpt_miss)
...
@@ -192,14 +206,21 @@ ENTRY(vhpt_miss)
*
between
reading
the
pagetable
and
the
"itc"
.
If
so
,
flush
the
entry
we
*
between
reading
the
pagetable
and
the
"itc"
.
If
so
,
flush
the
entry
we
*
inserted
and
retry
.
*
inserted
and
retry
.
*/
*/
ld8
r25
=[
r21
]
//
read
L3
PTE
again
ld8
r25
=[
r21
]
//
read
L4
entry
again
ld8
r26
=[
r17
]
//
read
L2
entry
again
ld8
r26
=[
r17
]
//
read
L3
PTE
again
#ifdef CONFIG_PGTABLE_4
ld8
r18
=[
r28
]
//
read
L2
entry
again
#endif
cmp.ne
p6
,
p7
=
r0
,
r0
;;
;;
cmp.ne
p6
,
p7
=
r26
,
r20
//
did
L2
entry
change
cmp.ne.or.andcm
p6
,
p7
=
r26
,
r20
//
did
L3
entry
change
#ifdef CONFIG_PGTABLE_4
cmp.ne.or.andcm
p6
,
p7
=
r29
,
r18
//
did
L4
PTE
change
#endif
mov
r27
=
PAGE_SHIFT
<<
2
mov
r27
=
PAGE_SHIFT
<<
2
;;
;;
(
p6
)
ptc.l
r22
,
r27
//
purge
PTE
page
translation
(
p6
)
ptc.l
r22
,
r27
//
purge
PTE
page
translation
(
p7
)
cmp.ne.or.andcm
p6
,
p7
=
r25
,
r18
//
did
L
3
PTE
change
(
p7
)
cmp.ne.or.andcm
p6
,
p7
=
r25
,
r18
//
did
L
4
PTE
change
;;
;;
(
p6
)
ptc.l
r16
,
r27
//
purge
translation
(
p6
)
ptc.l
r16
,
r27
//
purge
translation
#endif
#endif
...
@@ -432,18 +453,30 @@ ENTRY(nested_dtlb_miss)
...
@@ -432,18 +453,30 @@ ENTRY(nested_dtlb_miss)
(
p6
)
dep
r17
=
r18
,
r19
,
3
,(
PAGE_SHIFT
-
3
)
//
r17
=
PTA
+
IFA
(
33
,
42
)*
8
(
p6
)
dep
r17
=
r18
,
r19
,
3
,(
PAGE_SHIFT
-
3
)
//
r17
=
PTA
+
IFA
(
33
,
42
)*
8
(
p7
)
dep
r17
=
r18
,
r17
,
3
,(
PAGE_SHIFT
-
6
)
//
r17
=
PTA
+
(((
IFA
(
61
,
63
)
<<
7
)
|
IFA
(
33
,
39
))*
8
)
(
p7
)
dep
r17
=
r18
,
r17
,
3
,(
PAGE_SHIFT
-
6
)
//
r17
=
PTA
+
(((
IFA
(
61
,
63
)
<<
7
)
|
IFA
(
33
,
39
))*
8
)
cmp.eq
p7
,
p6
=
0
,
r21
//
unused
address
bits
all
zeroes
?
cmp.eq
p7
,
p6
=
0
,
r21
//
unused
address
bits
all
zeroes
?
shr.u
r18
=
r22
,
PMD_SHIFT
//
shift
L2
index
into
position
#ifdef CONFIG_PGTABLE_4
shr.u
r18
=
r22
,
PUD_SHIFT
//
shift
L2
index
into
position
#else
shr.u
r18
=
r22
,
PMD_SHIFT
//
shift
L3
index
into
position
#endif
;;
;;
ld8
r17
=[
r17
]
//
fetch
the
L1
entry
(
may
be
0
)
ld8
r17
=[
r17
]
//
fetch
the
L1
entry
(
may
be
0
)
;;
;;
(
p7
)
cmp.eq
p6
,
p7
=
r17
,
r0
//
was
L1
entry
NULL
?
(
p7
)
cmp.eq
p6
,
p7
=
r17
,
r0
//
was
L1
entry
NULL
?
dep
r17
=
r18
,
r17
,
3
,(
PAGE_SHIFT
-
3
)
//
compute
address
of
L2
page
table
entry
dep
r17
=
r18
,
r17
,
3
,(
PAGE_SHIFT
-
3
)
//
compute
address
of
L2
page
table
entry
;;
;;
#ifdef CONFIG_PGTABLE_4
(
p7
)
ld8
r17
=[
r17
]
//
fetch
the
L2
entry
(
may
be
0
)
(
p7
)
ld8
r17
=[
r17
]
//
fetch
the
L2
entry
(
may
be
0
)
shr.u
r1
9
=
r22
,
PAGE_SHIFT
//
shift
L3
index
into
position
shr.u
r1
8
=
r22
,
PMD_SHIFT
//
shift
L3
index
into
position
;;
;;
(
p7
)
cmp.eq.or.andcm
p6
,
p7
=
r17
,
r0
//
was
L2
entry
NULL
?
(
p7
)
cmp.eq.or.andcm
p6
,
p7
=
r17
,
r0
//
was
L2
entry
NULL
?
dep
r17
=
r19
,
r17
,
3
,(
PAGE_SHIFT
-
3
)
//
compute
address
of
L3
page
table
entry
dep
r17
=
r18
,
r17
,
3
,(
PAGE_SHIFT
-
3
)
//
compute
address
of
L2
page
table
entry
;;
#endif
(
p7
)
ld8
r17
=[
r17
]
//
fetch
the
L3
entry
(
may
be
0
)
shr.u
r19
=
r22
,
PAGE_SHIFT
//
shift
L4
index
into
position
;;
(
p7
)
cmp.eq.or.andcm
p6
,
p7
=
r17
,
r0
//
was
L3
entry
NULL
?
dep
r17
=
r19
,
r17
,
3
,(
PAGE_SHIFT
-
3
)
//
compute
address
of
L4
page
table
entry
(
p6
)
br.cond.spnt
page_fault
(
p6
)
br.cond.spnt
page_fault
mov
b0
=
r30
mov
b0
=
r30
br.sptk.many
b0
//
return
to
continuation
point
br.sptk.many
b0
//
return
to
continuation
point
...
...
arch/ia64/sn/kernel/setup.c
View file @
40122150
...
@@ -30,6 +30,7 @@
...
@@ -30,6 +30,7 @@
#include <linux/root_dev.h>
#include <linux/root_dev.h>
#include <linux/nodemask.h>
#include <linux/nodemask.h>
#include <linux/pm.h>
#include <linux/pm.h>
#include <linux/efi.h>
#include <asm/io.h>
#include <asm/io.h>
#include <asm/sal.h>
#include <asm/sal.h>
...
@@ -242,6 +243,135 @@ static void __init sn_check_for_wars(void)
...
@@ -242,6 +243,135 @@ static void __init sn_check_for_wars(void)
}
}
}
}
/*
* Scan the EFI PCDP table (if it exists) for an acceptable VGA console
* output device. If one exists, pick it and set sn_legacy_{io,mem} to
* reflect the bus offsets needed to address it.
*
* Since pcdp support in SN is not supported in the 2.4 kernel (or at least
* the one lbs is based on) just declare the needed structs here.
*
* Reference spec http://www.dig64.org/specifications/DIG64_PCDPv20.pdf
*
* Returns 0 if no acceptable vga is found, !0 otherwise.
*
* Note: This stuff is duped here because Altix requires the PCDP to
* locate a usable VGA device due to lack of proper ACPI support. Structures
* could be used from drivers/firmware/pcdp.h, but it was decided that moving
* this file to a more public location just for Altix use was undesireable.
*/
struct
hcdp_uart_desc
{
u8
pad
[
45
];
};
struct
pcdp
{
u8
signature
[
4
];
/* should be 'HCDP' */
u32
length
;
u8
rev
;
/* should be >=3 for pcdp, <3 for hcdp */
u8
sum
;
u8
oem_id
[
6
];
u64
oem_tableid
;
u32
oem_rev
;
u32
creator_id
;
u32
creator_rev
;
u32
num_type0
;
struct
hcdp_uart_desc
uart
[
0
];
/* num_type0 of these */
/* pcdp descriptors follow */
}
__attribute__
((
packed
));
struct
pcdp_device_desc
{
u8
type
;
u8
primary
;
u16
length
;
u16
index
;
/* interconnect specific structure follows */
/* device specific structure follows that */
}
__attribute__
((
packed
));
struct
pcdp_interface_pci
{
u8
type
;
/* 1 == pci */
u8
reserved
;
u16
length
;
u8
segment
;
u8
bus
;
u8
dev
;
u8
fun
;
u16
devid
;
u16
vendid
;
u32
acpi_interrupt
;
u64
mmio_tra
;
u64
ioport_tra
;
u8
flags
;
u8
translation
;
}
__attribute__
((
packed
));
struct
pcdp_vga_device
{
u8
num_eas_desc
;
/* ACPI Extended Address Space Desc follows */
}
__attribute__
((
packed
));
/* from pcdp_device_desc.primary */
#define PCDP_PRIMARY_CONSOLE 0x01
/* from pcdp_device_desc.type */
#define PCDP_CONSOLE_INOUT 0x0
#define PCDP_CONSOLE_DEBUG 0x1
#define PCDP_CONSOLE_OUT 0x2
#define PCDP_CONSOLE_IN 0x3
#define PCDP_CONSOLE_TYPE_VGA 0x8
#define PCDP_CONSOLE_VGA (PCDP_CONSOLE_TYPE_VGA | PCDP_CONSOLE_OUT)
/* from pcdp_interface_pci.type */
#define PCDP_IF_PCI 1
/* from pcdp_interface_pci.translation */
#define PCDP_PCI_TRANS_IOPORT 0x02
#define PCDP_PCI_TRANS_MMIO 0x01
static
void
sn_scan_pcdp
(
void
)
{
u8
*
bp
;
struct
pcdp
*
pcdp
;
struct
pcdp_device_desc
device
;
struct
pcdp_interface_pci
if_pci
;
extern
struct
efi
efi
;
pcdp
=
efi
.
hcdp
;
if
(
!
pcdp
)
return
;
/* no hcdp/pcdp table */
if
(
pcdp
->
rev
<
3
)
return
;
/* only support PCDP (rev >= 3) */
for
(
bp
=
(
u8
*
)
&
pcdp
->
uart
[
pcdp
->
num_type0
];
bp
<
(
u8
*
)
pcdp
+
pcdp
->
length
;
bp
+=
device
.
length
)
{
memcpy
(
&
device
,
bp
,
sizeof
(
device
));
if
(
!
(
device
.
primary
&
PCDP_PRIMARY_CONSOLE
))
continue
;
/* not primary console */
if
(
device
.
type
!=
PCDP_CONSOLE_VGA
)
continue
;
/* not VGA descriptor */
memcpy
(
&
if_pci
,
bp
+
sizeof
(
device
),
sizeof
(
if_pci
));
if
(
if_pci
.
type
!=
PCDP_IF_PCI
)
continue
;
/* not PCI interconnect */
if
(
if_pci
.
translation
&
PCDP_PCI_TRANS_IOPORT
)
vga_console_iobase
=
if_pci
.
ioport_tra
|
__IA64_UNCACHED_OFFSET
;
if
(
if_pci
.
translation
&
PCDP_PCI_TRANS_MMIO
)
vga_console_membase
=
if_pci
.
mmio_tra
|
__IA64_UNCACHED_OFFSET
;
break
;
/* once we find the primary, we're done */
}
}
/**
/**
* sn_setup - SN platform setup routine
* sn_setup - SN platform setup routine
* @cmdline_p: kernel command line
* @cmdline_p: kernel command line
...
@@ -263,16 +393,35 @@ void __init sn_setup(char **cmdline_p)
...
@@ -263,16 +393,35 @@ void __init sn_setup(char **cmdline_p)
#if defined(CONFIG_VT) && defined(CONFIG_VGA_CONSOLE)
#if defined(CONFIG_VT) && defined(CONFIG_VGA_CONSOLE)
/*
/*
* If there was a primary vga adapter identified through the
* Handle SN vga console.
* EFI PCDP table, make it the preferred console. Otherwise
*
* zero out conswitchp.
* SN systems do not have enough ACPI table information
* being passed from prom to identify VGA adapters and the legacy
* addresses to access them. Until that is done, SN systems rely
* on the PCDP table to identify the primary VGA console if one
* exists.
*
* However, kernel PCDP support is optional, and even if it is built
* into the kernel, it will not be used if the boot cmdline contains
* console= directives.
*
* So, to work around this mess, we duplicate some of the PCDP code
* here so that the primary VGA console (as defined by PCDP) will
* work on SN systems even if a different console (e.g. serial) is
* selected on the boot line (or CONFIG_EFI_PCDP is off).
*/
*/
if
(
!
vga_console_membase
)
sn_scan_pcdp
();
if
(
vga_console_membase
)
{
if
(
vga_console_membase
)
{
/* usable vga ... make tty0 the preferred default console */
/* usable vga ... make tty0 the preferred default console */
if
(
!
strstr
(
*
cmdline_p
,
"console="
))
add_preferred_console
(
"tty"
,
0
,
NULL
);
add_preferred_console
(
"tty"
,
0
,
NULL
);
}
else
{
}
else
{
printk
(
KERN_DEBUG
"SGI: Disabling VGA console
\n
"
);
printk
(
KERN_DEBUG
"SGI: Disabling VGA console
\n
"
);
if
(
!
strstr
(
*
cmdline_p
,
"console="
))
add_preferred_console
(
"ttySG"
,
0
,
NULL
);
#ifdef CONFIG_DUMMY_CONSOLE
#ifdef CONFIG_DUMMY_CONSOLE
conswitchp
=
&
dummy_con
;
conswitchp
=
&
dummy_con
;
#else
#else
...
...
include/asm-ia64/page.h
View file @
40122150
...
@@ -47,8 +47,6 @@
...
@@ -47,8 +47,6 @@
#define PERCPU_PAGE_SHIFT 16
/* log2() of max. size of per-CPU area */
#define PERCPU_PAGE_SHIFT 16
/* log2() of max. size of per-CPU area */
#define PERCPU_PAGE_SIZE (__IA64_UL_CONST(1) << PERCPU_PAGE_SHIFT)
#define PERCPU_PAGE_SIZE (__IA64_UL_CONST(1) << PERCPU_PAGE_SHIFT)
#define RGN_MAP_LIMIT ((1UL << (4*PAGE_SHIFT - 12)) - PAGE_SIZE)
/* per region addr limit */
#ifdef CONFIG_HUGETLB_PAGE
#ifdef CONFIG_HUGETLB_PAGE
# define HPAGE_REGION_BASE RGN_BASE(RGN_HPAGE)
# define HPAGE_REGION_BASE RGN_BASE(RGN_HPAGE)
...
@@ -175,11 +173,17 @@ get_order (unsigned long size)
...
@@ -175,11 +173,17 @@ get_order (unsigned long size)
*/
*/
typedef
struct
{
unsigned
long
pte
;
}
pte_t
;
typedef
struct
{
unsigned
long
pte
;
}
pte_t
;
typedef
struct
{
unsigned
long
pmd
;
}
pmd_t
;
typedef
struct
{
unsigned
long
pmd
;
}
pmd_t
;
#ifdef CONFIG_PGTABLE_4
typedef
struct
{
unsigned
long
pud
;
}
pud_t
;
#endif
typedef
struct
{
unsigned
long
pgd
;
}
pgd_t
;
typedef
struct
{
unsigned
long
pgd
;
}
pgd_t
;
typedef
struct
{
unsigned
long
pgprot
;
}
pgprot_t
;
typedef
struct
{
unsigned
long
pgprot
;
}
pgprot_t
;
# define pte_val(x) ((x).pte)
# define pte_val(x) ((x).pte)
# define pmd_val(x) ((x).pmd)
# define pmd_val(x) ((x).pmd)
#ifdef CONFIG_PGTABLE_4
# define pud_val(x) ((x).pud)
#endif
# define pgd_val(x) ((x).pgd)
# define pgd_val(x) ((x).pgd)
# define pgprot_val(x) ((x).pgprot)
# define pgprot_val(x) ((x).pgprot)
...
...
include/asm-ia64/pgalloc.h
View file @
40122150
...
@@ -86,6 +86,25 @@ static inline void pgd_free(pgd_t * pgd)
...
@@ -86,6 +86,25 @@ static inline void pgd_free(pgd_t * pgd)
pgtable_quicklist_free
(
pgd
);
pgtable_quicklist_free
(
pgd
);
}
}
#ifdef CONFIG_PGTABLE_4
static
inline
void
pgd_populate
(
struct
mm_struct
*
mm
,
pgd_t
*
pgd_entry
,
pud_t
*
pud
)
{
pgd_val
(
*
pgd_entry
)
=
__pa
(
pud
);
}
static
inline
pud_t
*
pud_alloc_one
(
struct
mm_struct
*
mm
,
unsigned
long
addr
)
{
return
pgtable_quicklist_alloc
();
}
static
inline
void
pud_free
(
pud_t
*
pud
)
{
pgtable_quicklist_free
(
pud
);
}
#define __pud_free_tlb(tlb, pud) pud_free(pud)
#endif
/* CONFIG_PGTABLE_4 */
static
inline
void
static
inline
void
pud_populate
(
struct
mm_struct
*
mm
,
pud_t
*
pud_entry
,
pmd_t
*
pmd
)
pud_populate
(
struct
mm_struct
*
mm
,
pud_t
*
pud_entry
,
pmd_t
*
pmd
)
{
{
...
...
include/asm-ia64/pgtable.h
View file @
40122150
...
@@ -84,32 +84,55 @@
...
@@ -84,32 +84,55 @@
#define __DIRTY_BITS _PAGE_ED | __DIRTY_BITS_NO_ED
#define __DIRTY_BITS _PAGE_ED | __DIRTY_BITS_NO_ED
/*
/*
* Definitions for first level:
* How many pointers will a page table level hold expressed in shift
*
* PGDIR_SHIFT determines what a first-level page table entry can map.
*/
*/
#define PGDIR_SHIFT (PAGE_SHIFT + 2*(PAGE_SHIFT-3))
#define PTRS_PER_PTD_SHIFT (PAGE_SHIFT-3)
#define PGDIR_SIZE (__IA64_UL(1) << PGDIR_SHIFT)
#define PGDIR_MASK (~(PGDIR_SIZE-1))
#define PTRS_PER_PGD (1UL << (PAGE_SHIFT-3))
#define USER_PTRS_PER_PGD (5*PTRS_PER_PGD/8)
/* regions 0-4 are user regions */
#define FIRST_USER_ADDRESS 0
/*
/*
* Definitions for second level:
* Definitions for fourth level:
*/
#define PTRS_PER_PTE (__IA64_UL(1) << (PTRS_PER_PTD_SHIFT))
/*
* Definitions for third level:
*
*
* PMD_SHIFT determines the size of the area a
secon
d-level page table
* PMD_SHIFT determines the size of the area a
thir
d-level page table
* can map.
* can map.
*/
*/
#define PMD_SHIFT (PAGE_SHIFT + (P
AGE_SHIFT-3
))
#define PMD_SHIFT (PAGE_SHIFT + (P
TRS_PER_PTD_SHIFT
))
#define PMD_SIZE (1UL << PMD_SHIFT)
#define PMD_SIZE (1UL << PMD_SHIFT)
#define PMD_MASK (~(PMD_SIZE-1))
#define PMD_MASK (~(PMD_SIZE-1))
#define PTRS_PER_PMD (1UL << (P
AGE_SHIFT-3
))
#define PTRS_PER_PMD (1UL << (P
TRS_PER_PTD_SHIFT
))
#ifdef CONFIG_PGTABLE_4
/*
/*
* Definitions for third level:
* Definitions for second level:
*
* PUD_SHIFT determines the size of the area a second-level page table
* can map.
*/
*/
#define PTRS_PER_PTE (__IA64_UL(1) << (PAGE_SHIFT-3))
#define PUD_SHIFT (PMD_SHIFT + (PTRS_PER_PTD_SHIFT))
#define PUD_SIZE (1UL << PUD_SHIFT)
#define PUD_MASK (~(PUD_SIZE-1))
#define PTRS_PER_PUD (1UL << (PTRS_PER_PTD_SHIFT))
#endif
/*
* Definitions for first level:
*
* PGDIR_SHIFT determines what a first-level page table entry can map.
*/
#ifdef CONFIG_PGTABLE_4
#define PGDIR_SHIFT (PUD_SHIFT + (PTRS_PER_PTD_SHIFT))
#else
#define PGDIR_SHIFT (PMD_SHIFT + (PTRS_PER_PTD_SHIFT))
#endif
#define PGDIR_SIZE (__IA64_UL(1) << PGDIR_SHIFT)
#define PGDIR_MASK (~(PGDIR_SIZE-1))
#define PTRS_PER_PGD_SHIFT PTRS_PER_PTD_SHIFT
#define PTRS_PER_PGD (1UL << PTRS_PER_PGD_SHIFT)
#define USER_PTRS_PER_PGD (5*PTRS_PER_PGD/8)
/* regions 0-4 are user regions */
#define FIRST_USER_ADDRESS 0
/*
/*
* All the normal masks have the "page accessed" bits on, as any time
* All the normal masks have the "page accessed" bits on, as any time
...
@@ -161,6 +184,9 @@
...
@@ -161,6 +184,9 @@
#define __S111 __pgprot(__ACCESS_BITS | _PAGE_PL_3 | _PAGE_AR_RWX)
#define __S111 __pgprot(__ACCESS_BITS | _PAGE_PL_3 | _PAGE_AR_RWX)
#define pgd_ERROR(e) printk("%s:%d: bad pgd %016lx.\n", __FILE__, __LINE__, pgd_val(e))
#define pgd_ERROR(e) printk("%s:%d: bad pgd %016lx.\n", __FILE__, __LINE__, pgd_val(e))
#ifdef CONFIG_PGTABLE_4
#define pud_ERROR(e) printk("%s:%d: bad pud %016lx.\n", __FILE__, __LINE__, pud_val(e))
#endif
#define pmd_ERROR(e) printk("%s:%d: bad pmd %016lx.\n", __FILE__, __LINE__, pmd_val(e))
#define pmd_ERROR(e) printk("%s:%d: bad pmd %016lx.\n", __FILE__, __LINE__, pmd_val(e))
#define pte_ERROR(e) printk("%s:%d: bad pte %016lx.\n", __FILE__, __LINE__, pte_val(e))
#define pte_ERROR(e) printk("%s:%d: bad pte %016lx.\n", __FILE__, __LINE__, pte_val(e))
...
@@ -218,6 +244,9 @@ ia64_phys_addr_valid (unsigned long addr)
...
@@ -218,6 +244,9 @@ ia64_phys_addr_valid (unsigned long addr)
#define kc_vaddr_to_offset(v) ((v) - RGN_BASE(RGN_GATE))
#define kc_vaddr_to_offset(v) ((v) - RGN_BASE(RGN_GATE))
#define kc_offset_to_vaddr(o) ((o) + RGN_BASE(RGN_GATE))
#define kc_offset_to_vaddr(o) ((o) + RGN_BASE(RGN_GATE))
#define RGN_MAP_SHIFT (PGDIR_SHIFT + PTRS_PER_PGD_SHIFT - 3)
#define RGN_MAP_LIMIT ((1UL << RGN_MAP_SHIFT) - PAGE_SIZE)
/* per region addr limit */
/*
/*
* Conversion functions: convert page frame number (pfn) and a protection value to a page
* Conversion functions: convert page frame number (pfn) and a protection value to a page
* table entry (pte).
* table entry (pte).
...
@@ -254,9 +283,16 @@ ia64_phys_addr_valid (unsigned long addr)
...
@@ -254,9 +283,16 @@ ia64_phys_addr_valid (unsigned long addr)
#define pud_bad(pud) (!ia64_phys_addr_valid(pud_val(pud)))
#define pud_bad(pud) (!ia64_phys_addr_valid(pud_val(pud)))
#define pud_present(pud) (pud_val(pud) != 0UL)
#define pud_present(pud) (pud_val(pud) != 0UL)
#define pud_clear(pudp) (pud_val(*(pudp)) = 0UL)
#define pud_clear(pudp) (pud_val(*(pudp)) = 0UL)
#define pud_page(pud) ((unsigned long) __va(pud_val(pud) & _PFN_MASK))
#define pud_page(pud) ((unsigned long) __va(pud_val(pud) & _PFN_MASK))
#ifdef CONFIG_PGTABLE_4
#define pgd_none(pgd) (!pgd_val(pgd))
#define pgd_bad(pgd) (!ia64_phys_addr_valid(pgd_val(pgd)))
#define pgd_present(pgd) (pgd_val(pgd) != 0UL)
#define pgd_clear(pgdp) (pgd_val(*(pgdp)) = 0UL)
#define pgd_page(pgd) ((unsigned long) __va(pgd_val(pgd) & _PFN_MASK))
#endif
/*
/*
* The following have defined behavior only work if pte_present() is true.
* The following have defined behavior only work if pte_present() is true.
*/
*/
...
@@ -324,7 +360,13 @@ pgd_offset (struct mm_struct *mm, unsigned long address)
...
@@ -324,7 +360,13 @@ pgd_offset (struct mm_struct *mm, unsigned long address)
here. */
here. */
#define pgd_offset_gate(mm, addr) pgd_offset_k(addr)
#define pgd_offset_gate(mm, addr) pgd_offset_k(addr)
#ifdef CONFIG_PGTABLE_4
/* Find an entry in the second-level page table.. */
/* Find an entry in the second-level page table.. */
#define pud_offset(dir,addr) \
((pud_t *) pgd_page(*(dir)) + (((addr) >> PUD_SHIFT) & (PTRS_PER_PUD - 1)))
#endif
/* Find an entry in the third-level page table.. */
#define pmd_offset(dir,addr) \
#define pmd_offset(dir,addr) \
((pmd_t *) pud_page(*(dir)) + (((addr) >> PMD_SHIFT) & (PTRS_PER_PMD - 1)))
((pmd_t *) pud_page(*(dir)) + (((addr) >> PMD_SHIFT) & (PTRS_PER_PMD - 1)))
...
@@ -557,7 +599,9 @@ do { \
...
@@ -557,7 +599,9 @@ do { \
#define __HAVE_ARCH_PGD_OFFSET_GATE
#define __HAVE_ARCH_PGD_OFFSET_GATE
#define __HAVE_ARCH_LAZY_MMU_PROT_UPDATE
#define __HAVE_ARCH_LAZY_MMU_PROT_UPDATE
#ifndef CONFIG_PGTABLE_4
#include <asm-generic/pgtable-nopud.h>
#include <asm-generic/pgtable-nopud.h>
#endif
#include <asm-generic/pgtable.h>
#include <asm-generic/pgtable.h>
#endif
/* _ASM_IA64_PGTABLE_H */
#endif
/* _ASM_IA64_PGTABLE_H */
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