blob: a92c933002c80d514a2d7d3d9b0c526e94cd78e9 [file] [log] [blame]
Simran Basie750a342013-03-12 13:45:26 -07001# Copyright (c) 2011 The Chromium OS Authors. All rights reserved.
2# Use of this source code is governed by a BSD-style license that can be
3# found in the LICENSE file.
4"""Defines the interfaces for the different servo models."""
Simran Basi5492bde2013-05-16 17:08:47 -07005
Simran Basie750a342013-03-12 13:45:26 -07006import collections
7
8INTERFACE_DEFAULTS = collections.defaultdict(dict)
9
Simran Basia9ad25e2013-04-23 11:57:00 -070010SERVO_ID_DEFAULTS = [(0x0403, 0x6011), (0x0403, 0x6014), (0x18d1, 0x5001),
11 (0x18d1, 0x5002), (0x18d1, 0x5004)]
Simran Basie750a342013-03-12 13:45:26 -070012
13# servo v1 w/o FT4232h EEPROM programmed
14INTERFACE_DEFAULTS[0x0403][0x6011] = ['ftdi_gpio', 'ftdi_i2c',
15 'ftdi_gpio', 'ftdi_gpio']
16# servo v1
17INTERFACE_DEFAULTS[0x18d1][0x5001] = ['ftdi_gpio', 'ftdi_i2c',
18 'ftdi_gpio', 'ftdi_gpio']
19# servo V2
20# Dummy interface 0 == JTAG via openocd
21# Dummy interface 4,5 == SPI via flashrom
Aseda Aboagyea4922212015-11-20 15:19:08 -080022# ec3po_uart interface 8,9 == usbpd console, ec console. Applicable to servo v3
23# as well.
24EC3PO_USBPD_INTERFACE_NUM = 8
25EC3PO_EC_INTERFACE_NUM = 9
26SERVO_V2_DEFAULTS = [(0x18d1, 0x5002)]
27for vid, pid in SERVO_V2_DEFAULTS:
28 INTERFACE_DEFAULTS[vid][pid] = \
Simran Basie750a342013-03-12 13:45:26 -070029 ['dummy', 'ftdi_i2c', 'ftdi_uart', 'ftdi_uart', 'dummy',
Aseda Aboagyea4922212015-11-20 15:19:08 -080030 'dummy', 'ftdi_uart', 'ftdi_uart',
31 {'name': 'ec3po_uart'},
32 {'name': 'ec3po_uart'}]
Simran Basie750a342013-03-12 13:45:26 -070033
34# servo v3
Aseda Aboagyea4922212015-11-20 15:19:08 -080035SERVO_V3_DEFAULTS = [(0x18d1, 0x5004)]
36for vid, pid in SERVO_V3_DEFAULTS:
37 INTERFACE_DEFAULTS[vid][pid] = \
Simran Basi949309b2013-05-31 15:12:15 -070038 ['bb_gpio',
Rong Changc6c8c022014-08-11 14:07:11 +080039 {'name': 'dev_i2c', 'bus_num': 1},
Simran Basi949309b2013-05-31 15:12:15 -070040 {'name': 'bb_uart', 'uart_num': 5,
Todd Brochb21d8042014-05-15 12:54:54 -070041 'txd': ['lcd_data8', 0x4], 'rxd': ['lcd_data9', 0x4]},
Rong Changc6c8c022014-08-11 14:07:11 +080042 {'name': 'dev_i2c', 'bus_num': 2},
Aaron.Chuang88eff332014-07-31 08:32:00 +080043 'bb_adc',
Simran Basi949309b2013-05-31 15:12:15 -070044 'dummy',
45 {'name': 'bb_uart', 'uart_num': 1},
Nick Sandersbc836282015-12-08 21:19:23 -080046 {'name': 'bb_uart', 'uart_num': 2},
Aseda Aboagyea4922212015-11-20 15:19:08 -080047 {'name': 'ec3po_uart'},
48 {'name': 'ec3po_uart'},
Nick Sandersbc836282015-12-08 21:19:23 -080049 {'name': 'bb_uart', 'uart_num': 4}]
Simran Basie750a342013-03-12 13:45:26 -070050
Simran Basia9ad25e2013-04-23 11:57:00 -070051INTERFACE_DEFAULTS[0x0403][0x6014] = INTERFACE_DEFAULTS[0x18d1][0x5004]
52
Simran Basie750a342013-03-12 13:45:26 -070053# miniservo
54MINISERVO_ID_DEFAULTS = [(0x403, 0x6001), (0x18d1, 0x5000)]
55for vid, pid in MINISERVO_ID_DEFAULTS:
Aseda Aboagyea4922212015-11-20 15:19:08 -080056 INTERFACE_DEFAULTS[vid][pid] = ['ftdi_gpiouart', {'name': 'ec3po_uart'}]
Simran Basie750a342013-03-12 13:45:26 -070057
58SERVO_ID_DEFAULTS.extend(MINISERVO_ID_DEFAULTS)
Vincent Palatinf536f002013-04-11 12:43:49 -070059
60# Toad
61TOAD_ID_DEFAULTS = [(0x403, 0x6015)]
62for vid, pid in TOAD_ID_DEFAULTS:
Aseda Aboagyea4922212015-11-20 15:19:08 -080063 INTERFACE_DEFAULTS[vid][pid] = ['ftdi_gpiouart', {'name': 'ec3po_uart'}]
Vincent Palatinf536f002013-04-11 12:43:49 -070064
65SERVO_ID_DEFAULTS.extend(TOAD_ID_DEFAULTS)
Vincent Palatin32fbecb2013-10-23 13:32:47 -070066
67# Reston
68RESTON_ID_DEFAULTS = [(0x18d1, 0x5007)]
69for vid, pid in RESTON_ID_DEFAULTS:
Aseda Aboagyea4922212015-11-20 15:19:08 -080070 INTERFACE_DEFAULTS[vid][pid] = ['ftdi_gpiouart', {'name': 'ec3po_uart'}]
Vincent Palatin32fbecb2013-10-23 13:32:47 -070071
72SERVO_ID_DEFAULTS.extend(RESTON_ID_DEFAULTS)
Vincent Palatin77629ac2014-03-21 09:33:13 -070073
74# Fruitpie
75FRUITPIE_ID_DEFAULTS = [(0x18d1, 0x5009)]
76for vid, pid in FRUITPIE_ID_DEFAULTS:
Aseda Aboagyea4922212015-11-20 15:19:08 -080077 INTERFACE_DEFAULTS[vid][pid] = ['ftdi_gpiouart', {'name': 'ec3po_uart'}]
Vincent Palatin77629ac2014-03-21 09:33:13 -070078
79SERVO_ID_DEFAULTS.extend(FRUITPIE_ID_DEFAULTS)
Todd Brochb21d8042014-05-15 12:54:54 -070080
Alec Berge7549802014-07-14 11:52:36 -070081# Plankton
82PLANKTON_ID_DEFAULTS = [(0x18d1, 0x500c)]
83for vid, pid in PLANKTON_ID_DEFAULTS:
Aseda Aboagyea4922212015-11-20 15:19:08 -080084 INTERFACE_DEFAULTS[vid][pid] = ['ftdi_gpiouart', {'name': 'ec3po_uart'}]
Alec Berge7549802014-07-14 11:52:36 -070085
86SERVO_ID_DEFAULTS.extend(PLANKTON_ID_DEFAULTS)
87
Todd Brochb21d8042014-05-15 12:54:54 -070088# Allow Board overrides of interfaces as we've started to overload some servo V2
89# pinout functionality. To-date just swapping EC SPI interface for USB PD MCU
90# UART
91# TODO(tbroch) See about availability of extra uart on Servo V3/beaglebone
92INTERFACE_BOARDS = collections.defaultdict(
93 lambda: collections.defaultdict(dict))
94# samus re-purposes EC SPI to be USB PD UART
95INTERFACE_BOARDS['samus'][0x18d1][0x5002] = \
96 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
97INTERFACE_BOARDS['samus'][0x18d1][0x5002][5] = 'ftdi_uart'
Rong Chang97d0e0c2015-04-24 09:02:31 +080098# oak re-purposes EC SPI to be USB PD UART
99INTERFACE_BOARDS['oak'][0x18d1][0x5002] = \
100 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
101INTERFACE_BOARDS['oak'][0x18d1][0x5002][5] = 'ftdi_uart'
Kevin K Wong6460d5a2015-06-24 18:05:11 -0700102# strago re-purposes JTAG to be UART
103INTERFACE_BOARDS['strago'][0x18d1][0x5002] = \
104 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
105INTERFACE_BOARDS['strago'][0x18d1][0x5002][0] = 'ftdi_uart'
Duncan Laurie0728aa82015-10-26 13:56:08 -0700106
107# Skylake boards re-purpose JTAG to be UART
108INTERFACE_BOARDS['chell'][0x18d1][0x5002] = \
109 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
110INTERFACE_BOARDS['chell'][0x18d1][0x5002][0] = 'ftdi_uart'
111INTERFACE_BOARDS['glados'][0x18d1][0x5002] = \
112 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
113INTERFACE_BOARDS['glados'][0x18d1][0x5002][0] = 'ftdi_uart'
Kevin K Wong92a07672015-06-24 22:21:31 -0700114INTERFACE_BOARDS['kunimitsu'][0x18d1][0x5002] = \
115 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
116INTERFACE_BOARDS['kunimitsu'][0x18d1][0x5002][0] = 'ftdi_uart'
Duncan Laurie0728aa82015-10-26 13:56:08 -0700117INTERFACE_BOARDS['lars'][0x18d1][0x5002] = \
118 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
119INTERFACE_BOARDS['lars'][0x18d1][0x5002][0] = 'ftdi_uart'