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 #ifndef NST_BOARD_UNL_TF1201_H
26 #define NST_BOARD_UNL_TF1201_H
27 
28 #ifdef NST_PRAGMA_ONCE
29 #pragma once
30 #endif
31 
32 namespace Nes
33 {
34 	namespace Core
35 	{
36 		namespace Boards
37 		{
38 			namespace Unlicensed
39 			{
40 				class Tf1201 : public Board
41 				{
42 				public:
43 
44 					explicit Tf1201(const Context&);
45 
46 				private:
47 
48 					void SubReset(bool);
49 					void SubLoad(State::Loader&,dword);
50 					void SubSave(State::Saver&) const;
51 					void UpdatePrg(uint);
52 					void Sync(Event,Input::Controllers*);
53 
54 					NES_DECL_POKE( 8000 );
55 					NES_DECL_POKE( 9001 );
56 					NES_DECL_POKE( B000 );
57 					NES_DECL_POKE( B002 );
58 					NES_DECL_POKE( F000 );
59 					NES_DECL_POKE( F001 );
60 					NES_DECL_POKE( F002 );
61 
62 					struct Irq
63 					{
64 						void Reset(bool);
65 						bool Clock();
66 
67 						enum
68 						{
69 							CLOCK_FILTER = 16
70 						};
71 
72 						ibool enabled;
73 						uint count;
74 					};
75 
76 					uint prgSelect;
77 					Timer::A12<Irq,Irq::CLOCK_FILTER> irq;
78 				};
79 			}
80 		}
81 	}
82 }
83 
84 #endif
85