-
Notifications
You must be signed in to change notification settings - Fork 1
/
AliM1543C_usb.h
88 lines (77 loc) · 2.85 KB
/
AliM1543C_usb.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/* ES40 emulator.
* Copyright (C) 2007-2008 by the ES40 Emulator Project
*
* WWW : http://sourceforge.net/projects/es40
* E-mail : [email protected]
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* Although this is not required, the author would appreciate being notified of,
* and receiving any modifications you may make to the source code that might serve
* the general public.
*/
/**
* \file
* Contains the definitions for the emulated Ali M1543C USB chipset part.
*
* $Id: AliM1543C_usb.h,v 1.5 2008/02/18 15:51:30 iamcamiel Exp $
*
* X-1.5 Brian wheeler 18-FEB-2008
* Implemented HCI register space.
*
* X-1.4 Camiel Vanderhoeven 08-JAN-2008
* Comments.
*
* X-1.3 Camiel Vanderhoeven 02-JAN-2008
* Comments.
*
* X-1.2 Camiel Vanderhoeven 17-DEC-2007
* SaveState file format 2.1
*
* X-1.1 Camiel Vanderhoeven 10-DEC-2007
* Initial version in CVS; this part was split off from the CAliM1543C
* class.
**/
#if !defined(INCLUDED_ALIM1543C_USB_H_)
#define INCLUDED_ALIM1543C_USB_H
#include "PCIDevice.h"
/**
* \brief Emulated USB part of ALi M1543C multi-function device.
*
* \todo This device is just a stub. Not functional yet.
*
* Documentation consulted:
* - Ali M1543C B1 South Bridge Version 1.20
* (http://mds.gotdns.com/sensors/docs/ali/1543dScb1-120.pdf)
* .
**/
class CAliM1543C_usb : public CPCIDevice
{
public:
virtual int SaveState(FILE * f);
virtual int RestoreState(FILE * f);
CAliM1543C_usb(CConfigurator * cfg, class CSystem * c, int pcibus, int pcidev);
virtual ~CAliM1543C_usb();
virtual void WriteMem_Bar(int func,int bar, u32 address, int dsize, u32 data);
virtual u32 ReadMem_Bar(int func,int bar, u32 address, int dsize);
private:
u64 usb_hci_read(u64 address, int dsize);
void usb_hci_write(u64 address, int dsize, u64 data);
/// The state structure contains all elements that need to be saved to the statefile.
struct SUSB_state {
u32 usb_data[0x110/4];
} state;
};
#endif // !defined(INCLUDED_ALIM1543C_USB_H)