1# External CEC adapter
2
3## USB - CEC Adapter from Pulse-Eight
4
5![Picture of USB - CEC Adapter](https://www.pulse-eight.com/generated-assets/products/0000237_555.jpeg)
6
7## Get the hardware
8
9*   [Order from Pulse-Eight](https://www.pulse-eight.com/p/104/usb-hdmi-cec-adapter#)
10*   [Pulse-Eight USB CEC adapter on Amazon](https://www.amazon.com/s/ref=nb_sb_ss_i_1_22?url=search-alias%3Daps&field-keywords=pulse+eight+usb+cec+adapter&sprefix=usb+cec+adapter+pulse+%2Caps%2C218&crid=UK4LY390M5H2)
11
12## Get the software {#software}
13
141.  Connect "TV" port on the adapter to your TV
152.  Connect USB mini port to you computer
163.  Install the cec-client
17
18    *   Linux
19
20    ```shell
21    sudo apt-get install cec-utils
22    ```
23
24    *   macOS (using [MacPorts](https://guide.macports.org/#installing))
25
26    ```shell
27     sudo /opt/local/bin/port install libcec
28    ```
29
304.  run the client
31
32    ```shell
33    $ cec-client
34    No device type given. Using 'recording device'
35    CEC Parser created - libCEC version 4.0.2
36    no serial port given. trying autodetect:
37     path:     /dev/cu.usbmodemv1
38     com port: /dev/cu.usbmodemv1
39
40    opening a connection to the CEC adapter...
41    DEBUG:   [               1] Broadcast (F): osd name set to 'Broadcast'
42    DEBUG:   [               3] connection opened, clearing any previous input     and waiting for active transmissions to end before starting
43    DEBUG:   [              10] communication thread started
44    DEBUG:   [              70] turning controlled mode on
45    NOTICE:  [             255] connection opened
46    DEBUG:   [             255] processor thread started
47    DEBUG:   [             255] << Broadcast (F) -> TV (0): POLL
48    TRAFFIC: [             255] << f0
49    DEBUG:   [             255] setting the line timeout to 3
50    DEBUG:   [             403] >> POLL sent
51    DEBUG:   [             403] TV (0): device status changed into 'present'
52    ```
53
54## Add timestamps
55
56Use the `ts` command to add timestamps.
57
58```shell
59$ cec-client  | ts
60Nov 18 16:15:46 No device type given. Using 'recording device'
61Nov 18 16:15:46 CEC Parser created - libCEC version 4.0.4
62Nov 18 16:15:46 no serial port given. trying autodetect:
63Nov 18 16:15:46  path:     /sys/devices/pci0000:00/0000:00:14.0/usb2/2-9
64Nov 18 16:15:46  com port: /dev/ttyACM0
65Nov 18 16:15:46
66Nov 18 16:15:46 opening a connection to the CEC adapter...
67Nov 18 16:15:46 DEBUG:   [             386] Broadcast (F): osd name set to 'Broadcast'
68```
69
70### ts is part of the moreutils package
71
72```shell
73sudo apt-get install moreutils
74```
75
76## cheat sheets
77
78*   Show all connected devices
79
80    ```shell
81    $ echo scan | cec-client -s -d 1
82
83    ```
84
85## Available Commands
86
87[tx] \{bytes\}
88:   transfer bytes over the CEC line.
89
90[txn] \{bytes\}
91:   transfer bytes but don't wait for transmission ACK.
92
93[on] \{address\}
94:   power on the device with the given logical address.
95
96[standby] \{address\}
97:   put the device with the given address in standby mode.
98
99[la] \{logical address\}
100:   change the logical address of the CEC adapter.
101
102[p] \{device\} \{port\}
103:   change the HDMI port number of the CEC adapter.
104
105[pa] \{physical address\}
106:   change the physical address of the CEC adapter.
107
108[as]
109:   make the CEC adapter the active source.
110
111[is]
112:   mark the CEC adapter as inactive source.
113
114[osd] \{addr\} \{string\}
115:   set OSD message on the specified device.
116
117[ver] \{addr\}
118:   get the CEC version of the specified device.
119
120[ven] \{addr\}
121:   get the vendor ID of the specified device.
122
123[lang] \{addr\}
124:   get the menu language of the specified device.
125
126[pow] \{addr\}
127:   get the power status of the specified device.
128
129[name] \{addr\}
130:   get the OSD name of the specified device.
131
132[poll] \{addr\}
133:   poll the specified device.
134
135[lad]
136:   lists active devices on the bus
137
138[ad] \{addr\}
139:   checks whether the specified device is active.
140
141[at] \{type\}
142:   checks whether the specified device type is active.
143
144[sp] \{addr\}
145:   makes the specified physical address active.
146
147[spl] \{addr\}
148:   makes the specified logical address active.
149
150[volup]
151:   send a volume up command to the amp if present
152
153[voldown]
154:   send a volume down command to the amp if present
155
156[mute]
157:   send a mute/unmute command to the amp if present
158
159[self]
160:   show the list of addresses controlled by libCEC
161
162[scan]
163:   scan the CEC bus and display device info
164
165## Sending Remote Control Events
166
167You can send CEC remote events using the `tx` command above. The format is as
168follows:
169
170```
171tx <source id><destination id>:<command id>:<param value>
172```
173
174where all of the above parameters should be filled in with a single HEX digit
175(except `<command id>`, which requires 2 digits). Here, we want to send commands
176to the Android TV, so we will place its ID in `<destination id>`. The scan
177command above will give you the IDs for each device that the CEC adapter is
178aware of.
179
180In the examples below the DUT is a CEC player device with a logical address of
1814. Here are some useful commands to execute remote actions:
182
183*   Press home
184
185    ```
186    tx 04:44:09
187    ```
188
189*   Press select
190
191    ```
192    tx 04:44:00
193    ```
194
195*   Press d-pad up
196
197    ```
198    tx 04:44:01
199    ```
200
201*   Press d-pad down
202
203    ```
204    tx 04:44:02
205    ```
206
207*   Press d-pad left
208
209    ```
210    tx 04:44:03
211    ```
212
213*   Press d-pad right
214
215    ```
216    tx 04:44:04
217    ```
218
219You can check out [https://www.cec-o-matic.com/](https]://www.cec-o-matic.com/)
220for more info on formatting your request and a full list of commands and their
221respective parameters.
222