blob: afdcea313f82df00cdb7d08edf4d5917bcc6f601 [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
22INTERFACE_DEFAULTS[0x18d1][0x5002] = \
23 ['dummy', 'ftdi_i2c', 'ftdi_uart', 'ftdi_uart', 'dummy',
24 'dummy', 'ftdi_uart', 'ftdi_uart']
25
26# servo v3
Simran Basie750a342013-03-12 13:45:26 -070027INTERFACE_DEFAULTS[0x18d1][0x5004] = \
Simran Basi949309b2013-05-31 15:12:15 -070028 ['bb_gpio',
Rong Changc6c8c022014-08-11 14:07:11 +080029 {'name': 'dev_i2c', 'bus_num': 1},
Simran Basi949309b2013-05-31 15:12:15 -070030 {'name': 'bb_uart', 'uart_num': 5,
Todd Brochb21d8042014-05-15 12:54:54 -070031 'txd': ['lcd_data8', 0x4], 'rxd': ['lcd_data9', 0x4]},
Rong Changc6c8c022014-08-11 14:07:11 +080032 {'name': 'dev_i2c', 'bus_num': 2},
Aaron.Chuang88eff332014-07-31 08:32:00 +080033 'bb_adc',
Simran Basi949309b2013-05-31 15:12:15 -070034 'dummy',
35 {'name': 'bb_uart', 'uart_num': 1},
Nick Sandersbc836282015-12-08 21:19:23 -080036 {'name': 'bb_uart', 'uart_num': 2},
37 {'name': 'bb_uart', 'uart_num': 4}]
Simran Basie750a342013-03-12 13:45:26 -070038
Simran Basia9ad25e2013-04-23 11:57:00 -070039INTERFACE_DEFAULTS[0x0403][0x6014] = INTERFACE_DEFAULTS[0x18d1][0x5004]
40
Simran Basie750a342013-03-12 13:45:26 -070041# miniservo
42MINISERVO_ID_DEFAULTS = [(0x403, 0x6001), (0x18d1, 0x5000)]
43for vid, pid in MINISERVO_ID_DEFAULTS:
44 INTERFACE_DEFAULTS[vid][pid] = ['ftdi_gpiouart']
45
46SERVO_ID_DEFAULTS.extend(MINISERVO_ID_DEFAULTS)
Vincent Palatinf536f002013-04-11 12:43:49 -070047
48# Toad
49TOAD_ID_DEFAULTS = [(0x403, 0x6015)]
50for vid, pid in TOAD_ID_DEFAULTS:
Vincent Palatinbfa35742013-04-11 15:09:05 -070051 INTERFACE_DEFAULTS[vid][pid] = ['ftdi_gpiouart']
Vincent Palatinf536f002013-04-11 12:43:49 -070052
53SERVO_ID_DEFAULTS.extend(TOAD_ID_DEFAULTS)
Vincent Palatin32fbecb2013-10-23 13:32:47 -070054
55# Reston
56RESTON_ID_DEFAULTS = [(0x18d1, 0x5007)]
57for vid, pid in RESTON_ID_DEFAULTS:
58 INTERFACE_DEFAULTS[vid][pid] = ['ftdi_gpiouart']
59
60SERVO_ID_DEFAULTS.extend(RESTON_ID_DEFAULTS)
Vincent Palatin77629ac2014-03-21 09:33:13 -070061
62# Fruitpie
63FRUITPIE_ID_DEFAULTS = [(0x18d1, 0x5009)]
64for vid, pid in FRUITPIE_ID_DEFAULTS:
65 INTERFACE_DEFAULTS[vid][pid] = ['ftdi_gpiouart']
66
67SERVO_ID_DEFAULTS.extend(FRUITPIE_ID_DEFAULTS)
Todd Brochb21d8042014-05-15 12:54:54 -070068
Alec Berge7549802014-07-14 11:52:36 -070069# Plankton
70PLANKTON_ID_DEFAULTS = [(0x18d1, 0x500c)]
71for vid, pid in PLANKTON_ID_DEFAULTS:
72 INTERFACE_DEFAULTS[vid][pid] = ['ftdi_gpiouart']
73
74SERVO_ID_DEFAULTS.extend(PLANKTON_ID_DEFAULTS)
75
Todd Brochb21d8042014-05-15 12:54:54 -070076# Allow Board overrides of interfaces as we've started to overload some servo V2
77# pinout functionality. To-date just swapping EC SPI interface for USB PD MCU
78# UART
79# TODO(tbroch) See about availability of extra uart on Servo V3/beaglebone
80INTERFACE_BOARDS = collections.defaultdict(
81 lambda: collections.defaultdict(dict))
82# samus re-purposes EC SPI to be USB PD UART
83INTERFACE_BOARDS['samus'][0x18d1][0x5002] = \
84 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
85INTERFACE_BOARDS['samus'][0x18d1][0x5002][5] = 'ftdi_uart'
Rong Chang97d0e0c2015-04-24 09:02:31 +080086# oak re-purposes EC SPI to be USB PD UART
87INTERFACE_BOARDS['oak'][0x18d1][0x5002] = \
88 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
89INTERFACE_BOARDS['oak'][0x18d1][0x5002][5] = 'ftdi_uart'
Kevin K Wong6460d5a2015-06-24 18:05:11 -070090# strago re-purposes JTAG to be UART
91INTERFACE_BOARDS['strago'][0x18d1][0x5002] = \
92 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
93INTERFACE_BOARDS['strago'][0x18d1][0x5002][0] = 'ftdi_uart'
Duncan Laurie0728aa82015-10-26 13:56:08 -070094
95# Skylake boards re-purpose JTAG to be UART
96INTERFACE_BOARDS['chell'][0x18d1][0x5002] = \
97 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
98INTERFACE_BOARDS['chell'][0x18d1][0x5002][0] = 'ftdi_uart'
99INTERFACE_BOARDS['glados'][0x18d1][0x5002] = \
100 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
101INTERFACE_BOARDS['glados'][0x18d1][0x5002][0] = 'ftdi_uart'
Kevin K Wong92a07672015-06-24 22:21:31 -0700102INTERFACE_BOARDS['kunimitsu'][0x18d1][0x5002] = \
103 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
104INTERFACE_BOARDS['kunimitsu'][0x18d1][0x5002][0] = 'ftdi_uart'
Duncan Laurie0728aa82015-10-26 13:56:08 -0700105INTERFACE_BOARDS['lars'][0x18d1][0x5002] = \
106 list(INTERFACE_DEFAULTS[0x18d1][0x5002])
107INTERFACE_BOARDS['lars'][0x18d1][0x5002][0] = 'ftdi_uart'