Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
S
Suyu
Manage
Activity
Members
Labels
Plan
Issues
0
Issue boards
Milestones
Wiki
Code
Merge requests
0
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package Registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
many-archive
Suyu
Commits
6f6d5158
There was an error fetching the commit references. Please try again later.
Commit
6f6d5158
authored
11 years ago
by
bunnei
Browse files
Options
Downloads
Patches
Plain Diff
added OS memory read/write for thread command buffer
parent
b24e6f2b
No related branches found
No related tags found
No related merge requests found
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
src/core/hle/hle.cpp
+43
-2
43 additions, 2 deletions
src/core/hle/hle.cpp
src/core/hle/hle.h
+12
-1
12 additions, 1 deletion
src/core/hle/hle.h
src/core/mem_map.h
+0
-4
0 additions, 4 deletions
src/core/mem_map.h
src/core/mem_map_funcs.cpp
+5
-5
5 additions, 5 deletions
src/core/mem_map_funcs.cpp
with
60 additions
and
12 deletions
src/core/hle/hle.cpp
+
43
−
2
View file @
6f6d5158
...
@@ -15,6 +15,40 @@ namespace HLE {
...
@@ -15,6 +15,40 @@ namespace HLE {
static
std
::
vector
<
ModuleDef
>
g_module_db
;
static
std
::
vector
<
ModuleDef
>
g_module_db
;
u8
*
g_command_buffer
=
NULL
;
///< Command buffer used for sharing between appcore and syscore
// Read from memory used by CTROS HLE functions
template
<
typename
T
>
inline
void
Read
(
T
&
var
,
const
u32
addr
)
{
if
(
addr
>=
HLE
::
CMD_BUFFER_ADDR
&&
addr
<
HLE
::
CMD_BUFFER_ADDR_END
)
{
var
=
*
((
const
T
*
)
&
g_command_buffer
[
addr
&
CMD_BUFFER_MASK
]);
}
else
{
ERROR_LOG
(
HLE
,
"unknown read from address %08X"
,
addr
);
}
}
// Write to memory used by CTROS HLE functions
template
<
typename
T
>
inline
void
Write
(
u32
addr
,
const
T
data
)
{
if
(
addr
>=
HLE
::
CMD_BUFFER_ADDR
&&
addr
<
HLE
::
CMD_BUFFER_ADDR_END
)
{
*
(
T
*
)
&
g_command_buffer
[
addr
&
CMD_BUFFER_MASK
]
=
data
;
}
else
{
ERROR_LOG
(
HLE
,
"unknown write to address %08X"
,
addr
);
}
}
// Explicitly instantiate template functions because we aren't defining this in the header:
template
void
Read
<
u64
>(
u64
&
var
,
const
u32
addr
);
template
void
Read
<
u32
>(
u32
&
var
,
const
u32
addr
);
template
void
Read
<
u16
>(
u16
&
var
,
const
u32
addr
);
template
void
Read
<
u8
>(
u8
&
var
,
const
u32
addr
);
template
void
Write
<
u64
>(
u32
addr
,
const
u64
data
);
template
void
Write
<
u32
>(
u32
addr
,
const
u32
data
);
template
void
Write
<
u16
>(
u32
addr
,
const
u16
data
);
template
void
Write
<
u8
>(
u32
addr
,
const
u8
data
);
const
FunctionDef
*
GetSyscallInfo
(
u32
opcode
)
{
const
FunctionDef
*
GetSyscallInfo
(
u32
opcode
)
{
u32
func_num
=
opcode
&
0xFFFFFF
;
// 8 bits
u32
func_num
=
opcode
&
0xFFFFFF
;
// 8 bits
if
(
func_num
>
0xFF
)
{
if
(
func_num
>
0xFF
)
{
...
@@ -41,8 +75,8 @@ void CallSyscall(u32 opcode) {
...
@@ -41,8 +75,8 @@ void CallSyscall(u32 opcode) {
Addr
CallGetThreadCommandBuffer
()
{
Addr
CallGetThreadCommandBuffer
()
{
// Called on insruction: mrc p15, 0, r0, c13, c0, 3
// Called on insruction: mrc p15, 0, r0, c13, c0, 3
// Returns an address in OSHLE memory for the CPU to read/write to
// Returns an address in OSHLE memory for the CPU to read/write to
RETURN
(
OS_THREAD_COMMAN
D_BUFFER_ADDR
);
RETURN
(
CM
D_BUFFER_ADDR
);
return
OS_THREAD_COMMAN
D_BUFFER_ADDR
;
return
CM
D_BUFFER_ADDR
;
}
}
void
RegisterModule
(
std
::
string
name
,
int
num_functions
,
const
FunctionDef
*
func_table
)
{
void
RegisterModule
(
std
::
string
name
,
int
num_functions
,
const
FunctionDef
*
func_table
)
{
...
@@ -56,6 +90,8 @@ void RegisterAllModules() {
...
@@ -56,6 +90,8 @@ void RegisterAllModules() {
void
Init
()
{
void
Init
()
{
Service
::
Init
();
Service
::
Init
();
g_command_buffer
=
new
u8
[
CMD_BUFFER_SIZE
];
RegisterAllModules
();
RegisterAllModules
();
...
@@ -63,7 +99,12 @@ void Init() {
...
@@ -63,7 +99,12 @@ void Init() {
}
}
void
Shutdown
()
{
void
Shutdown
()
{
Service
::
Shutdown
();
delete
g_command_buffer
;
g_module_db
.
clear
();
g_module_db
.
clear
();
NOTICE_LOG
(
HLE
,
"shutdown OK"
);
NOTICE_LOG
(
HLE
,
"shutdown OK"
);
}
}
...
...
This diff is collapsed.
Click to expand it.
src/core/hle/hle.h
+
12
−
1
View file @
6f6d5158
...
@@ -17,7 +17,10 @@
...
@@ -17,7 +17,10 @@
namespace
HLE
{
namespace
HLE
{
enum
{
enum
{
OS_THREAD_COMMAND_BUFFER_ADDR
=
0xA0004000
,
CMD_BUFFER_ADDR
=
0xA0010000
,
///< Totally arbitrary unused address space
CMD_BUFFER_SIZE
=
0x10000
,
CMD_BUFFER_MASK
=
(
CMD_BUFFER_SIZE
-
1
),
CMD_BUFFER_ADDR_END
=
(
CMD_BUFFER_ADDR
+
CMD_BUFFER_SIZE
),
};
};
typedef
u32
Addr
;
typedef
u32
Addr
;
...
@@ -35,6 +38,14 @@ struct ModuleDef {
...
@@ -35,6 +38,14 @@ struct ModuleDef {
const
FunctionDef
*
func_table
;
const
FunctionDef
*
func_table
;
};
};
// Read from memory used by CTROS HLE functions
template
<
typename
T
>
inline
void
Read
(
T
&
var
,
const
u32
addr
);
// Write to memory used by CTROS HLE functions
template
<
typename
T
>
inline
void
Write
(
u32
addr
,
const
T
data
);
void
RegisterModule
(
std
::
string
name
,
int
num_functions
,
const
FunctionDef
*
func_table
);
void
RegisterModule
(
std
::
string
name
,
int
num_functions
,
const
FunctionDef
*
func_table
);
void
CallSyscall
(
u32
opcode
);
void
CallSyscall
(
u32
opcode
);
...
...
This diff is collapsed.
Click to expand it.
src/core/mem_map.h
+
0
−
4
View file @
6f6d5158
...
@@ -32,10 +32,6 @@ enum {
...
@@ -32,10 +32,6 @@ enum {
MEM_VRAM_VADDR
=
0x1F000000
,
MEM_VRAM_VADDR
=
0x1F000000
,
MEM_SCRATCHPAD_VADDR
=
(
0x10000000
-
MEM_SCRATCHPAD_SIZE
),
///< Scratchpad virtual address
MEM_SCRATCHPAD_VADDR
=
(
0x10000000
-
MEM_SCRATCHPAD_SIZE
),
///< Scratchpad virtual address
MEM_OSHLE_SIZE
=
0x08000000
,
///< ...Same size as FCRAM for now
MEM_OSHLE_VADDR
=
0xA0000000
,
///< Memory for use by OSHLE accessible by appcore CPU
MEM_OSHLE_VADDR_END
=
(
MEM_OSHLE_VADDR
+
MEM_OSHLE_SIZE
),
};
};
////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////
...
...
This diff is collapsed.
Click to expand it.
src/core/mem_map_funcs.cpp
+
5
−
5
View file @
6f6d5158
...
@@ -20,8 +20,8 @@ inline void _Read(T &var, const u32 addr) {
...
@@ -20,8 +20,8 @@ inline void _Read(T &var, const u32 addr) {
// Memory allocated for HLE use that can be addressed from the emulated application
// Memory allocated for HLE use that can be addressed from the emulated application
// The primary use of this is sharing a commandbuffer between the HLE OS (syscore) and the LLE
// The primary use of this is sharing a commandbuffer between the HLE OS (syscore) and the LLE
// core running the user application (appcore)
// core running the user application (appcore)
if
(
addr
>=
MEM_OSHLE_VADDR
&&
addr
<
MEM_OSHLE_V
ADDR_END
)
{
if
(
addr
>=
HLE
::
CMD_BUFFER_ADDR
&&
addr
<
HLE
::
CMD_BUFFER_
ADDR_END
)
{
NOTICE_LOG
(
MEMMAP
,
"OSHLE read @ 0x%08X"
,
addr
);
HLE
::
Read
<
T
>
(
var
,
addr
);
// Hardware I/O register reads
// Hardware I/O register reads
// 0x10XXXXXX- is physical address space, 0x1EXXXXXX is virtual address space
// 0x10XXXXXX- is physical address space, 0x1EXXXXXX is virtual address space
...
@@ -58,13 +58,13 @@ inline void _Write(u32 addr, const T data) {
...
@@ -58,13 +58,13 @@ inline void _Write(u32 addr, const T data) {
// Memory allocated for HLE use that can be addressed from the emulated application
// Memory allocated for HLE use that can be addressed from the emulated application
// The primary use of this is sharing a commandbuffer between the HLE OS (syscore) and the LLE
// The primary use of this is sharing a commandbuffer between the HLE OS (syscore) and the LLE
// core running the user application (appcore)
// core running the user application (appcore)
if
(
addr
>=
MEM_OSHLE_VADDR
&&
addr
<
MEM_OSHLE_V
ADDR_END
)
{
if
(
addr
>=
HLE
::
CMD_BUFFER_ADDR
&&
addr
<
HLE
::
CMD_BUFFER_
ADDR_END
)
{
NOTICE_LOG
(
MEMMAP
,
"OSHLE write @ 0x%08X"
,
addr
);
HLE
::
Write
<
T
>
(
addr
,
data
);
// Hardware I/O register writes
// Hardware I/O register writes
// 0x10XXXXXX- is physical address space, 0x1EXXXXXX is virtual address space
// 0x10XXXXXX- is physical address space, 0x1EXXXXXX is virtual address space
}
else
if
((
addr
&
0xFF000000
)
==
0x10000000
||
(
addr
&
0xFF000000
)
==
0x1E000000
)
{
}
else
if
((
addr
&
0xFF000000
)
==
0x10000000
||
(
addr
&
0xFF000000
)
==
0x1E000000
)
{
HW
::
Write
<
const
T
>
(
addr
,
data
);
HW
::
Write
<
T
>
(
addr
,
data
);
// ExeFS:/.code is loaded here:
// ExeFS:/.code is loaded here:
}
else
if
((
addr
&
0xFFF00000
)
==
0x00100000
)
{
}
else
if
((
addr
&
0xFFF00000
)
==
0x00100000
)
{
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment