blob: ea3c8d399abec32d62b8fb975a930506bb0e0bca (
plain)
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
|
# Copyright 2015-present Facebook. All rights reserved.
#
# This program file 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; version 2 of the License.
#
# 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 in a file named COPYING; if not, write to the
# Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor,
# Boston, MA 02110-1301 USA
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
from __future__ import unicode_literals
import phymemory
_soc_reg_map = {}
class SCUReg(phymemory.PhyMemory):
SCU_REG_MAX = 0x1A4
SCU_ADDR_BASE = 0x1E6E2000
def __init__(self, reg):
assert 0 <= reg <= self.SCU_REG_MAX
self.reg = reg
super(SCUReg, self).__init__(self.SCU_ADDR_BASE + reg, 'SCU%X' % reg)
def soc_get_register(addr):
if addr in _soc_reg_map:
return _soc_reg_map[addr]
reg = SCUReg(addr)
_soc_reg_map[addr] = reg
return reg
|