diff options
| author | gdkchan <gab.dark.100@gmail.com> | 2018-02-07 13:44:48 -0300 |
|---|---|---|
| committer | gdkchan <gab.dark.100@gmail.com> | 2018-02-07 13:44:48 -0300 |
| commit | 18ac1c4045cc156068bd5a4fa82035c79c74e25d (patch) | |
| tree | ef551cebfa5e211a34a0b4b24e171477335d73b9 /GLScreen.cs | |
| parent | d77d691381ffa79b18a0df1b898b20b3a098ca1a (diff) | |
Removed parts of the MMU functionality to use memory directly (faster, but potentially more dangerous, WIP), also changed the Shl/Sshr immediate instructions to use IL instead of calling the method
Diffstat (limited to 'GLScreen.cs')
| -rw-r--r-- | GLScreen.cs | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/GLScreen.cs b/GLScreen.cs index d757db8f..3e16f7f1 100644 --- a/GLScreen.cs +++ b/GLScreen.cs @@ -6,6 +6,7 @@ using Gal; using OpenTK; using OpenTK.Graphics; using OpenTK.Graphics.OpenGL; +using Ryujinx.OsHle; using System; namespace Ryujinx @@ -60,12 +61,14 @@ namespace Ryujinx unsafe void UploadBitmap() { - if (Renderer.FrameBufferPtr == 0) + int FbSize = Width * Height * 4; + + if (Renderer.FrameBufferPtr == 0 || Renderer.FrameBufferPtr + FbSize > uint.MaxValue) { return; } - byte* SrcPtr = (byte*)IntPtr.Add(Ns.Ram, (int)Renderer.FrameBufferPtr); + byte* SrcPtr = (byte*)Ns.Ram + (uint)Renderer.FrameBufferPtr; for (int Y = 0; Y < Height; Y++) { @@ -275,7 +278,14 @@ void main(void) { { unsafe { - byte* Ptr = (byte*)IntPtr.Add(Ns.Ram, (int)Ns.Os.HidOffset); + long HidOffset = Ns.Os.GetVirtHidOffset(); + + if (HidOffset == 0 || HidOffset + Horizon.HidSize > uint.MaxValue) + { + return; + } + + byte* Ptr = (byte*)Ns.Ram + (uint)HidOffset; int State = 0; |
