1 /*
2 *
3 * Copyright (c) 2013, The Linux Foundation. All rights reserved.
4 * Not a Contribution.
5 *
6 * Copyright 2012 The Android Open Source Project
7 *
8 * Licensed under the Apache License, Version 2.0 (the "License"); you
9 * may not use this file except in compliance with the License. You may
10 * obtain a copy of the License at
11 *
12 * http://www.apache.org/licenses/LICENSE-2.0
13 *
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
17 * implied. See the License for the specific language governing
18 * permissions and limitations under the License.
19 *
20 */
21
22 /******************************************************************************
23 *
24 * Filename: hw_ar3k.c
25 *
26 * Description: Contains controller-specific functions, like
27 * firmware patch download
28 * low power mode operations
29 *
30 ******************************************************************************/
31 #ifdef __cplusplus
32 extern "C" {
33 #endif
34
35 #define LOG_TAG "bt_vendor"
36
37 #include <sys/uio.h>
38 #include <sys/socket.h>
39 #include <log/log.h>
40 #include <sys/types.h>
41 #include <sys/stat.h>
42 #include <signal.h>
43 #include <time.h>
44 #include <errno.h>
45 #include <fcntl.h>
46 #include <dirent.h>
47 #include <ctype.h>
48 #include <cutils/properties.h>
49 #include <stdlib.h>
50 #include <string.h>
51 #include <termios.h>
52 #include <string.h>
53 #include <unistd.h>
54
55 #include "bt_hci_bdroid.h"
56 #include "hci_uart.h"
57 #include "hw_ar3k.h"
58
59 /******************************************************************************
60 ** Variables
61 ******************************************************************************/
62 int cbstat = 0;
63 #define PATCH_LOC_STRING_LEN 8
64 char ARbyte[3];
65 char ARptr[MAX_PATCH_CMD + 1];
66 int byte_cnt;
67 int patch_count = 0;
68 char patch_loc[PATCH_LOC_STRING_LEN + 1];
69 int PSCounter=0;
70
71 uint32_t dev_type = 0;
72 uint32_t rom_version = 0;
73 uint32_t build_version = 0;
74
75 char patch_file[PATH_MAX];
76 char ps_file[PATH_MAX];
77 FILE *stream;
78 int tag_count=0;
79
80 /* for friendly debugging outpout string */
81 static char *lpm_mode[] = {
82 "UNKNOWN",
83 "disabled",
84 "enabled"
85 };
86
87 static char *lpm_state[] = {
88 "UNKNOWN",
89 "de-asserted",
90 "asserted"
91 };
92
93 static uint8_t upio_state[UPIO_MAX_COUNT];
94 struct ps_cfg_entry ps_list[MAX_TAGS];
95
96 #define PS_EVENT_LEN 100
97
98 #ifdef __cplusplus
99 }
100 #endif
101
102 #define RESERVED(p) if(p) ALOGI( "%s: reserved param", __FUNCTION__);
103
104 /*****************************************************************************
105 ** Functions
106 *****************************************************************************/
107
is_bt_soc_ath()108 int is_bt_soc_ath() {
109 int ret = 0;
110 char bt_soc_type[PROPERTY_VALUE_MAX];
111 ret = property_get("qcom.bluetooth.soc", bt_soc_type, NULL);
112 if (ret != 0) {
113 ALOGI("qcom.bluetooth.soc set to %s\n", bt_soc_type);
114 if (!strncasecmp(bt_soc_type, "ath3k", sizeof("ath3k")))
115 return 1;
116 } else {
117 ALOGI("qcom.bluetooth.soc not set, so using default.\n");
118 }
119
120 return 0;
121 }
122
123 /*
124 * Send HCI command and wait for command complete event.
125 * The event buffer has to be freed by the caller.
126 */
127
send_hci_cmd_sync(int dev,uint8_t * cmd,int len,uint8_t ** event)128 static int send_hci_cmd_sync(int dev, uint8_t *cmd, int len, uint8_t **event)
129 {
130 int err;
131 uint8_t *hci_event;
132 uint8_t pkt_type = HCI_COMMAND_PKT;
133
134 if (len == 0)
135 return len;
136
137 if (write(dev, &pkt_type, 1) != 1)
138 return -EILSEQ;
139 if (write(dev, (unsigned char *)cmd, len) != len)
140 return -EILSEQ;
141
142 hci_event = (uint8_t *)malloc(PS_EVENT_LEN);
143 if (!hci_event)
144 return -ENOMEM;
145
146 err = read_hci_event(dev, (unsigned char *)hci_event, PS_EVENT_LEN);
147 if (err > 0) {
148 *event = hci_event;
149 } else {
150 free(hci_event);
151 return -EILSEQ;
152 }
153
154 return len;
155 }
156
convert_bdaddr(char * str_bdaddr,char * bdaddr)157 static void convert_bdaddr(char *str_bdaddr, char *bdaddr)
158 {
159 char bdbyte[3];
160 char *str_byte = str_bdaddr;
161 int i, j;
162 int colon_present = 0;
163
164 if (strstr(str_bdaddr, ":"))
165 colon_present = 1;
166
167 bdbyte[2] = '\0';
168
169 /* Reverse the BDADDR to LSB first */
170 for (i = 0, j = 5; i < 6; i++, j--) {
171 bdbyte[0] = str_byte[0];
172 bdbyte[1] = str_byte[1];
173 bdaddr[j] = strtol(bdbyte, NULL, 16);
174
175 if (colon_present == 1)
176 str_byte += 3;
177 else
178 str_byte += 2;
179 }
180 }
181
uart_speed(int s)182 static int uart_speed(int s)
183 {
184 switch (s) {
185 case 9600:
186 return B9600;
187 case 19200:
188 return B19200;
189 case 38400:
190 return B38400;
191 case 57600:
192 return B57600;
193 case 115200:
194 return B115200;
195 case 230400:
196 return B230400;
197 case 460800:
198 return B460800;
199 case 500000:
200 return B500000;
201 case 576000:
202 return B576000;
203 case 921600:
204 return B921600;
205 case 1000000:
206 return B1000000;
207 case 1152000:
208 return B1152000;
209 case 1500000:
210 return B1500000;
211 case 2000000:
212 return B2000000;
213 #ifdef B2500000
214 case 2500000:
215 return B2500000;
216 #endif
217 #ifdef B3000000
218 case 3000000:
219 return B3000000;
220 #endif
221 #ifdef B3500000
222 case 3500000:
223 return B3500000;
224 #endif
225 #ifdef B4000000
226 case 4000000:
227 return B4000000;
228 #endif
229 default:
230 return B57600;
231 }
232 }
233
set_speed(int fd,struct termios * ti,int speed)234 int set_speed(int fd, struct termios *ti, int speed)
235 {
236 if (cfsetospeed(ti, uart_speed(speed)) < 0)
237 return -errno;
238
239 if (cfsetispeed(ti, uart_speed(speed)) < 0)
240 return -errno;
241
242 if (tcsetattr(fd, TCSANOW, ti) < 0)
243 return -errno;
244
245 return 0;
246 }
247
load_hci_ps_hdr(uint8_t * cmd,uint8_t ps_op,int len,int index)248 static void load_hci_ps_hdr(uint8_t *cmd, uint8_t ps_op, int len, int index)
249 {
250 hci_command_hdr *ch = (void *)cmd;
251
252 ch->opcode = htobs(cmd_opcode_pack(HCI_VENDOR_CMD_OGF,
253 HCI_PS_CMD_OCF));
254 ch->plen = len + PS_HDR_LEN;
255 cmd += HCI_COMMAND_HDR_SIZE;
256
257 cmd[0] = ps_op;
258 cmd[1] = index;
259 cmd[2] = index >> 8;
260 cmd[3] = len;
261 }
262
263
read_ps_event(uint8_t * event,uint16_t ocf)264 static int read_ps_event(uint8_t *event, uint16_t ocf)
265 {
266 hci_event_hdr *eh;
267 uint16_t opcode = htobs(cmd_opcode_pack(HCI_VENDOR_CMD_OGF, ocf));
268
269 event++;
270
271 eh = (void *)event;
272 event += HCI_EVENT_HDR_SIZE;
273
274 if (eh->evt == EVT_CMD_COMPLETE) {
275 evt_cmd_complete *cc = (void *)event;
276
277 event += EVT_CMD_COMPLETE_SIZE;
278
279 if (cc->opcode == opcode && event[0] == HCI_EV_SUCCESS)
280 return 0;
281 else
282 return -EILSEQ;
283 }
284
285 return -EILSEQ;
286 }
287
288 #define PS_WRITE 1
289 #define PS_RESET 2
290 #define WRITE_PATCH 8
291 #define ENABLE_PATCH 11
292
293 #define HCI_PS_CMD_HDR_LEN 7
294
write_cmd(int fd,uint8_t * buffer,int len)295 static int write_cmd(int fd, uint8_t *buffer, int len)
296 {
297 uint8_t *event;
298 int err;
299
300 err = send_hci_cmd_sync(fd, buffer, len, &event);
301 if (err < 0)
302 return err;
303
304 err = read_ps_event(event, HCI_PS_CMD_OCF);
305
306 free(event);
307
308 return err;
309 }
310
311 #define PS_RESET_PARAM_LEN 6
312 #define PS_RESET_CMD_LEN (HCI_PS_CMD_HDR_LEN + PS_RESET_PARAM_LEN)
313
314 #define PS_ID_MASK 0xFF
315
316 /* Sends PS commands using vendor specficic HCI commands */
write_ps_cmd(int fd,uint8_t opcode,uint32_t ps_param)317 static int write_ps_cmd(int fd, uint8_t opcode, uint32_t ps_param)
318 {
319 uint8_t cmd[HCI_MAX_CMD_SIZE];
320 uint32_t i;
321
322 switch (opcode) {
323 case ENABLE_PATCH:
324 load_hci_ps_hdr(cmd, opcode, 0, 0x00);
325
326 if (write_cmd(fd, cmd, HCI_PS_CMD_HDR_LEN) < 0)
327 return -EILSEQ;
328 break;
329
330 case PS_RESET:
331 load_hci_ps_hdr(cmd, opcode, PS_RESET_PARAM_LEN, 0x00);
332
333 cmd[7] = 0x00;
334 cmd[PS_RESET_CMD_LEN - 2] = ps_param & PS_ID_MASK;
335 cmd[PS_RESET_CMD_LEN - 1] = (ps_param >> 8) & PS_ID_MASK;
336
337 if (write_cmd(fd, cmd, PS_RESET_CMD_LEN) < 0)
338 return -EILSEQ;
339 break;
340
341 case PS_WRITE:
342 for (i = 0; i < ps_param; i++) {
343 load_hci_ps_hdr(cmd, opcode, ps_list[i].len,
344 ps_list[i].id);
345
346 memcpy(&cmd[HCI_PS_CMD_HDR_LEN], ps_list[i].data,
347 ps_list[i].len);
348
349 if (write_cmd(fd, cmd, ps_list[i].len +
350 HCI_PS_CMD_HDR_LEN) < 0)
351 return -EILSEQ;
352 }
353 break;
354 }
355
356 return 0;
357 }
358
359 #define PS_ASIC_FILE "PS_ASIC.pst"
360 #define PS_FPGA_FILE "PS_FPGA.pst"
361 #define MAXPATHLEN 4096
get_ps_file_name(uint32_t devtype,uint32_t rom_version,char * path)362 static void get_ps_file_name(uint32_t devtype, uint32_t rom_version,char *path)
363 {
364 char *filename;
365
366 if (devtype == 0xdeadc0de)
367 filename = PS_ASIC_FILE;
368 else
369 filename = PS_FPGA_FILE;
370
371 snprintf(path, MAXPATHLEN, "%s%x/%s", FW_PATH, rom_version, filename);
372 }
373
374 #define PATCH_FILE "RamPatch.txt"
375 #define FPGA_ROM_VERSION 0x99999999
376 #define ROM_DEV_TYPE 0xdeadc0de
377
get_patch_file_name(uint32_t dev_type,uint32_t rom_version,uint32_t build_version,char * path)378 static void get_patch_file_name(uint32_t dev_type, uint32_t rom_version,
379 uint32_t build_version, char *path)
380 {
381 if (rom_version == FPGA_ROM_VERSION && dev_type != ROM_DEV_TYPE
382 &&dev_type != 0 && build_version == 1)
383 path[0] = '\0';
384 else
385 snprintf(path, MAXPATHLEN, "%s%x/%s", FW_PATH, rom_version, PATCH_FILE);
386 }
387
set_cntrlr_baud(int fd,int speed)388 static int set_cntrlr_baud(int fd, int speed)
389 {
390 int baud;
391 struct timespec tm = { 0, 500000};
392 unsigned char cmd[MAX_CMD_LEN], rsp[HCI_MAX_EVENT_SIZE];
393 unsigned char *ptr = cmd + 1;
394 hci_command_hdr *ch = (void *)ptr;
395
396 cmd[0] = HCI_COMMAND_PKT;
397
398 /* set controller baud rate to user specified value */
399 ptr = cmd + 1;
400 ch->opcode = htobs(cmd_opcode_pack(HCI_VENDOR_CMD_OGF,
401 HCI_CHG_BAUD_CMD_OCF));
402 ch->plen = 2;
403 ptr += HCI_COMMAND_HDR_SIZE;
404
405 baud = speed/100;
406 ptr[0] = (char)baud;
407 ptr[1] = (char)(baud >> 8);
408
409 if (write(fd, cmd, WRITE_BAUD_CMD_LEN) != WRITE_BAUD_CMD_LEN) {
410 ALOGI("Failed to write change baud rate command");
411 return -ETIMEDOUT;
412 }
413
414 nanosleep(&tm, NULL);
415
416 if (read_hci_event(fd, rsp, sizeof(rsp)) < 0)
417 return -ETIMEDOUT;
418
419 return 0;
420 }
421
422 #define PS_UNDEF 0
423 #define PS_ID 1
424 #define PS_LEN 2
425 #define PS_DATA 3
426
427 #define PS_MAX_LEN 500
428 #define LINE_SIZE_MAX (PS_MAX_LEN * 2)
429 #define ENTRY_PER_LINE 16
430
431 #define __check_comment(buf) (((buf)[0] == '/') && ((buf)[1] == '/'))
432 #define __skip_space(str) while (*(str) == ' ') ((str)++)
433
434
435 #define __is_delim(ch) ((ch) == ':')
436 #define MAX_PREAMBLE_LEN 4
437
438 /* Parse PS entry preamble of format [X:X] for main type and subtype */
get_ps_type(char * ptr,int index,char * type,char * sub_type)439 static int get_ps_type(char *ptr, int index, char *type, char *sub_type)
440 {
441 int i;
442 int delim = false;
443
444 if (index > MAX_PREAMBLE_LEN)
445 return -EILSEQ;
446
447 for (i = 1; i < index; i++) {
448 if (__is_delim(ptr[i])) {
449 delim = true;
450 continue;
451 }
452
453 if (isalpha(ptr[i])) {
454 if (delim == false)
455 (*type) = toupper(ptr[i]);
456 else
457 (*sub_type) = toupper(ptr[i]);
458 }
459 }
460
461 return 0;
462 }
463
464 #define ARRAY 'A'
465 #define STRING 'S'
466 #define DECIMAL 'D'
467 #define BINARY 'B'
468
469 #define PS_HEX 0
470 #define PS_DEC 1
471
get_input_format(char * buf,struct ps_entry_type * format)472 static int get_input_format(char *buf, struct ps_entry_type *format)
473 {
474 char *ptr = NULL;
475 char type = '\0';
476 char sub_type = '\0';
477
478 format->type = PS_HEX;
479 format->array = true;
480
481 if (strstr(buf, "[") != buf)
482 return 0;
483
484 ptr = strstr(buf, "]");
485 if (!ptr)
486 return -EILSEQ;
487
488 if (get_ps_type(buf, ptr - buf, &type, &sub_type) < 0)
489 return -EILSEQ;
490
491 /* Check is data type is of array */
492 if (type == ARRAY || sub_type == ARRAY)
493 format->array = true;
494
495 if (type == STRING || sub_type == STRING)
496 format->array = false;
497
498 if (type == DECIMAL || type == BINARY)
499 format->type = PS_DEC;
500 else
501 format->type = PS_HEX;
502
503 return 0;
504 }
505
506
507
508 #define UNDEFINED 0xFFFF
509
read_data_in_section(char * buf,struct ps_entry_type type)510 static unsigned int read_data_in_section(char *buf, struct ps_entry_type type)
511 {
512 char *ptr = buf;
513
514 if (!buf)
515 return UNDEFINED;
516
517 if (buf == strstr(buf, "[")) {
518 ptr = strstr(buf, "]");
519 if (!ptr)
520 return UNDEFINED;
521
522 ptr++;
523 }
524
525 if (type.type == PS_HEX && type.array != true)
526 return strtol(ptr, NULL, 16);
527
528 return UNDEFINED;
529 }
530
531
532 /* Read PS entries as string, convert and add to Hex array */
update_tag_data(struct ps_cfg_entry * tag,struct tag_info * info,const char * ptr)533 static void update_tag_data(struct ps_cfg_entry *tag,
534 struct tag_info *info, const char *ptr)
535 {
536 char buf[3];
537
538 buf[2] = '\0';
539
540 strlcpy(buf, &ptr[info->char_cnt],sizeof(buf));
541 tag->data[info->byte_count] = strtol(buf, NULL, 16);
542 info->char_cnt += 3;
543 info->byte_count++;
544
545 strlcpy(buf, &ptr[info->char_cnt], sizeof(buf));
546 tag->data[info->byte_count] = strtol(buf, NULL, 16);
547 info->char_cnt += 3;
548 info->byte_count++;
549 }
550
update_char_count(const char * buf)551 static inline int update_char_count(const char *buf)
552 {
553 char *end_ptr;
554
555 if (strstr(buf, "[") == buf) {
556 end_ptr = strstr(buf, "]");
557 if (!end_ptr)
558 return 0;
559 else
560 return(end_ptr - buf) + 1;
561 }
562
563 return 0;
564 }
565
566 #define PS_HEX 0
567 #define PS_DEC 1
568
ath_parse_ps(FILE * stream)569 static int ath_parse_ps(FILE *stream)
570 {
571 char buf[LINE_SIZE_MAX + 1];
572 char *ptr;
573 uint8_t tag_cnt = 0;
574 int16_t byte_count = 0;
575 struct ps_entry_type format;
576 struct tag_info status = { 0, 0, 0, 0};
577
578 do {
579 int read_count;
580 struct ps_cfg_entry *tag;
581
582 ptr = fgets(buf, LINE_SIZE_MAX, stream);
583 if (!ptr)
584 break;
585
586 __skip_space(ptr);
587 if (__check_comment(ptr))
588 continue;
589
590 /* Lines with a '#' will be followed by new PS entry */
591 if (ptr == strstr(ptr, "#")) {
592 if (status.section != PS_UNDEF) {
593 return -EILSEQ;
594 } else {
595 status.section = PS_ID;
596 continue;
597 }
598 }
599
600 tag = &ps_list[tag_cnt];
601
602 switch (status.section) {
603 case PS_ID:
604 if (get_input_format(ptr, &format) < 0)
605 return -EILSEQ;
606
607 tag->id = read_data_in_section(ptr, format);
608 status.section = PS_LEN;
609 break;
610
611 case PS_LEN:
612 if (get_input_format(ptr, &format) < 0)
613 return -EILSEQ;
614
615 byte_count = read_data_in_section(ptr, format);
616 if (byte_count > PS_MAX_LEN)
617 return -EILSEQ;
618
619 tag->len = byte_count;
620 tag->data = (uint8_t *)malloc(byte_count);
621
622 status.section = PS_DATA;
623 status.line_count = 0;
624 break;
625
626 case PS_DATA:
627 if (status.line_count == 0)
628 if (get_input_format(ptr, &format) < 0)
629 return -EILSEQ;
630
631 __skip_space(ptr);
632
633 status.char_cnt = update_char_count(ptr);
634
635 read_count = (byte_count > ENTRY_PER_LINE) ?
636 ENTRY_PER_LINE : byte_count;
637
638 if (format.type == PS_HEX && format.array == true) {
639 while (read_count > 0) {
640 update_tag_data(tag, &status, ptr);
641 read_count -= 2;
642 }
643
644 if (byte_count > ENTRY_PER_LINE)
645 byte_count -= ENTRY_PER_LINE;
646 else
647 byte_count = 0;
648 }
649
650 status.line_count++;
651
652 if (byte_count == 0)
653 memset(&status, 0x00, sizeof(struct tag_info));
654
655 if (status.section == PS_UNDEF)
656 tag_cnt++;
657
658 if (tag_cnt == MAX_TAGS)
659 return -EILSEQ;
660 break;
661 }
662 } while (ptr);
663
664 return tag_cnt;
665 }
666
667 #define PS_RAM_SIZE 2048
668
ps_config_download(int fd,int tag_count)669 static int ps_config_download(int fd, int tag_count)
670 {
671 if (write_ps_cmd(fd, PS_RESET, PS_RAM_SIZE) < 0)
672 return -1;
673
674 if (tag_count > 0)
675 if (write_ps_cmd(fd, PS_WRITE, tag_count) < 0)
676 return -1;
677 return 0;
678 }
679
write_bdaddr(int pConfig,char * bdaddr)680 static int write_bdaddr(int pConfig, char *bdaddr)
681 {
682 uint8_t *event;
683 int err;
684 uint8_t cmd[13];
685 uint8_t *ptr = cmd;
686 hci_command_hdr *ch = (void *)cmd;
687
688 memset(cmd, 0, sizeof(cmd));
689
690 ch->opcode = htobs(cmd_opcode_pack(HCI_VENDOR_CMD_OGF,
691 HCI_PS_CMD_OCF));
692 ch->plen = 10;
693 ptr += HCI_COMMAND_HDR_SIZE;
694
695 ptr[0] = 0x01;
696 ptr[1] = 0x01;
697 ptr[2] = 0x00;
698 ptr[3] = 0x06;
699
700 convert_bdaddr(bdaddr, (char *)&ptr[4]);
701
702 err = send_hci_cmd_sync(pConfig, cmd, sizeof(cmd), &event);
703 if (err < 0)
704 return err;
705
706 err = read_ps_event(event, HCI_PS_CMD_OCF);
707
708 free(event);
709
710 return err;
711 }
712
write_bdaddr_from_file(int rom_version,int fd)713 static void write_bdaddr_from_file(int rom_version, int fd)
714 {
715 FILE *stream;
716 char bdaddr[PATH_MAX];
717 char bdaddr_file[PATH_MAX];
718
719 snprintf(bdaddr_file, MAXPATHLEN, "%s%x/%s",
720 FW_PATH, rom_version, BDADDR_FILE);
721
722 stream = fopen(bdaddr_file, "r");
723 if (!stream)
724 return;
725
726 if (fgets(bdaddr, PATH_MAX - 1, stream))
727 write_bdaddr(fd, bdaddr);
728
729 fclose(stream);
730 }
731
732 #define HCI_EVT_CMD_CMPL_OPCODE 3
733 #define HCI_EVT_CMD_CMPL_STATUS_RET_BYTE 5
734
baswap(bdaddr_t * dst,const bdaddr_t * src)735 void baswap(bdaddr_t *dst, const bdaddr_t *src)
736 {
737 register unsigned char *d = (unsigned char *) dst;
738 register const unsigned char *s = (const unsigned char *) src;
739 register int i;
740 for (i = 0; i < 6; i++)
741 d[i] = s[5-i];
742 }
743
744
str2ba(const char * str,bdaddr_t * ba)745 int str2ba(const char *str, bdaddr_t *ba)
746 {
747 uint8_t b[6];
748 const char *ptr = str;
749 int i;
750
751 for (i = 0; i < 6; i++) {
752 b[i] = (uint8_t) strtol(ptr, NULL, 16);
753 ptr = strchr(ptr, ':');
754 if (i != 5 && !ptr)
755 ptr = ":00:00:00:00:00";
756 ptr++;
757 }
758 baswap(ba, (bdaddr_t *) b);
759 return 0;
760 }
761
762 #define DEV_REGISTER 0x4FFC
763 #define GET_DEV_TYPE_OCF 0x05
764
get_device_type(int dev,uint32_t * code)765 static int get_device_type(int dev, uint32_t *code)
766 {
767 uint8_t cmd[8] = {0};
768 uint8_t *event;
769 uint32_t reg;
770 int err;
771 uint8_t *ptr = cmd;
772 hci_command_hdr *ch = (void *)cmd;
773
774 ch->opcode = htobs(cmd_opcode_pack(HCI_VENDOR_CMD_OGF,
775 GET_DEV_TYPE_OCF));
776 ch->plen = 5;
777 ptr += HCI_COMMAND_HDR_SIZE;
778
779 ptr[0] = (uint8_t)DEV_REGISTER;
780 ptr[1] = (uint8_t)DEV_REGISTER >> 8;
781 ptr[2] = (uint8_t)DEV_REGISTER >> 16;
782 ptr[3] = (uint8_t)DEV_REGISTER >> 24;
783 ptr[4] = 0x04;
784
785 err = send_hci_cmd_sync(dev, cmd, sizeof(cmd), &event);
786 if (err < 0)
787 return err;
788
789 err = read_ps_event(event, GET_DEV_TYPE_OCF);
790 if (err < 0)
791 goto cleanup;
792
793 reg = event[10];
794 reg = (reg << 8) | event[9];
795 reg = (reg << 8) | event[8];
796 reg = (reg << 8) | event[7];
797 *code = reg;
798
799 cleanup:
800 free(event);
801
802 return err;
803 }
804
805 #define GET_VERSION_OCF 0x1E
806
read_ath3k_version(int pConfig,uint32_t * rom_version,uint32_t * build_version)807 static int read_ath3k_version(int pConfig, uint32_t *rom_version,
808 uint32_t *build_version)
809 {
810 uint8_t cmd[3] = {0};
811 uint8_t *event;
812 int err;
813 int status;
814 hci_command_hdr *ch = (void *)cmd;
815
816 ch->opcode = htobs(cmd_opcode_pack(HCI_VENDOR_CMD_OGF,
817 GET_VERSION_OCF));
818 ch->plen = 0;
819
820 err = send_hci_cmd_sync(pConfig, cmd, sizeof(cmd), &event);
821 if (err < 0)
822 return err;
823
824 err = read_ps_event(event, GET_VERSION_OCF);
825 if (err < 0)
826 goto cleanup;
827
828 status = event[10];
829 status = (status << 8) | event[9];
830 status = (status << 8) | event[8];
831 status = (status << 8) | event[7];
832 *rom_version = status;
833
834 status = event[14];
835 status = (status << 8) | event[13];
836 status = (status << 8) | event[12];
837 status = (status << 8) | event[11];
838 *build_version = status;
839
840 cleanup:
841 free(event);
842
843 return err;
844 }
845
846 #define VERIFY_CRC 9
847 #define PS_REGION 1
848 #define PATCH_REGION 2
849
get_ath3k_crc(int dev)850 static int get_ath3k_crc(int dev)
851 {
852 uint8_t cmd[7] = {0};
853 uint8_t *event;
854 int err;
855
856 load_hci_ps_hdr(cmd, VERIFY_CRC, 0, PS_REGION | PATCH_REGION);
857
858 err = send_hci_cmd_sync(dev, cmd, sizeof(cmd), &event);
859 if (err < 0)
860 return err;
861 /* Send error code if CRC check patched */
862 if (read_ps_event(event, HCI_PS_CMD_OCF) >= 0)
863 err = -EILSEQ;
864
865 free(event);
866
867 return err;
868 }
869
870 #define SET_PATCH_RAM_ID 0x0D
871 #define SET_PATCH_RAM_CMD_SIZE 11
872 #define ADDRESS_LEN 4
set_patch_ram(int dev,char * patch_loc,int len)873 static int set_patch_ram(int dev, char *patch_loc, int len)
874 {
875 int err;
876 uint8_t cmd[20] = {0};
877 int i, j;
878 char loc_byte[3];
879 uint8_t *event;
880 uint8_t *loc_ptr = &cmd[7];
881
882 RESERVED(len);
883
884 if (!patch_loc)
885 return -1;
886
887 loc_byte[2] = '\0';
888
889 load_hci_ps_hdr(cmd, SET_PATCH_RAM_ID, ADDRESS_LEN, 0);
890
891 for (i = 0, j = 3; i < 4; i++, j--) {
892 loc_byte[0] = patch_loc[0];
893 loc_byte[1] = patch_loc[1];
894 loc_ptr[j] = strtol(loc_byte, NULL, 16);
895 patch_loc += 2;
896 }
897
898 err = send_hci_cmd_sync(dev, cmd, SET_PATCH_RAM_CMD_SIZE, &event);
899 if (err < 0)
900 return err;
901
902 err = read_ps_event(event, HCI_PS_CMD_OCF);
903
904 free(event);
905
906 return err;
907 }
908
909 #define PATCH_LOC_KEY "DA:"
910 #define PATCH_LOC_STRING_LEN 8
ps_patch_download(int fd,FILE * stream)911 static int ps_patch_download(int fd, FILE *stream)
912 {
913 char byte[3];
914 char ptr[MAX_PATCH_CMD + 1];
915 int byte_cnt;
916 int patch_count = 0;
917 char patch_loc[PATCH_LOC_STRING_LEN + 1];
918
919 byte[2] = '\0';
920
921 while (fgets(ptr, MAX_PATCH_CMD, stream)) {
922 if (strlen(ptr) <= 1)
923 continue;
924 else if (strstr(ptr, PATCH_LOC_KEY) == ptr) {
925 strlcpy(patch_loc, &ptr[sizeof(PATCH_LOC_KEY) - 1],
926 PATCH_LOC_STRING_LEN);
927 if (set_patch_ram(fd, patch_loc, sizeof(patch_loc)) < 0)
928 return -1;
929 } else if (isxdigit(ptr[0]))
930 break;
931 else
932 return -1;
933 }
934
935 byte_cnt = strtol(ptr, NULL, 16);
936
937 while (byte_cnt > 0) {
938 int i;
939 uint8_t cmd[HCI_MAX_CMD_SIZE] = {0};
940 struct patch_entry patch;
941
942 if (byte_cnt > MAX_PATCH_CMD)
943 patch.len = MAX_PATCH_CMD;
944 else
945 patch.len = byte_cnt;
946
947 for (i = 0; i < patch.len; i++) {
948 if (!fgets(byte, 3, stream))
949 return -1;
950
951 patch.data[i] = strtoul(byte, NULL, 16);
952 }
953
954 load_hci_ps_hdr(cmd, WRITE_PATCH, patch.len, patch_count);
955 memcpy(&cmd[HCI_PS_CMD_HDR_LEN], patch.data, patch.len);
956
957 if (write_cmd(fd, cmd, patch.len + HCI_PS_CMD_HDR_LEN) < 0)
958 return -1;
959
960 patch_count++;
961 byte_cnt = byte_cnt - MAX_PATCH_CMD;
962 }
963
964 if (write_ps_cmd(fd, ENABLE_PATCH, 0) < 0)
965 return -1;
966
967 return patch_count;
968 }
969
ath_ps_download(int fd)970 static int ath_ps_download(int fd)
971 {
972 int err = 0;
973 int tag_count;
974 int patch_count = 0;
975 uint32_t rom_version = 0;
976 uint32_t build_version = 0;
977 uint32_t dev_type = 0;
978 char patch_file[PATH_MAX];
979 char ps_file[PATH_MAX];
980 FILE *stream;
981
982 /*
983 * Verfiy firmware version. depending on it select the PS
984 * config file to download.
985 */
986 if (get_device_type(fd, &dev_type) < 0) {
987 err = -EILSEQ;
988 goto download_cmplete;
989 }
990
991 if (read_ath3k_version(fd, &rom_version, &build_version) < 0) {
992 err = -EILSEQ;
993 goto download_cmplete;
994 }
995
996 /* Do not download configuration if CRC passes */
997 if (get_ath3k_crc(fd) < 0) {
998 err = 0;
999 goto download_cmplete;
1000 }
1001
1002 get_ps_file_name(dev_type, rom_version, ps_file);
1003 get_patch_file_name(dev_type, rom_version, build_version, patch_file);
1004
1005 stream = fopen(ps_file, "r");
1006 if (!stream) {
1007 ALOGI("firmware file open error:%s, ver:%x\n",ps_file, rom_version);
1008 if (rom_version == 0x1020201)
1009 err = 0;
1010 else
1011 err = -EILSEQ;
1012 goto download_cmplete;
1013 }
1014 tag_count = ath_parse_ps(stream);
1015
1016 fclose(stream);
1017
1018 if (tag_count < 0) {
1019 err = -EILSEQ;
1020 goto download_cmplete;
1021 }
1022
1023 /*
1024 * It is not necessary that Patch file be available,
1025 * continue with PS Operations if patch file is not available.
1026 */
1027 if (patch_file[0] == '\0')
1028 err = 0;
1029
1030 stream = fopen(patch_file, "r");
1031 if (!stream)
1032 err = 0;
1033 else {
1034 patch_count = ps_patch_download(fd, stream);
1035 fclose(stream);
1036
1037 if (patch_count < 0) {
1038 err = -EILSEQ;
1039 goto download_cmplete;
1040 }
1041 }
1042
1043 err = ps_config_download(fd, tag_count);
1044
1045 download_cmplete:
1046 if (!err)
1047 write_bdaddr_from_file(rom_version, fd);
1048
1049 return err;
1050 }
1051
ath3k_init(int fd,int speed,int init_speed,char * bdaddr,struct termios * ti)1052 int ath3k_init(int fd, int speed, int init_speed, char *bdaddr, struct termios *ti)
1053 {
1054 ALOGI(" %s ", __FUNCTION__);
1055
1056 int r;
1057 int err = 0;
1058 struct timespec tm = { 0, 500000};
1059 unsigned char cmd[MAX_CMD_LEN] = {0};
1060 unsigned char rsp[HCI_MAX_EVENT_SIZE];
1061 unsigned char *ptr = cmd + 1;
1062 hci_command_hdr *ch = (void *)ptr;
1063 int flags = 0;
1064
1065 if (ioctl(fd, TIOCMGET, &flags) < 0) {
1066 ALOGI("TIOCMGET failed in init\n");
1067 return -1;
1068 }
1069 flags |= TIOCM_RTS;
1070 if (ioctl(fd, TIOCMSET, &flags) < 0) {
1071 ALOGI("TIOCMSET failed in init: HW Flow-on error\n");
1072 return -1;
1073 }
1074
1075 /* set both controller and host baud rate to maximum possible value */
1076 err = set_cntrlr_baud(fd, speed);
1077 ALOGI("set_cntrlr_baud : ret:%d \n", err);
1078 if (err < 0)
1079 return err;
1080
1081 err = set_speed(fd, ti, speed);
1082 if (err < 0) {
1083 ALOGI("Can't set required baud rate");
1084 return err;
1085 }
1086
1087 /* Download PS and patch */
1088 r = ath_ps_download(fd);
1089 if (r < 0) {
1090 ALOGI("Failed to Download configuration");
1091 err = -ETIMEDOUT;
1092 goto failed;
1093 }
1094
1095 ALOGI("ath_ps_download is done\n");
1096
1097 cmd[0] = HCI_COMMAND_PKT;
1098 /* Write BDADDR */
1099 if (bdaddr) {
1100 ch->opcode = htobs(cmd_opcode_pack(HCI_VENDOR_CMD_OGF,
1101 HCI_PS_CMD_OCF));
1102 ch->plen = 10;
1103 ptr += HCI_COMMAND_HDR_SIZE;
1104
1105 ptr[0] = 0x01;
1106 ptr[1] = 0x01;
1107 ptr[2] = 0x00;
1108 ptr[3] = 0x06;
1109 str2ba(bdaddr, (bdaddr_t *)(ptr + 4));
1110
1111 if (write(fd, cmd, WRITE_BDADDR_CMD_LEN) !=
1112 WRITE_BDADDR_CMD_LEN) {
1113 ALOGI("Failed to write BD_ADDR command\n");
1114 err = -ETIMEDOUT;
1115 goto failed;
1116 }
1117
1118 if (read_hci_event(fd, rsp, sizeof(rsp)) < 0) {
1119 ALOGI("Failed to set BD_ADDR\n");
1120 err = -ETIMEDOUT;
1121 goto failed;
1122 }
1123 }
1124
1125 /* Send HCI Reset */
1126 cmd[1] = 0x03;
1127 cmd[2] = 0x0C;
1128 cmd[3] = 0x00;
1129
1130 r = write(fd, cmd, 4);
1131 if (r != 4) {
1132 err = -ETIMEDOUT;
1133 goto failed;
1134 }
1135
1136 nanosleep(&tm, NULL);
1137 if (read_hci_event(fd, rsp, sizeof(rsp)) < 0) {
1138 err = -ETIMEDOUT;
1139 goto failed;
1140 }
1141
1142 ALOGI("HCI Reset is done\n");
1143 err = set_cntrlr_baud(fd, speed);
1144 if (err < 0)
1145 ALOGI("set_cntrlr_baud0:%d,%d\n", speed, err);
1146
1147 failed:
1148 if (err < 0) {
1149 set_cntrlr_baud(fd, init_speed);
1150 set_speed(fd, ti, init_speed);
1151 }
1152
1153 return err;
1154
1155 }
1156 #define BTPROTO_HCI 1
1157
1158 /* Open HCI device.
1159 * Returns device descriptor (dd). */
hci_open_dev(int dev_id)1160 int hci_open_dev(int dev_id)
1161 {
1162 struct sockaddr_hci a;
1163 int dd, err;
1164
1165 /* Create HCI socket */
1166 dd = socket(AF_BLUETOOTH, SOCK_RAW, BTPROTO_HCI);
1167 if (dd < 0)
1168 return dd;
1169
1170 /* Bind socket to the HCI device */
1171 memset(&a, 0, sizeof(a));
1172 a.hci_family = AF_BLUETOOTH;
1173 a.hci_dev = dev_id;
1174 if (bind(dd, (struct sockaddr *) &a, sizeof(a)) < 0)
1175 goto failed;
1176
1177 return dd;
1178
1179 failed:
1180 err = errno;
1181 close(dd);
1182 errno = err;
1183
1184 return -1;
1185 }
1186
hci_close_dev(int dd)1187 int hci_close_dev(int dd)
1188 {
1189 return close(dd);
1190 }
1191
1192 /* HCI functions that require open device
1193 * dd - Device descriptor returned by hci_open_dev. */
1194
hci_send_cmd(int dd,uint16_t ogf,uint16_t ocf,uint8_t plen,void * param)1195 int hci_send_cmd(int dd, uint16_t ogf, uint16_t ocf, uint8_t plen, void *param)
1196 {
1197 uint8_t type = HCI_COMMAND_PKT;
1198 hci_command_hdr hc;
1199 struct iovec iv[3];
1200 int ivn;
1201
1202 hc.opcode = htobs(cmd_opcode_pack(ogf, ocf));
1203 hc.plen= plen;
1204
1205 iv[0].iov_base = &type;
1206 iv[0].iov_len = 1;
1207 iv[1].iov_base = &hc;
1208 iv[1].iov_len = HCI_COMMAND_HDR_SIZE;
1209 ivn = 2;
1210
1211 if (plen) {
1212 iv[2].iov_base = param;
1213 iv[2].iov_len = plen;
1214 ivn = 3;
1215 }
1216
1217 while (writev(dd, iv, ivn) < 0) {
1218 if (errno == EAGAIN || errno == EINTR)
1219 continue;
1220 return -1;
1221 }
1222 return 0;
1223 }
1224
1225 #define HCI_SLEEP_CMD_OCF 0x04
1226 #define TIOCSETD 0x5423
1227 #define HCIUARTSETFLAGS _IOW('U', 204, int)
1228 #define HCIUARTSETPROTO _IOW('U', 200, int)
1229 #define HCIUARTGETDEVICE _IOW('U', 202, int)
1230 /*
1231 * Atheros AR300x specific initialization post callback
1232 */
ath3k_post(int fd,int pm)1233 int ath3k_post(int fd, int pm)
1234 {
1235 int dev_id, dd;
1236 struct timespec tm = { 0, 50000};
1237
1238 sleep(1);
1239
1240 dev_id = ioctl(fd, HCIUARTGETDEVICE, 0);
1241 if (dev_id < 0) {
1242 perror("cannot get device id");
1243 return dev_id;
1244 }
1245
1246 dd = hci_open_dev(dev_id);
1247 if (dd < 0) {
1248 perror("HCI device open failed");
1249 return dd;
1250 }
1251
1252 if (ioctl(dd, HCIDEVUP, dev_id) < 0 && errno != EALREADY) {
1253 perror("hci down:Power management Disabled");
1254 hci_close_dev(dd);
1255 return -1;
1256 }
1257
1258 /* send vendor specific command with Sleep feature Enabled */
1259 if (hci_send_cmd(dd, OGF_VENDOR_CMD, HCI_SLEEP_CMD_OCF, 1, &pm) < 0)
1260 perror("PM command failed, power management Disabled");
1261
1262 nanosleep(&tm, NULL);
1263 hci_close_dev(dd);
1264
1265 return 0;
1266 }
1267
1268
1269
1270 #define FLOW_CTL 0x0001
1271 #define ENABLE_PM 1
1272 #define DISABLE_PM 0
1273
1274 /* Initialize UART driver */
init_uart(char * dev,struct uart_t * u,int send_break,int raw)1275 static int init_uart(char *dev, struct uart_t *u, int send_break, int raw)
1276 {
1277 ALOGI(" %s ", __FUNCTION__);
1278
1279 struct termios ti;
1280
1281 int i, fd;
1282 unsigned long flags = 0;
1283
1284 if (raw)
1285 flags |= 1 << HCI_UART_RAW_DEVICE;
1286
1287
1288 fd = open(dev, O_RDWR | O_NOCTTY);
1289
1290 if (fd < 0) {
1291 ALOGI("Can't open serial port");
1292 return -1;
1293 }
1294
1295
1296 tcflush(fd, TCIOFLUSH);
1297
1298 if (tcgetattr(fd, &ti) < 0) {
1299 ALOGI("Can't get port settings: %d\n", errno);
1300 return -1;
1301 }
1302
1303 cfmakeraw(&ti);
1304
1305 ti.c_cflag |= CLOCAL;
1306 if (u->flags & FLOW_CTL)
1307 ti.c_cflag |= CRTSCTS;
1308 else
1309 ti.c_cflag &= ~CRTSCTS;
1310
1311 if (tcsetattr(fd, TCSANOW, &ti) < 0) {
1312 ALOGI("Can't set port settings");
1313 return -1;
1314 }
1315
1316 if (set_speed(fd, &ti, u->init_speed) < 0) {
1317 ALOGI("Can't set initial baud rate");
1318 return -1;
1319 }
1320
1321 tcflush(fd, TCIOFLUSH);
1322
1323 if (send_break) {
1324 tcsendbreak(fd, 0);
1325 usleep(500000);
1326 }
1327
1328 ath3k_init(fd,u->speed,u->init_speed,u->bdaddr, &ti);
1329
1330 ALOGI("Device setup complete\n");
1331
1332
1333 tcflush(fd, TCIOFLUSH);
1334
1335 // Set actual baudrate
1336 /*
1337 if (set_speed(fd, &ti, u->speed) < 0) {
1338 perror("Can't set baud rate");
1339 return -1;
1340 }
1341
1342 i = N_HCI;
1343 if (ioctl(fd, TIOCSETD, &i) < 0) {
1344 perror("Can't set line discipline");
1345 return -1;
1346 }
1347
1348 if (flags && ioctl(fd, HCIUARTSETFLAGS, flags) < 0) {
1349 perror("Can't set UART flags");
1350 return -1;
1351 }
1352
1353 if (ioctl(fd, HCIUARTSETPROTO, u->proto) < 0) {
1354 perror("Can't set device");
1355 return -1;
1356 }
1357
1358 #if !defined(SW_BOARD_HAVE_BLUETOOTH_RTK)
1359 ath3k_post(fd, u->pm);
1360 #endif
1361 */
1362
1363 return fd;
1364 }
1365
1366
hw_config_ath3k(char * port_name)1367 int hw_config_ath3k(char *port_name)
1368 {
1369 ALOGI(" %s ", __FUNCTION__);
1370 PSCounter=0;
1371 struct sigaction sa;
1372 struct uart_t u ;
1373 int n=0,send_break=0,raw=0;
1374
1375 memset(&u, 0, sizeof(u));
1376 u.speed =3000000;
1377 u.init_speed =115200;
1378 u.flags |= FLOW_CTL;
1379 u.pm = DISABLE_PM;
1380
1381 n = init_uart(port_name, &u, send_break, raw);
1382 if (n < 0) {
1383 ALOGI("Can't initialize device");
1384 }
1385
1386 return n;
1387 }
1388
lpm_set_ar3k(uint8_t pio,uint8_t action,uint8_t polarity)1389 void lpm_set_ar3k(uint8_t pio, uint8_t action, uint8_t polarity)
1390 {
1391 int rc;
1392 int fd = -1;
1393 char buffer;
1394
1395 ALOGI("lpm mode: %d action: %d", pio, action);
1396
1397 RESERVED(polarity);
1398
1399 switch (pio)
1400 {
1401 case UPIO_LPM_MODE:
1402 if (upio_state[UPIO_LPM_MODE] == action)
1403 {
1404 ALOGI("LPM is %s already", lpm_mode[action]);
1405 return;
1406 }
1407
1408 fd = open(VENDOR_LPM_PROC_NODE, O_WRONLY);
1409
1410 if (fd < 0)
1411 {
1412 ALOGE("upio_set : open(%s) for write failed: %s (%d)",
1413 VENDOR_LPM_PROC_NODE, strerror(errno), errno);
1414 return;
1415 }
1416
1417 if (action == UPIO_ASSERT)
1418 {
1419 buffer = '1';
1420 }
1421 else
1422 {
1423 buffer = '0';
1424 }
1425
1426 if (write(fd, &buffer, 1) < 0)
1427 {
1428 ALOGE("upio_set : write(%s) failed: %s (%d)",
1429 VENDOR_LPM_PROC_NODE, strerror(errno),errno);
1430 }
1431 else
1432 {
1433 upio_state[UPIO_LPM_MODE] = action;
1434 ALOGI("LPM is set to %s", lpm_mode[action]);
1435 }
1436
1437 if (fd >= 0)
1438 close(fd);
1439
1440 break;
1441
1442 case UPIO_BT_WAKE:
1443 /* UPIO_DEASSERT should be allowed because in Rx case assert occur
1444 * from the remote side where as deassert will be initiated from Host
1445 */
1446 if ((action == UPIO_ASSERT) && (upio_state[UPIO_BT_WAKE] == action))
1447 {
1448 ALOGI("BT_WAKE is %s already", lpm_state[action]);
1449
1450 return;
1451 }
1452
1453 if (action == UPIO_DEASSERT)
1454 buffer = '0';
1455 else
1456 buffer = '1';
1457
1458 fd = open(VENDOR_BTWRITE_PROC_NODE, O_WRONLY);
1459
1460 if (fd < 0)
1461 {
1462 ALOGE("upio_set : open(%s) for write failed: %s (%d)",
1463 VENDOR_BTWRITE_PROC_NODE, strerror(errno), errno);
1464 return;
1465 }
1466
1467 if (write(fd, &buffer, 1) < 0)
1468 {
1469 ALOGE("upio_set : write(%s) failed: %s (%d)",
1470 VENDOR_BTWRITE_PROC_NODE, strerror(errno),errno);
1471 }
1472 else
1473 {
1474 upio_state[UPIO_BT_WAKE] = action;
1475 ALOGI("BT_WAKE is set to %s", lpm_state[action]);
1476 }
1477
1478 ALOGI("proc btwrite assertion");
1479
1480 if (fd >= 0)
1481 close(fd);
1482
1483 break;
1484
1485 case UPIO_HOST_WAKE:
1486 ALOGI("upio_set: UPIO_HOST_WAKE");
1487 break;
1488 }
1489
1490 }
1491