1 ////////////////////////////////////////////////////////////////////////////////////////
2 //
3 // Nestopia - NES/Famicom emulator written in C++
4 //
5 // Copyright (C) 2003-2008 Martin Freij
6 //
7 // This file is part of Nestopia.
8 //
9 // Nestopia is free software; you can redistribute it and/or modify
10 // it under the terms of the GNU General Public License as published by
11 // the Free Software Foundation; either version 2 of the License, or
12 // (at your option) any later version.
13 //
14 // Nestopia is distributed in the hope that it will be useful,
15 // but WITHOUT ANY WARRANTY; without even the implied warranty of
16 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 // GNU General Public License for more details.
18 //
19 // You should have received a copy of the GNU General Public License
20 // along with Nestopia; if not, write to the Free Software
21 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
22 //
23 ////////////////////////////////////////////////////////////////////////////////////////
24 
25 #include "NstBoard.hpp"
26 #include "NstBoardHenggedianzi.hpp"
27 
28 namespace Nes
29 {
30 	namespace Core
31 	{
32 		namespace Boards
33 		{
34 			namespace Hengedianzi
35 			{
36 				#ifdef NST_MSVC_OPTIMIZE
37 				#pragma optimize("s", on)
38 				#endif
39 
SubReset(const bool hard)40 				void Standard::SubReset(const bool hard)
41 				{
42 					Map( 0x8000U, 0xFFFFU, &Standard::Poke_8000 );
43 
44 					if (hard)
45 						prg.SwapBank<SIZE_32K,0x0000>(0);
46 				}
47 
SubReset(const bool hard)48 				void Xjzb::SubReset(const bool hard)
49 				{
50 					Map( 0x5000U, 0x5FFFU, &Xjzb::Poke_5000 );
51 					Map( 0x8000U, 0xFFFFU, NMT_SWAP_HV );
52 
53 					if (hard)
54 						prg.SwapBank<SIZE_32K,0x0000>(0);
55 				}
56 
57 				#ifdef NST_MSVC_OPTIMIZE
58 				#pragma optimize("", on)
59 				#endif
60 
61 				NES_POKE_D(Xjzb,5000)
62 				{
63 					prg.SwapBank<SIZE_32K,0x0000>( data >> 1 );
64 				}
65 
66 				NES_POKE_D(Standard,8000)
67 				{
68 					prg.SwapBank<SIZE_32K,0x0000>( data );
69 					ppu.SetMirroring( (data >> 5 & 0x1) ? Ppu::NMT_H : Ppu::NMT_V );
70 				}
71 			}
72 		}
73 	}
74 }
75