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
208b7d1e
Commit
208b7d1e
authored
Jul 23, 2002
by
Geert Uytterhoeven
Committed by
Linus Torvalds
Jul 23, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] M68k update (part 29)
Add Mac/m68k support to valkyriefb
parent
b0283159
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
83 additions
and
36 deletions
+83
-36
drivers/video/valkyriefb.c
drivers/video/valkyriefb.c
+52
-26
drivers/video/valkyriefb.h
drivers/video/valkyriefb.h
+31
-10
No files found.
drivers/video/valkyriefb.c
View file @
208b7d1e
...
@@ -7,6 +7,8 @@
...
@@ -7,6 +7,8 @@
* Vmode-switching changes and vmode 15/17 modifications created 29 August
* Vmode-switching changes and vmode 15/17 modifications created 29 August
* 1998 by Barry K. Nathan <barryn@pobox.com>.
* 1998 by Barry K. Nathan <barryn@pobox.com>.
*
*
* Ported to m68k Macintosh by David Huggins-Daines <dhd@debian.org>
*
* Derived directly from:
* Derived directly from:
*
*
* controlfb.c -- frame buffer device for the PowerMac 'control' display
* controlfb.c -- frame buffer device for the PowerMac 'control' display
...
@@ -59,7 +61,12 @@
...
@@ -59,7 +61,12 @@
#include <linux/adb.h>
#include <linux/adb.h>
#include <linux/cuda.h>
#include <linux/cuda.h>
#include <asm/io.h>
#include <asm/io.h>
#ifdef CONFIG_MAC
#include <asm/bootinfo.h>
#include <asm/macintosh.h>
#else
#include <asm/prom.h>
#include <asm/prom.h>
#endif
#include <asm/pgtable.h>
#include <asm/pgtable.h>
#include <video/fbcon.h>
#include <video/fbcon.h>
...
@@ -71,8 +78,15 @@
...
@@ -71,8 +78,15 @@
static
int
can_soft_blank
=
1
;
static
int
can_soft_blank
=
1
;
#ifdef CONFIG_MAC
/* We don't yet have functions to read the PRAM... perhaps we can
adapt them from the PPC code? */
static
int
default_vmode
=
VMODE_640_480_67
;
static
int
default_cmode
=
CMODE_8
;
#else
static
int
default_vmode
=
VMODE_NVRAM
;
static
int
default_vmode
=
VMODE_NVRAM
;
static
int
default_cmode
=
CMODE_NVRAM
;
static
int
default_cmode
=
CMODE_NVRAM
;
#endif
static
char
fontname
[
40
]
__initdata
=
{
0
};
static
char
fontname
[
40
]
__initdata
=
{
0
};
static
int
switching
=
0
;
static
int
switching
=
0
;
...
@@ -116,7 +130,6 @@ struct fb_info_valkyrie {
...
@@ -116,7 +130,6 @@ struct fb_info_valkyrie {
int
valkyriefb_init
(
void
);
int
valkyriefb_init
(
void
);
int
valkyriefb_setup
(
char
*
);
int
valkyriefb_setup
(
char
*
);
static
void
valkyrie_of_init
(
struct
device_node
*
dp
);
static
int
valkyrie_get_fix
(
struct
fb_fix_screeninfo
*
fix
,
int
con
,
static
int
valkyrie_get_fix
(
struct
fb_fix_screeninfo
*
fix
,
int
con
,
struct
fb_info
*
info
);
struct
fb_info
*
info
);
static
int
valkyrie_get_var
(
struct
fb_var_screeninfo
*
var
,
int
con
,
static
int
valkyrie_get_var
(
struct
fb_var_screeninfo
*
var
,
int
con
,
...
@@ -409,6 +422,7 @@ static void __init init_valkyrie(struct fb_info_valkyrie *p)
...
@@ -409,6 +422,7 @@ static void __init init_valkyrie(struct fb_info_valkyrie *p)
printk
(
KERN_INFO
"Monitor sense value = 0x%x, "
,
p
->
sense
);
printk
(
KERN_INFO
"Monitor sense value = 0x%x, "
,
p
->
sense
);
/* Try to pick a video mode out of NVRAM if we have one. */
/* Try to pick a video mode out of NVRAM if we have one. */
#ifndef CONFIG_MAC
if
(
default_vmode
==
VMODE_NVRAM
)
{
if
(
default_vmode
==
VMODE_NVRAM
)
{
default_vmode
=
nvram_read_byte
(
NV_VMODE
);
default_vmode
=
nvram_read_byte
(
NV_VMODE
);
if
(
default_vmode
<=
0
if
(
default_vmode
<=
0
...
@@ -416,12 +430,15 @@ static void __init init_valkyrie(struct fb_info_valkyrie *p)
...
@@ -416,12 +430,15 @@ static void __init init_valkyrie(struct fb_info_valkyrie *p)
||
!
valkyrie_reg_init
[
default_vmode
-
1
])
||
!
valkyrie_reg_init
[
default_vmode
-
1
])
default_vmode
=
VMODE_CHOOSE
;
default_vmode
=
VMODE_CHOOSE
;
}
}
#endif
if
(
default_vmode
==
VMODE_CHOOSE
)
if
(
default_vmode
==
VMODE_CHOOSE
)
default_vmode
=
mac_map_monitor_sense
(
p
->
sense
);
default_vmode
=
mac_map_monitor_sense
(
p
->
sense
);
if
(
!
valkyrie_reg_init
[
default_vmode
-
1
])
if
(
!
valkyrie_reg_init
[
default_vmode
-
1
])
default_vmode
=
VMODE_640_480_67
;
default_vmode
=
VMODE_640_480_67
;
#ifndef CONFIG_MAC
if
(
default_cmode
==
CMODE_NVRAM
)
if
(
default_cmode
==
CMODE_NVRAM
)
default_cmode
=
nvram_read_byte
(
NV_CMODE
);
default_cmode
=
nvram_read_byte
(
NV_CMODE
);
#endif
/*
/*
* Reduce the pixel size if we don't have enough VRAM or bandwitdh.
* Reduce the pixel size if we don't have enough VRAM or bandwitdh.
...
@@ -514,48 +531,57 @@ static void valkyrie_set_par(const struct fb_par_valkyrie *par,
...
@@ -514,48 +531,57 @@ static void valkyrie_set_par(const struct fb_par_valkyrie *par,
int
__init
valkyriefb_init
(
void
)
int
__init
valkyriefb_init
(
void
)
{
{
struct
fb_info_valkyrie
*
p
;
unsigned
long
frame_buffer_phys
,
cmap_regs_phys
,
flags
;
#ifdef CONFIG_MAC
if
(
!
MACH_IS_MAC
)
return
0
;
if
(
!
(
mac_bi_data
.
id
==
MAC_MODEL_Q630
/* I'm not sure about this one */
||
mac_bi_data
.
id
==
MAC_MODEL_P588
))
return
0
;
/* Hardcoded addresses... welcome to 68k Macintosh country :-) */
frame_buffer_phys
=
0xf9000000
;
cmap_regs_phys
=
0x50f24000
;
flags
=
IOMAP_NOCACHE_SER
;
/* IOMAP_WRITETHROUGH?? */
#else
/* ppc (!CONFIG_MAC) */
struct
device_node
*
dp
;
struct
device_node
*
dp
;
dp
=
find_devices
(
"valkyrie"
);
dp
=
find_devices
(
"valkyrie"
);
if
(
dp
!=
0
)
if
(
dp
==
0
)
valkyrie_of_init
(
dp
);
return
0
;
return
0
;
}
static
void
__init
valkyrie_of_init
(
struct
device_node
*
dp
)
{
struct
fb_info_valkyrie
*
p
;
unsigned
long
addr
;
if
(
dp
->
n_addrs
!=
1
)
{
if
(
dp
->
n_addrs
!=
1
)
{
printk
(
KERN_ERR
"expecting 1 address for valkyrie (got %d)"
,
dp
->
n_addrs
);
printk
(
KERN_ERR
"expecting 1 address for valkyrie (got %d)"
,
dp
->
n_addrs
);
return
;
return
0
;
}
}
frame_buffer_phys
=
dp
->
addrs
[
0
].
address
;
cmap_regs_phys
=
dp
->
addrs
[
0
].
address
+
0x304000
;
flags
=
_PAGE_WRITETHRU
;
#endif
/* ppc (!CONFIG_MAC) */
p
=
kmalloc
(
sizeof
(
*
p
),
GFP_ATOMIC
);
p
=
kmalloc
(
sizeof
(
*
p
),
GFP_ATOMIC
);
if
(
p
==
0
)
if
(
p
==
0
)
return
;
return
0
;
memset
(
p
,
0
,
sizeof
(
*
p
));
memset
(
p
,
0
,
sizeof
(
*
p
));
/* Map in frame buffer and registers */
/* Map in frame buffer and registers */
addr
=
dp
->
addrs
[
0
].
address
;
if
(
!
request_mem_region
(
frame_buffer_phys
,
0x100000
,
"valkyriefb"
))
{
if
(
!
request_mem_region
(
addr
,
dp
->
addrs
[
0
].
size
,
"valkyriefb"
))
{
kfree
(
p
);
kfree
(
p
);
return
;
return
0
;
}
}
p
->
frame_buffer_phys
=
addr
;
p
->
frame_buffer
=
__ioremap
(
addr
,
0x100000
,
_PAGE_WRITETHRU
);
p
->
cmap_regs_phys
=
addr
+
0x304000
;
p
->
cmap_regs
=
ioremap
(
p
->
cmap_regs_phys
,
4096
);
p
->
valkyrie_regs_phys
=
addr
+
0x30a000
;
p
->
valkyrie_regs
=
ioremap
(
p
->
valkyrie_regs_phys
,
4096
);
/*
* kps: As far as I know, all Valkyries have fixed usable VRAM.
*/
p
->
total_vram
=
0x100000
;
p
->
total_vram
=
0x100000
;
p
->
frame_buffer_phys
=
frame_buffer_phys
;
p
->
frame_buffer
=
__ioremap
(
frame_buffer_phys
,
p
->
total_vram
,
flags
);
p
->
cmap_regs_phys
=
cmap_regs_phys
;
p
->
cmap_regs
=
ioremap
(
p
->
cmap_regs_phys
,
0x1000
);
p
->
valkyrie_regs_phys
=
cmap_regs_phys
+
0x6000
;
p
->
valkyrie_regs
=
ioremap
(
p
->
valkyrie_regs_phys
,
0x1000
);
init_valkyrie
(
p
);
init_valkyrie
(
p
);
return
0
;
}
}
/*
/*
...
...
drivers/video/valkyriefb.h
View file @
208b7d1e
...
@@ -9,6 +9,8 @@
...
@@ -9,6 +9,8 @@
*
*
* vmode 10 changed by Steven Borley <sjb@salix.demon.co.uk>, 14 mai 2000
* vmode 10 changed by Steven Borley <sjb@salix.demon.co.uk>, 14 mai 2000
*
*
* Ported to 68k Macintosh by David Huggins-Daines <dhd@debian.org>
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version
* as published by the Free Software Foundation; either version
...
@@ -37,12 +39,19 @@
...
@@ -37,12 +39,19 @@
* Copyright (C) 1998 Jon Howell
* Copyright (C) 1998 Jon Howell
*/
*/
#ifdef CONFIG_MAC
/* Valkyrie registers are word-aligned on m68k */
#define VALKYRIE_REG_PADSIZE 3
#else
#define VALKYRIE_REG_PADSIZE 7
#endif
/*
/*
* Structure of the registers for the Valkyrie colormap registers.
* Structure of the registers for the Valkyrie colormap registers.
*/
*/
struct
cmap_regs
{
struct
cmap_regs
{
unsigned
char
addr
;
unsigned
char
addr
;
char
pad1
[
7
];
char
pad1
[
VALKYRIE_REG_PADSIZE
];
unsigned
char
lut
;
unsigned
char
lut
;
};
};
...
@@ -52,7 +61,7 @@ struct cmap_regs {
...
@@ -52,7 +61,7 @@ struct cmap_regs {
struct
vpreg
{
/* padded register */
struct
vpreg
{
/* padded register */
unsigned
char
r
;
unsigned
char
r
;
char
pad
[
7
];
char
pad
[
VALKYRIE_REG_PADSIZE
];
};
};
...
@@ -81,6 +90,7 @@ struct valkyrie_regvals {
...
@@ -81,6 +90,7 @@ struct valkyrie_regvals {
int
vres
;
int
vres
;
};
};
#ifndef CONFIG_MAC
/* Register values for 1024x768, 75Hz mode (17) */
/* Register values for 1024x768, 75Hz mode (17) */
/* I'm not sure which mode this is (16 or 17), so I'm defining it as 17,
/* I'm not sure which mode this is (16 or 17), so I'm defining it as 17,
* since the equivalent mode in controlfb (which I adapted this from) is
* since the equivalent mode in controlfb (which I adapted this from) is
...
@@ -125,14 +135,6 @@ static struct valkyrie_regvals valkyrie_reg_init_14 = {
...
@@ -125,14 +135,6 @@ static struct valkyrie_regvals valkyrie_reg_init_14 = {
1024
,
768
1024
,
768
};
};
/* Register values for 832x624, 75Hz mode (13) */
static
struct
valkyrie_regvals
valkyrie_reg_init_13
=
{
9
,
{
23
,
42
,
3
},
/* pixel clock = 57.07MHz for V=74.27Hz */
{
832
,
0
},
832
,
624
};
/* Register values for 800x600, 72Hz mode (11) */
/* Register values for 800x600, 72Hz mode (11) */
static
struct
valkyrie_regvals
valkyrie_reg_init_11
=
{
static
struct
valkyrie_regvals
valkyrie_reg_init_11
=
{
13
,
13
,
...
@@ -140,6 +142,15 @@ static struct valkyrie_regvals valkyrie_reg_init_11 = {
...
@@ -140,6 +142,15 @@ static struct valkyrie_regvals valkyrie_reg_init_11 = {
{
800
,
0
},
{
800
,
0
},
800
,
600
800
,
600
};
};
#endif
/* CONFIG_MAC */
/* Register values for 832x624, 75Hz mode (13) */
static
struct
valkyrie_regvals
valkyrie_reg_init_13
=
{
9
,
{
23
,
42
,
3
},
/* pixel clock = 57.07MHz for V=74.27Hz */
{
832
,
0
},
832
,
624
};
/* Register values for 800x600, 60Hz mode (10) */
/* Register values for 800x600, 60Hz mode (10) */
static
struct
valkyrie_regvals
valkyrie_reg_init_10
=
{
static
struct
valkyrie_regvals
valkyrie_reg_init_10
=
{
...
@@ -177,6 +188,15 @@ static struct valkyrie_regvals *valkyrie_reg_init[VMODE_MAX] = {
...
@@ -177,6 +188,15 @@ static struct valkyrie_regvals *valkyrie_reg_init[VMODE_MAX] = {
NULL
,
NULL
,
NULL
,
NULL
,
&
valkyrie_reg_init_10
,
&
valkyrie_reg_init_10
,
#ifdef CONFIG_MAC
NULL
,
NULL
,
&
valkyrie_reg_init_13
,
NULL
,
NULL
,
NULL
,
NULL
,
#else
&
valkyrie_reg_init_11
,
&
valkyrie_reg_init_11
,
NULL
,
NULL
,
&
valkyrie_reg_init_13
,
&
valkyrie_reg_init_13
,
...
@@ -184,6 +204,7 @@ static struct valkyrie_regvals *valkyrie_reg_init[VMODE_MAX] = {
...
@@ -184,6 +204,7 @@ static struct valkyrie_regvals *valkyrie_reg_init[VMODE_MAX] = {
&
valkyrie_reg_init_15
,
&
valkyrie_reg_init_15
,
NULL
,
NULL
,
&
valkyrie_reg_init_17
,
&
valkyrie_reg_init_17
,
#endif
NULL
,
NULL
,
NULL
,
NULL
,
NULL
NULL
...
...
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