summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSehong Na <sehong.na@samsung.com>2014-05-31 12:30:44 +0900
committerSehong Na <sehong.na@samsung.com>2014-05-31 12:30:44 +0900
commit8e7b03dbe514528edce65c10de370130ea298293 (patch)
tree0b273da6a54dd89065aa1250334949b0d3a73f55
downloadbluetooth-firmware-bcm-2.3a_release.tar.gz
bluetooth-firmware-bcm-2.3a_release.tar.bz2
bluetooth-firmware-bcm-2.3a_release.zip
-rw-r--r--mobile/AUTHORS2
-rw-r--r--mobile/CMakeLists.txt12
-rw-r--r--mobile/LICENSE.APLv2203
-rw-r--r--mobile/LICENSE.Broadcom64
-rw-r--r--mobile/NOTICE10
-rw-r--r--mobile/bluetooth-firmware-bcm.manifest8
-rw-r--r--mobile/debian/bluetooth-firmware-bcm.install2
-rw-r--r--mobile/debian/bluetooth-firmware-bcm.postinst.in10
-rwxr-xr-xmobile/debian/changelog35
-rw-r--r--mobile/debian/compat1
-rw-r--r--mobile/debian/control25
-rwxr-xr-xmobile/debian/rules112
-rw-r--r--mobile/firmware/BCM4330B1_002.001.003.0221.0265.hcdbin0 -> 32195 bytes
-rw-r--r--mobile/firmware/BCM4334B0_002.001.013.0079.0081.hcdbin0 -> 29265 bytes
-rwxr-xr-xmobile/firmware/CMakeLists.txt3
-rwxr-xr-xmobile/scripts/CMakeLists.txt5
-rwxr-xr-xmobile/scripts/bt-dev-end.sh32
-rwxr-xr-xmobile/scripts/bt-dev-start-c210.sh83
-rwxr-xr-xmobile/scripts/bt-dev-start-e4412.sh92
-rwxr-xr-xmobile/scripts/bt-set-addr.sh16
-rw-r--r--mobile/set-address/CMakeLists.txt21
-rw-r--r--mobile/set-address/setbd.c186
-rw-r--r--mobile/tools/CMakeLists.txt25
-rw-r--r--mobile/tools/bcmtool_4330b1.c1034
-rw-r--r--packaging/bluetooth-firmware-bcm.spec143
-rw-r--r--wearable/AUTHORS4
-rw-r--r--wearable/CMakeLists.txt12
-rw-r--r--wearable/LICENSE.APLv2204
-rw-r--r--wearable/LICENSE.Broadcom64
-rw-r--r--wearable/NOTICE10
-rw-r--r--wearable/bluetooth-firmware-bcm.manifest8
-rw-r--r--wearable/debian/bluetooth-firmware-bcm-c210.install3
-rw-r--r--wearable/debian/bluetooth-firmware-bcm-c210.postinst.in12
-rw-r--r--wearable/debian/bluetooth-firmware-bcm-e4412.install3
-rw-r--r--wearable/debian/bluetooth-firmware-bcm-e4412.postinst.in12
-rw-r--r--wearable/debian/changelog127
-rw-r--r--wearable/debian/compat1
-rw-r--r--wearable/debian/control44
-rwxr-xr-xwearable/debian/rules125
-rw-r--r--wearable/firmware/BCM20710A1_001.002.014.0028.0048.hcdbin0 -> 32905 bytes
-rw-r--r--wearable/firmware/BCM20710A1_001.002.014.0052.0000_Samsung_Tizen_Lite_TEST_ONLY.hcdbin0 -> 39568 bytes
-rw-r--r--wearable/firmware/BCM20710A1_001.002.014.0056.0000_Samsung_Tizen_Lite_TEST_ONLY.hcdbin0 -> 39658 bytes
-rw-r--r--wearable/firmware/BCM20710A1_001.002.014.0059.0060.hcdbin0 -> 39400 bytes
-rw-r--r--wearable/firmware/BCM4330B1_002.001.003.0013.0000_SS-SLP7-B42_NoExtLNA_37_4MHz-TEST-ONLY.hcdbin0 -> 12743 bytes
-rw-r--r--wearable/firmware/BCM4330B1_002.001.003.0221.0265.hcdbin0 -> 32195 bytes
-rw-r--r--wearable/firmware/BCM4334B0_002.001.013.0079.0081.hcdbin0 -> 29265 bytes
-rw-r--r--wearable/firmware/BCM4334B0_002.001.013.0079.0083.hcdbin0 -> 29258 bytes
-rw-r--r--wearable/firmware/BCM4334B0_002.001.013.0079.0084.hcdbin0 -> 29263 bytes
-rw-r--r--wearable/firmware/BCM4334B0_002.001.013.0779.0950.hcdbin0 -> 37392 bytes
-rw-r--r--wearable/firmware/BCM4334B0_002.001.013.0942.1036.hcdbin0 -> 39505 bytes
-rw-r--r--wearable/firmware/BCM4334B0_002.001.013.1024.1064.hcdbin0 -> 39839 bytes
-rw-r--r--wearable/firmware/CMakeLists.txt14
-rw-r--r--wearable/firmware/bcm4334w/BCM43342A1_001.002.003.0874.0000_SEMCO_B58_TEST_ONLY.hcdbin0 -> 43135 bytes
-rw-r--r--wearable/firmware/bcm4334w/BCM43342A1_001.002.003.0987.0000_Samsung_Rinato_Tizen_ePA_RFtest_LE_7dBm.hcdbin0 -> 49919 bytes
-rw-r--r--wearable/firmware/bcm4334w/BCM4334B0_002.001.013.1675.1676_B2_ORC.hcdbin0 -> 53935 bytes
-rw-r--r--wearable/firmware/bcm4334w/BCM4334W_001.002.003.0874.0000_Samsung_Rinato_TEST_ONLY.hcdbin0 -> 43082 bytes
-rw-r--r--wearable/firmware/bcm4334w/BCM4334W_001.002.003.0874.0000_ePA_SEMCO_B58_TEST_ONLY.hcdbin0 -> 43147 bytes
-rwxr-xr-xwearable/firmware/bcm4334w/BCM4334W_001.002.003.0987.0000_Samsung_Rinato_M7_TEST_ONLY_GGPatch.hcdbin0 -> 48537 bytes
-rwxr-xr-xwearable/firmware/bcm4334w/BCM4334W_001.002.003.0987.1017.hcdbin0 -> 51383 bytes
-rw-r--r--wearable/firmware/bcm4334w/BCM4334W_001.002.003.0995.1021_B58_ePA.HCDbin0 -> 52368 bytes
-rw-r--r--wearable/firmware/bcm4334w/BCM4334W_001.002.003.0997.1024_B58_ePA.hcdbin0 -> 52384 bytes
-rw-r--r--wearable/firmware/bcm4334w/BCM4334W_001.002.003.0997.1027_B58_ePA.hcdbin0 -> 52399 bytes
-rw-r--r--wearable/firmware/bcm4334w/BCM4334W_Generic_37_4MHz_wlcsp_Rinato_ePA_TestOnly.hcdbin0 -> 49452 bytes
-rw-r--r--wearable/firmware/bcm4334w/BCM4334W_Rinato_TestOnly.hcdbin0 -> 49448 bytes
-rwxr-xr-xwearable/firmware/bcm4334w/configdata_wlcsp_Semco_B58_ePA_TestOnly.hcdbin0 -> 48655 bytes
-rw-r--r--wearable/firmware/bcm4335/BCM4335B0_002.001.006.0203.0206_ORC_JF-LTE.hcdbin0 -> 61117 bytes
-rw-r--r--wearable/firmware/bcm4335/BCM4335B0_002.001.006.0233.0234_ORC_RedWood.hcdbin0 -> 61958 bytes
-rw-r--r--wearable/firmware/bcm4335/ReleaseNotes_BCM4335B0_002.001.006.0233.0234_ORC_Samsung_RedWood_BT4.0_37_4MHz.txt45
-rw-r--r--wearable/firmware/bcm4339/BCM4339_003.001.009.0025.0053_ORC_H-LTE.hcdbin0 -> 33345 bytes
-rw-r--r--wearable/firmware/bcm4339/BCM4339_003.001.009.0028.0085_RedWood.hcdbin0 -> 33726 bytes
-rw-r--r--wearable/firmware/bcm4339/BCM4339_003.001.009.0030.0122_ORC_RedWood.hcdbin0 -> 38973 bytes
-rw-r--r--wearable/scripts/CMakeLists.txt6
-rwxr-xr-xwearable/scripts/bt-dev-end.sh22
-rwxr-xr-xwearable/scripts/bt-dev-start-c210.sh91
-rwxr-xr-xwearable/scripts/bt-dev-start-e4412.sh135
-rwxr-xr-xwearable/scripts/bt-dev-start-msm8974.sh66
-rwxr-xr-xwearable/scripts/bt-set-addr.sh16
-rw-r--r--wearable/set-address/CMakeLists.txt21
-rw-r--r--wearable/set-address/setbd.c190
-rw-r--r--wearable/tools/CMakeLists.txt25
-rw-r--r--wearable/tools/bcmtool.c897
-rw-r--r--wearable/tools/bcmtool_4330b1.c1024
82 files changed, 5305 insertions, 0 deletions
diff --git a/mobile/AUTHORS b/mobile/AUTHORS
new file mode 100644
index 0000000..46d1687
--- /dev/null
+++ b/mobile/AUTHORS
@@ -0,0 +1,2 @@
+Jinmin Jung <jinmin@samsung.com>
+DoHyun Pyun <dh79.pyun@samsung.com>
diff --git a/mobile/CMakeLists.txt b/mobile/CMakeLists.txt
new file mode 100644
index 0000000..94e9747
--- /dev/null
+++ b/mobile/CMakeLists.txt
@@ -0,0 +1,12 @@
+CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
+
+FOREACH(flag ${package_CFLAGS})
+ SET(EXTRA_CFLAGS "${EXTRA_CFLAGS} ${flag}")
+ENDFOREACH(flag)
+
+SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_CFLAGS}")
+
+ADD_SUBDIRECTORY(set-address)
+ADD_SUBDIRECTORY(tools)
+ADD_SUBDIRECTORY(firmware)
+ADD_SUBDIRECTORY(scripts)
diff --git a/mobile/LICENSE.APLv2 b/mobile/LICENSE.APLv2
new file mode 100644
index 0000000..6b0b127
--- /dev/null
+++ b/mobile/LICENSE.APLv2
@@ -0,0 +1,203 @@
+
+ Apache License
+ Version 2.0, January 2004
+ http://www.apache.org/licenses/
+
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+ 1. Definitions.
+
+ "License" shall mean the terms and conditions for use, reproduction,
+ and distribution as defined by Sections 1 through 9 of this document.
+
+ "Licensor" shall mean the copyright owner or entity authorized by
+ the copyright owner that is granting the License.
+
+ "Legal Entity" shall mean the union of the acting entity and all
+ other entities that control, are controlled by, or are under common
+ control with that entity. For the purposes of this definition,
+ "control" means (i) the power, direct or indirect, to cause the
+ direction or management of such entity, whether by contract or
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
+ outstanding shares, or (iii) beneficial ownership of such entity.
+
+ "You" (or "Your") shall mean an individual or Legal Entity
+ exercising permissions granted by this License.
+
+ "Source" form shall mean the preferred form for making modifications,
+ including but not limited to software source code, documentation
+ source, and configuration files.
+
+ "Object" form shall mean any form resulting from mechanical
+ transformation or translation of a Source form, including but
+ not limited to compiled object code, generated documentation,
+ and conversions to other media types.
+
+ "Work" shall mean the work of authorship, whether in Source or
+ Object form, made available under the License, as indicated by a
+ copyright notice that is included in or attached to the work
+ (an example is provided in the Appendix below).
+
+ "Derivative Works" shall mean any work, whether in Source or Object
+ form, that is based on (or derived from) the Work and for which the
+ editorial revisions, annotations, elaborations, or other modifications
+ represent, as a whole, an original work of authorship. For the purposes
+ of this License, Derivative Works shall not include works that remain
+ separable from, or merely link (or bind by name) to the interfaces of,
+ the Work and Derivative Works thereof.
+
+ "Contribution" shall mean any work of authorship, including
+ the original version of the Work and any modifications or additions
+ to that Work or Derivative Works thereof, that is intentionally
+ submitted to Licensor for inclusion in the Work by the copyright owner
+ or by an individual or Legal Entity authorized to submit on behalf of
+ the copyright owner. For the purposes of this definition, "submitted"
+ means any form of electronic, verbal, or written communication sent
+ to the Licensor or its representatives, including but not limited to
+ communication on electronic mailing lists, source code control systems,
+ and issue tracking systems that are managed by, or on behalf of, the
+ Licensor for the purpose of discussing and improving the Work, but
+ excluding communication that is conspicuously marked or otherwise
+ designated in writing by the copyright owner as "Not a Contribution."
+
+ "Contributor" shall mean Licensor and any individual or Legal Entity
+ on behalf of whom a Contribution has been received by Licensor and
+ subsequently incorporated within the Work.
+
+ 2. Grant of Copyright License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ copyright license to reproduce, prepare Derivative Works of,
+ publicly display, publicly perform, sublicense, and distribute the
+ Work and such Derivative Works in Source or Object form.
+
+ 3. Grant of Patent License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ (except as stated in this section) patent license to make, have made,
+ use, offer to sell, sell, import, and otherwise transfer the Work,
+ where such license applies only to those patent claims licensable
+ by such Contributor that are necessarily infringed by their
+ Contribution(s) alone or by combination of their Contribution(s)
+ with the Work to which such Contribution(s) was submitted. If You
+ institute patent litigation against any entity (including a
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
+ or a Contribution incorporated within the Work constitutes direct
+ or contributory patent infringement, then any patent licenses
+ granted to You under this License for that Work shall terminate
+ as of the date such litigation is filed.
+
+ 4. Redistribution. You may reproduce and distribute copies of the
+ Work or Derivative Works thereof in any medium, with or without
+ modifications, and in Source or Object form, provided that You
+ meet the following conditions:
+
+ (a) You must give any other recipients of the Work or
+ Derivative Works a copy of this License; and
+
+ (b) You must cause any modified files to carry prominent notices
+ stating that You changed the files; and
+
+ (c) You must retain, in the Source form of any Derivative Works
+ that You distribute, all copyright, patent, trademark, and
+ attribution notices from the Source form of the Work,
+ excluding those notices that do not pertain to any part of
+ the Derivative Works; and
+
+ (d) If the Work includes a "NOTICE" text file as part of its
+ distribution, then any Derivative Works that You distribute must
+ include a readable copy of the attribution notices contained
+ within such NOTICE file, excluding those notices that do not
+ pertain to any part of the Derivative Works, in at least one
+ of the following places: within a NOTICE text file distributed
+ as part of the Derivative Works; within the Source form or
+ documentation, if provided along with the Derivative Works; or,
+ within a display generated by the Derivative Works, if and
+ wherever such third-party notices normally appear. The contents
+ of the NOTICE file are for informational purposes only and
+ do not modify the License. You may add Your own attribution
+ notices within Derivative Works that You distribute, alongside
+ or as an addendum to the NOTICE text from the Work, provided
+ that such additional attribution notices cannot be construed
+ as modifying the License.
+
+ You may add Your own copyright statement to Your modifications and
+ may provide additional or different license terms and conditions
+ for use, reproduction, or distribution of Your modifications, or
+ for any such Derivative Works as a whole, provided Your use,
+ reproduction, and distribution of the Work otherwise complies with
+ the conditions stated in this License.
+
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
+ any Contribution intentionally submitted for inclusion in the Work
+ by You to the Licensor shall be under the terms and conditions of
+ this License, without any additional terms or conditions.
+ Notwithstanding the above, nothing herein shall supersede or modify
+ the terms of any separate license agreement you may have executed
+ with Licensor regarding such Contributions.
+
+ 6. Trademarks. This License does not grant permission to use the trade
+ names, trademarks, service marks, or product names of the Licensor,
+ except as required for reasonable and customary use in describing the
+ origin of the Work and reproducing the content of the NOTICE file.
+
+ 7. Disclaimer of Warranty. Unless required by applicable law or
+ agreed to in writing, Licensor provides the Work (and each
+ Contributor provides its Contributions) on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ implied, including, without limitation, any warranties or conditions
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+ PARTICULAR PURPOSE. You are solely responsible for determining the
+ appropriateness of using or redistributing the Work and assume any
+ risks associated with Your exercise of permissions under this License.
+
+ 8. Limitation of Liability. In no event and under no legal theory,
+ whether in tort (including negligence), contract, or otherwise,
+ unless required by applicable law (such as deliberate and grossly
+ negligent acts) or agreed to in writing, shall any Contributor be
+ liable to You for damages, including any direct, indirect, special,
+ incidental, or consequential damages of any character arising as a
+ result of this License or out of the use or inability to use the
+ Work (including but not limited to damages for loss of goodwill,
+ work stoppage, computer failure or malfunction, or any and all
+ other commercial damages or losses), even if such Contributor
+ has been advised of the possibility of such damages.
+
+ 9. Accepting Warranty or Additional Liability. While redistributing
+ the Work or Derivative Works thereof, You may choose to offer,
+ and charge a fee for, acceptance of support, warranty, indemnity,
+ or other liability obligations and/or rights consistent with this
+ License. However, in accepting such obligations, You may act only
+ on Your own behalf and on Your sole responsibility, not on behalf
+ of any other Contributor, and only if You agree to indemnify,
+ defend, and hold each Contributor harmless for any liability
+ incurred by, or claims asserted against, such Contributor by reason
+ of your accepting any such warranty or additional liability.
+
+ END OF TERMS AND CONDITIONS
+
+ APPENDIX: How to apply the Apache License to your work.
+
+ To apply the Apache License to your work, attach the following
+ boilerplate notice, with the fields enclosed by brackets "[]"
+ replaced with your own identifying information. (Don't include
+ the brackets!) The text should be enclosed in the appropriate
+ comment syntax for the file format. We also recommend that a
+ file or class name and description of purpose be included on the
+ same "printed page" as the copyright notice for easier
+ identification within third-party archives.
+
+ Copyright [yyyy] [name of copyright owner]
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+
diff --git a/mobile/LICENSE.Broadcom b/mobile/LICENSE.Broadcom
new file mode 100644
index 0000000..acf4e62
--- /dev/null
+++ b/mobile/LICENSE.Broadcom
@@ -0,0 +1,64 @@
+SOFTWARE LICENSE AGREEMENT
+
+The accompanying software in binary code form ("Software"), is licensed to you,
+or, if you are accepting on behalf of an entity, the entity and its affiliates
+exercising rights hereunder ("Licensee") subject to the terms of this software
+license agreement ("Agreement"), unless Licensee and Broadcom Corporation
+("Broadcom") execute a separate written software license agreement governing
+use of the Software. ANY USE, REPRODUCTION, OR DISTRIBUTION OF THE SOFTWARE
+CONSTITUTES LICENSEE'S ACCEPTANCE OF THIS AGREEMENT.
+
+1. License. Subject to the terms and conditions of this Agreement,
+Broadcom hereby grants to Licensee a limited, non-exclusive, non-transferable,
+royalty-free license: (i) to use and integrate the Software with any other
+software; and (ii) to reproduce and distribute the Software complete,
+unmodified, and as provided by Broadcom, solely for use with Broadcom
+proprietary integrated circuit product(s) sold by Broadcom with which the
+Software was designed to be used, or their successors.
+
+2. Restrictions. Licensee shall distribute Software with a copy of this
+Agreement. Licensee shall not remove, efface or obscure any copyright or
+trademark notices from the Software. Reproductions of the Broadcom copyright
+notice shall be included with each copy of the Software, except where such
+Software is embedded in a manner not readily accessible to the end user.
+Licensee shall not: (i) use, license, sell or otherwise distribute the Software
+except as provided in this Agreement; (ii) attempt to modify in any way,
+reverse engineer, decompile or disassemble any portion of the Software; or
+(iii) use the Software or other material in violation of any applicable law or
+regulation, including but not limited to any regulatory agency. This Agreement
+shall automatically terminate upon Licensee’s failure to comply with any of the
+terms of this Agreement. In such event, Licensee will destroy all copies of the
+Software and its component parts.
+
+3. Ownership. The Software is licensed and not sold. Title to and
+ownership of the Software, including all intellectual property rights thereto,
+and any portion thereof remain with Broadcom or its licensors. Licensee hereby
+covenants that it will not assert any claim that the Software created by or for
+Broadcom infringe any intellectual property right owned or controlled by
+Licensee.
+
+4. Disclaimer. THE SOFTWARE IS OFFERED "AS IS," AND BROADCOM PROVIDES AND
+GRANTS AND LICENSEE RECEIVES NO SUPPORT AND NO WARRANTIES OF ANY KIND, EXPRESS
+OR IMPLIED, BY STATUTE, COMMUNICATION OR CONDUCT WITH LICENSEE, OR OTHERWISE.
+BROADCOM SPECIFICALLY DISCLAIMS ANY IMPLIED WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A SPECIFIC PURPOSE, OR NONINFRINGEMENT CONCERNING THE SOFTWARE OR
+ANY UPGRADES TO OR DOCUMENTATION FOR THE SOFTWARE. WITHOUT LIMITATION OF THE
+ABOVE, BROADCOM GRANTS NO WARRANTY THAT THE SOFTWARE IS ERROR-FREE OR WILL
+OPERATE WITHOUT INTERRUPTION, AND GRANTS NO WARRANTY REGARDING ITS USE OR THE
+RESULTS THEREFROM INCLUDING, WITHOUT LIMITATION, ITS CORRECTNESS, ACCURACY, OR
+RELIABILITY. TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT SHALL BROADCOM
+OR ANY OF ITS LICENSORS HAVE ANY LIABILITY FOR ANY DIRECT, INDIRECT,
+INCIDENTAL, SPECIAL, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND ON ANY THEORY
+OF LIABILITY, WHETHER FOR BREACH OF CONTRACT, TORT (INCLUDING NEGLIGENCE) OR
+OTHERWISE, ARISING OUT OF THIS AGREEMENT OR USE, REPRODUCTION, OR DISTRIBUTION
+OF THE SOFTWARE, INCLUDING BUT NOT LIMITED TO LOSS OF DATA AND LOSS OF PROFITS,
+EVEN IF SUCH PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. THESE
+LIMITATIONS SHALL APPLY NOTWITHSTANDING ANY FAILURE OF ESSENTIAL PURPOSE OF ANY
+LIMITED REMEDY.
+
+5. Export Laws. LICENSEE UNDERSTANDS AND AGREES THAT THE SOFTWARE IS
+SUBJECT TO UNITED STATES AND OTHER APPLICABLE EXPORT-RELATED LAWS AND
+REGULATIONS AND THAT LICENSEE MAY NOT EXPORT, RE-EXPORT OR TRANSFER THE
+SOFTWARE OR ANY DIRECT PRODUCT OF THE SOFTWARE EXCEPT AS PERMITTED UNDER THOSE
+LAWS. WITHOUT LIMITING THE FOREGOING, EXPORT, RE-EXPORT, OR TRANSFER OF THE
+SOFTWARE TO CUBA, IRAN, NORTH KOREA, SUDAN, AND SYRIA IS PROHIBITED.
diff --git a/mobile/NOTICE b/mobile/NOTICE
new file mode 100644
index 0000000..411d0c9
--- /dev/null
+++ b/mobile/NOTICE
@@ -0,0 +1,10 @@
+Copyright (c) 2012 Samsung Electronics Co., Ltd. All rights reserved.
+Except as noted, this software is licensed under Apache License, Version 2.
+Please, see the LICENSE.APLv2 file for Apache License terms and conditions.
+
+The following files are copyrighted by Broadcom and licensed under
+a separate license. Please, see the LICENSE.Broadcom file for
+license terms and conditions.
+
+Copyright (c) 2012 Broadcom Co., Ltd. All rights reserved.
+- firmware/*.hcd
diff --git a/mobile/bluetooth-firmware-bcm.manifest b/mobile/bluetooth-firmware-bcm.manifest
new file mode 100644
index 0000000..a3dc534
--- /dev/null
+++ b/mobile/bluetooth-firmware-bcm.manifest
@@ -0,0 +1,8 @@
+<manifest>
+ <define>
+ <domain name="bt_firmware"/>
+ </define>
+ <request>
+ <domain name="bt_firmware"/>
+ </request>
+</manifest>
diff --git a/mobile/debian/bluetooth-firmware-bcm.install b/mobile/debian/bluetooth-firmware-bcm.install
new file mode 100644
index 0000000..a99d1b4
--- /dev/null
+++ b/mobile/debian/bluetooth-firmware-bcm.install
@@ -0,0 +1,2 @@
+usr/bin/*
+usr/etc/bluetooth/BCM4330B1_002.001.003.0221.0265.hcd
diff --git a/mobile/debian/bluetooth-firmware-bcm.postinst.in b/mobile/debian/bluetooth-firmware-bcm.postinst.in
new file mode 100644
index 0000000..cb03b3c
--- /dev/null
+++ b/mobile/debian/bluetooth-firmware-bcm.postinst.in
@@ -0,0 +1,10 @@
+#!/bin/sh
+
+# Change File Permission
+chmod 644 @PREFIX@/etc/bluetooth/BCM4330B1_002.001.003.0221.0265.hcd
+
+# root case
+if [ ${USER} = "root" ]
+then
+ chown root:root @PREFIX@/etc/bluetooth/BCM4330B1_002.001.003.0221.0265.hcd
+fi
diff --git a/mobile/debian/changelog b/mobile/debian/changelog
new file mode 100755
index 0000000..bb496ac
--- /dev/null
+++ b/mobile/debian/changelog
@@ -0,0 +1,35 @@
+bluetooth-firmware-bcm (0.2.28) precise; urgency=low
+
+ * Synchronize the code with Private git
+
+ -- Jaekyun Lee <jkyun.ee@samsung.com> Fri, 07 Dec 2012 14:53:59 +0900
+
+bluetooth-firmware-bcm (0.1.4) unstable; urgency=low
+
+ * Add e4412 firmware
+
+ -- Jaekyun Lee <jkyun.lee@samsung.com> Wed, 17 Oct 2012 11:50:43 +0900
+
+bluetooth-firmware-bcm (0.1.3) unstable; urgency=low
+
+ * rename bt-firmware-43xx to bluetooth-firmware-bcm
+
+ -- Jaekyun Lee <jkyun.lee@samsung.com> Sat, 11 Aug 2012 14:26:05 +0900
+
+bt-firmware-43xx (0.1.2) unstable; urgency=low
+
+ * Fix set bd bug as TAPI IMEI API deprecated
+
+ -- Jaekyun Lee <jkyun.lee@samsung.com> Mon, 26 Mar 2012 15:13:31 +0900
+
+bt-firmware-43xx (0.1.1) unstable; urgency=low
+
+ * common script moved to bluetooth-tools
+
+ -- Jaekyun Lee <jkyun.lee@samsung.com> Fri, 23 Mar 2012 11:29:47 +0900
+
+bt-firmware-43xx (0.1.0) unstable; urgency=low
+
+ * Initail Release
+
+ -- DoHyun Pyun <dh79.pyun@samsung.com> Tue, 14 Feb 2012 15:13:03 +0900
diff --git a/mobile/debian/compat b/mobile/debian/compat
new file mode 100644
index 0000000..7ed6ff8
--- /dev/null
+++ b/mobile/debian/compat
@@ -0,0 +1 @@
+5
diff --git a/mobile/debian/control b/mobile/debian/control
new file mode 100644
index 0000000..91d830a
--- /dev/null
+++ b/mobile/debian/control
@@ -0,0 +1,25 @@
+Source: bluetooth-firmware-bcm
+Section: devel
+Priority: optional
+Maintainer: DoHyun Pyun <dh79.pyun@samsung.com>, ChanYeol Park <chanyeol.park@samsung.com>, Girish A J <girish.joshi@samsung.com>, InJun Yang <injun.yang@samsung.com>, Jaekyun Lee <jkyun.lee@samsung.com>
+Uploaders: Sunil Behera <sunil.behera@samsung.com>, Syam Sidhardhan <s.syam@samsung.com>
+Build-Depends: debhelper (>= 5), libglib2.0-dev, libvconf-dev
+Standards-Version: 3.7.2
+Homepage: N/A
+
+Package: bluetooth-firmware-bcm
+Architecture: any
+Section: utils
+Depends: ${shlibs:Depends}, ${misc:Depends}, bluetooth-tools
+Description: firmware and tools
+ firmware and tools
+
+Package: bluetooth-firmware-bcm-dbg
+Section: debug
+Architecture: any
+Depends: ${shlibs:Depends}, ${misc:Depends}, bluetooth-firmware-bcm (= ${Source-Version})
+Description: Tools for bluetooth-firmware-bcm (unstripped)
+ The package contains detached debugging symbols for the binary packages
+ produced by the bt-firmware-43xx soruce.
+
+
diff --git a/mobile/debian/rules b/mobile/debian/rules
new file mode 100755
index 0000000..531d1a1
--- /dev/null
+++ b/mobile/debian/rules
@@ -0,0 +1,112 @@
+#!/usr/bin/make -f
+
+# Uncomment this to turn on verbose mode.
+#export DH_VERBOSE=1
+
+CFLAGS ?= -Wall -g
+LDFLAGS ?=
+PREFIX ?= /usr
+DATADIR ?= /opt
+PLUGIN_PREFIX ?= /usr
+
+CMAKE_BUILD_DIR ?= $(CURDIR)/cmake_build_tmp
+
+ifneq (,$(findstring noopt,$(DEB_BUILD_OPTIONS)))
+ CFLAGS += -O0
+else
+ CFLAGS += -O2
+endif
+
+LDFLAGS += -Wl,--rpath=$(PREFIX)/lib -Wl,--as-needed -Wl,--unresolved-symbols=ignore-in-shared-libs
+
+configure: configure-stamp
+configure-stamp:
+ dh_testdir
+ # Add here commands to configure the package.
+ mkdir -p $(CMAKE_BUILD_DIR) && \
+ cd $(CMAKE_BUILD_DIR) && \
+ CFLAGS="$(CFLAGS) -fpie" LDFLAGS="$(LDFLAGS) -pie" \
+ cmake .. -DCMAKE_INSTALL_PREFIX=$(PREFIX) -DPLUGIN_INSTALL_PREFIX=$(PLUGIN_PREFIX)
+
+ touch configure-stamp
+
+build: build-stamp
+
+build-stamp: configure-stamp
+ dh_testdir
+
+ # Add here commands to compile the package.
+ cd $(CMAKE_BUILD_DIR) && $(MAKE)
+
+ for f in `find $(CURDIR)/debian/ -name "*.in"`; do \
+ cat $$f > $${f%.in}; \
+ sed -i -e "s#@PREFIX@#$(PREFIX)#g" $${f%.in}; \
+ sed -i -e "s#@DATADIR@#$(DATADIR)#g" $${f%.in}; \
+ sed -i -e "s#@PLUGIN_PREFIX@#$(PLUGIN_PREFIX)#g" $${f%.in}; \
+ done
+
+ touch $@
+
+clean:
+ dh_testdir
+ dh_testroot
+ rm -f build-stamp configure-stamp
+
+ # Add here commands to clean up after the build process.
+ -rm -rf $(CMAKE_BUILD_DIR)
+ for f in `find $(CURDIR)/debian/ -name "*.in"`; do \
+ rm -f $${f%.in}; \
+ done
+
+ dh_clean
+
+install: build
+ dh_testdir
+ dh_testroot
+ dh_clean -k
+ dh_installdirs
+
+ # Add here commands to install the package into debian/wavplayer.
+ cd $(CMAKE_BUILD_DIR) && $(MAKE) DESTDIR=$(CURDIR)/debian/tmp install
+
+
+
+ # Booting script
+
+# Build architecture-independent files here.
+binary-indep: build install
+# We have nothing to do by default.
+
+# Build architecture-dependent files here.
+binary-arch: build install
+ dh_testdir
+ dh_testroot
+ dh_installchangelogs
+ dh_installdocs
+ dh_installexamples
+ dh_install --sourcedir=debian/tmp
+# dh_installmenu
+# dh_installdebconf
+# dh_installlogrotate
+# dh_installemacsen
+# dh_installpam
+# dh_installmime
+# dh_python
+# dh_installinit
+# dh_installcron
+# dh_installinfo
+ dh_installman
+ dh_link
+ dh_strip --dbg-package=bluetooth-firmware-bcm-dbg
+ dh_compress
+ dh_fixperms
+# dh_perl
+ dh_makeshlibs
+ dh_installdeb
+ dh_shlibdeps
+ dh_gencontrol
+ dh_md5sums
+ dh_builddeb
+
+binary: binary-indep binary-arch
+.PHONY: build clean binary-indep binary-arch binary install configure
diff --git a/mobile/firmware/BCM4330B1_002.001.003.0221.0265.hcd b/mobile/firmware/BCM4330B1_002.001.003.0221.0265.hcd
new file mode 100644
index 0000000..a8c7f30
--- /dev/null
+++ b/mobile/firmware/BCM4330B1_002.001.003.0221.0265.hcd
Binary files differ
diff --git a/mobile/firmware/BCM4334B0_002.001.013.0079.0081.hcd b/mobile/firmware/BCM4334B0_002.001.013.0079.0081.hcd
new file mode 100644
index 0000000..ff13214
--- /dev/null
+++ b/mobile/firmware/BCM4334B0_002.001.013.0079.0081.hcd
Binary files differ
diff --git a/mobile/firmware/CMakeLists.txt b/mobile/firmware/CMakeLists.txt
new file mode 100755
index 0000000..750e004
--- /dev/null
+++ b/mobile/firmware/CMakeLists.txt
@@ -0,0 +1,3 @@
+# install firmware
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/BCM4330B1_002.001.003.0221.0265.hcd DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/BCM4334B0_002.001.013.0079.0081.hcd DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
diff --git a/mobile/scripts/CMakeLists.txt b/mobile/scripts/CMakeLists.txt
new file mode 100755
index 0000000..c432239
--- /dev/null
+++ b/mobile/scripts/CMakeLists.txt
@@ -0,0 +1,5 @@
+# install firmware
+INSTALL(PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR}/bt-dev-end.sh DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR}/bt-dev-start-c210.sh DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR}/bt-dev-start-e4412.sh DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR}/bt-set-addr.sh DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
diff --git a/mobile/scripts/bt-dev-end.sh b/mobile/scripts/bt-dev-end.sh
new file mode 100755
index 0000000..cb57537
--- /dev/null
+++ b/mobile/scripts/bt-dev-end.sh
@@ -0,0 +1,32 @@
+#!/bin/sh
+
+#
+# Script for stopping Broadcom UART Bluetooth stack
+#
+
+# Device down
+/usr/sbin/hciconfig hci0 down
+
+# OMAP4
+REVISION_NUM=`grep Revision /proc/cpuinfo | awk "{print \\$3}"`
+if [ $REVISION_NUM == "0006" ]; then
+ rmmod bt_drv.ko
+ rmmod st_drv.ko
+ sleep 1
+ killall uim_rfkill
+ exit 0
+fi
+
+# Turn off Bluetooth Chip
+rfkill block bluetooth
+
+killall hciattach
+
+#if [ -e /sys/class/gpio/gpio17/value ]
+#then
+# # Reset BT chip
+# echo 0 > /sys/class/gpio/gpio17/value
+# sleep 0.1
+# echo 1 > /sys/class/gpio/gpio17/value
+#fi
+
diff --git a/mobile/scripts/bt-dev-start-c210.sh b/mobile/scripts/bt-dev-start-c210.sh
new file mode 100755
index 0000000..1be1b62
--- /dev/null
+++ b/mobile/scripts/bt-dev-start-c210.sh
@@ -0,0 +1,83 @@
+#!/bin/sh
+
+# Script for registering Broadcom UART BT device
+BT_UART_DEVICE=/dev/ttySAC0
+BT_CHIP_TYPE=bcm2035
+BCM_TOOL=/usr/bin/bcmtool_4330b1
+BT_ADDR=/csa/bluetooth/.bd_addr
+
+BT_PLATFORM_DEFAULT_HCI_NAME="TIZEN-Mobile"
+UART_SPEED=3000000
+
+#set default firmware
+BCM_FIRMWARE=BCM4330B1_002.001.003.0221.0265.hcd
+
+REVISION_NUM=`grep Revision /proc/cpuinfo | awk "{print \\$3}"`
+REVISION_HIGH=`echo $REVISION_NUM| cut -c1-2`
+REVISION_LOW=`echo $REVISION_NUM| cut -c3-`
+
+HARDWARE=`grep Hardware /proc/cpuinfo | awk "{print \\$3}"`
+
+if [ ! -e "$BT_UART_DEVICE" ]
+then
+ mknod $BT_UART_DEVICE c 204 64
+fi
+
+# Set BT address: This will internally check for the file presence
+/usr/bin/setbd
+
+#if the setbd return non 0, which means incorrect bd address file, then exit
+if [ $? -ne 0 ]
+then
+ exit 1
+fi
+
+# Trun-on Bluetooth Chip
+rfkill unblock bluetooth
+
+echo "Check for Bluetooth device status"
+if (/usr/sbin/hciconfig | grep hci); then
+ echo "Bluetooth device is UP"
+ /usr/sbin/hciconfig hci0 up
+else
+ echo "Bluetooth device is DOWN"
+ echo "Registering Bluetooth device"
+
+ $BCM_TOOL $BT_UART_DEVICE -FILE=/usr/etc/bluetooth/$BCM_FIRMWARE -BAUD=$UART_SPEED -ADDR=$BT_ADDR -SETSCO=0,0,0,0,0,0,0,3,3,0 -LP > /dev/null 2>&1 &
+ bcmtool_pid=$!
+ #Check next 2.4 seconds for bcmtool success
+ for (( i=1; i<=24; i++))
+ do
+ sleep 0.1
+ kill -0 $bcmtool_pid
+ bcmtool_alive=$?
+
+ if [ $i -eq 24 ]
+ then
+ echo "time expired happen $i"
+ kill -TERM $bcmtool_pid
+ rfkill block bluetooth
+ exit 1
+ fi
+
+ if [ $bcmtool_alive -eq 0 ]
+ then
+ echo "Continue....$i"
+ continue
+ else
+ echo "Break.......$i"
+ break
+ fi
+ done
+
+ # Attaching Broadcom device
+ if (/usr/sbin/hciattach $BT_UART_DEVICE -s $UART_SPEED $BT_CHIP_TYPE $UART_SPEED flow); then
+ sleep 0.1
+ /usr/sbin/hciconfig hci0 name $BT_PLATFORM_DEFAULT_HCI_NAME
+ /usr/sbin/hciconfig hci0 sspmode 1
+ echo "HCIATTACH success"
+ else
+ echo "HCIATTACH failed"
+ rfkill block bluetooth
+ fi
+fi
diff --git a/mobile/scripts/bt-dev-start-e4412.sh b/mobile/scripts/bt-dev-start-e4412.sh
new file mode 100755
index 0000000..3a9e663
--- /dev/null
+++ b/mobile/scripts/bt-dev-start-e4412.sh
@@ -0,0 +1,92 @@
+#!/bin/sh
+
+#
+# Script for registering Broadcom UART BT device
+#
+BT_UART_DEVICE=/dev/ttySAC0
+BT_CHIP_TYPE=bcm2035
+BCM_TOOL=/usr/bin/bcmtool_4330b1
+
+BT_ADDR=/csa/bluetooth/.bd_addr
+
+BT_PLATFORM_DEFAULT_HCI_NAME="TIZEN-Mobile"
+UART_SPEED=3000000
+
+# defult firmware
+# SEMCO external LNA, I2S slave
+BCM_FIRMWARE=BCM4334B0_002.001.013.0079.0081.hcd
+
+HOST_NAME=`grep Hardware /proc/cpuinfo | awk "{print \\$3}"`
+REVISION_NUM=`grep Revision /proc/cpuinfo | awk "{print \\$3}"`
+REVISION_HIGH=`echo $REVISION_NUM| cut -c1-2`
+REVISION_LOW=`echo $REVISION_NUM| cut -c3-`
+
+echo $BCM_FIRMWARE
+
+if [ ! -e "$BT_UART_DEVICE" ]
+then
+ mknod $BT_UART_DEVICE c 204 64
+fi
+
+# Set BT address: This will internally check for the file presence
+/usr/bin/setbd
+
+#if the setbd return non 0, which means incorrect bd address file, then exit
+if [ $? -ne 0 ]
+then
+ exit 1
+fi
+
+rfkill unblock bluetooth
+
+echo "Check for Bluetooth device status"
+if (/usr/sbin/hciconfig | grep hci); then
+ echo "Bluetooth device is UP"
+ /usr/sbin/hciconfig hci0 up
+else
+ echo "Bluetooth device is DOWN"
+ echo "Registering Bluetooth device"
+
+ $BCM_TOOL $BT_UART_DEVICE -FILE=/usr/etc/bluetooth/$BCM_FIRMWARE -BAUD=$UART_SPEED -ADDR=$BT_ADDR -SETSCO=0,0,0,0,0,0,0,3,3,0 -LP > /dev/null 2>&1 &
+ bcmtool_pid=$!
+ #Check next 5 seconds for bcmtool success
+ for (( i=1; i<=50; i++))
+ do
+ sleep 0.1
+ kill -0 $bcmtool_pid
+ bcmtool_alive=$?
+
+ if [ $i -eq 50 ]
+ then
+ echo "time expired happen $i"
+ kill -TERM $bcmtool_pid
+ rfkill block bluetooth
+ cp /var/log/messages /var/lib/bluetooth/
+ exit 1
+ fi
+
+ if [ $bcmtool_alive -eq 0 ]
+ then
+ echo "Continue....$i"
+ continue
+ else
+ echo "Break.......$i"
+ break
+ fi
+ done
+
+ # Attaching Broadcom device
+ if (/usr/sbin/hciattach $BT_UART_DEVICE -s $UART_SPEED $BT_CHIP_TYPE $UART_SPEED flow); then
+ sleep 0.1
+ /usr/sbin/hciconfig hci0 name $BT_PLATFORM_DEFAULT_HCI_NAME
+ /usr/sbin/hciconfig hci0 sspmode 1
+ echo "HCIATTACH success"
+ else
+ echo "HCIATTACH failed"
+ rfkill block bluetooth
+ cp /var/log/messages /var/lib/bluetooth/
+ fi
+fi
+
+#/usr/sbin/hciconfig hci0 down
+
diff --git a/mobile/scripts/bt-set-addr.sh b/mobile/scripts/bt-set-addr.sh
new file mode 100755
index 0000000..a2624a0
--- /dev/null
+++ b/mobile/scripts/bt-set-addr.sh
@@ -0,0 +1,16 @@
+#!/bin/sh
+
+#
+# Script for setting Bluetooth Address
+#
+
+#if [ -e /csa/bluetooth/.bd_addr ]
+#then
+# echo "Already .bd_addr exists"
+# exit 0
+#fi
+
+/usr/bin/setbd
+
+echo "Set BT address successes"
+
diff --git a/mobile/set-address/CMakeLists.txt b/mobile/set-address/CMakeLists.txt
new file mode 100644
index 0000000..c3e04db
--- /dev/null
+++ b/mobile/set-address/CMakeLists.txt
@@ -0,0 +1,21 @@
+CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
+PROJECT(setbd C)
+
+SET(SRCS setbd.c)
+
+SET(PREFIX ${CMAKE_INSTALL_PREFIX})
+
+FIND_PROGRAM(UNAME NAMES uname)
+EXEC_PROGRAM("${UNAME}" ARGS "-m" OUTPUT_VARIABLE "ARCH")
+IF("${ARCH}" STREQUAL "arm")
+ ADD_DEFINITIONS("-DTARGET")
+ MESSAGE("add -DTARGET")
+ENDIF("${ARCH}" STREQUAL "arm")
+
+ADD_DEFINITIONS("-DPREFIX=\"${CMAKE_INSTALL_PREFIX}\"")
+
+ADD_EXECUTABLE(${PROJECT_NAME} ${SRCS})
+TARGET_LINK_LIBRARIES(${PROJECT_NAME} ${package_LDFLAGS})
+
+INSTALL(TARGETS ${PROJECT_NAME} DESTINATION bin)
+
diff --git a/mobile/set-address/setbd.c b/mobile/set-address/setbd.c
new file mode 100644
index 0000000..fbcfff1
--- /dev/null
+++ b/mobile/set-address/setbd.c
@@ -0,0 +1,186 @@
+/*
+ * setbd.c
+ *
+ * Copyright (c) 2012-2013 Samsung Electronics Co., Ltd.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <errno.h>
+#include <fcntl.h>
+#include <unistd.h>
+#include <time.h>
+#include <sys/time.h>
+#include <dirent.h>
+#include <sys/stat.h>
+
+#define BD_ADDR_PATH "/csa/bluetooth"
+#define BD_ADDR_FILE "/csa/bluetooth/.bd_addr"
+
+#define BD_ADDR_LEN 14
+#define BD_PREFIX "0002\n"
+
+void makeRandomBD(unsigned char *buf)
+{
+ int ran;
+ int i;
+ unsigned int seed;
+ struct timeval tv;
+
+ memcpy(buf, BD_PREFIX, 5);
+ i = gettimeofday(&tv, NULL);
+
+ if (i < 0) {
+ perror("Fail to call gettimeofday()");
+ seed = time(NULL);
+ } else
+ seed = (unsigned int)tv.tv_usec;
+
+ for (i = 5; i < BD_ADDR_LEN; i++) {
+ if (7 == i) {
+ buf[i] = '\n';
+ continue;
+ }
+ ran = rand_r(&seed) % 16;
+ if (10 > ran)
+ ran += 0x30;
+ else
+ ran += 0x57;
+ buf[i] = ran;
+ }
+ printf("Random number is\r\n");
+ for (i = 0; i < BD_ADDR_LEN; i++) {
+ printf("%c", buf[i]);
+ }
+ printf("\r\n");
+}
+
+void make_bt_address_folder(void)
+{
+ DIR *dp;
+ int err;
+
+ dp = opendir(BD_ADDR_PATH);
+ if (dp == NULL) {
+ if (mkdir(BD_ADDR_PATH, 0755) < 0) {
+ err = -errno;
+ printf("mkdir: %s(%d)", strerror(-err), -err);
+ }
+ return;
+ }
+
+ closedir(dp);
+}
+
+int make_bt_address(void)
+{
+ int fd;
+ unsigned char txt[BD_ADDR_LEN];
+ char nap[4 + 1], uap[2 + 1], lap[6 + 1];
+ int ret;
+
+ make_bt_address_folder();
+
+ fd = open(BD_ADDR_FILE, O_RDONLY | O_SYNC);
+
+ if (fd < 0) {
+ printf("File not exist\n");
+
+ fd = open(BD_ADDR_FILE, O_RDWR | O_CREAT | O_TRUNC | O_SYNC,
+ 0644);
+
+ if (fd < 0) {
+ printf("Can't open address file\n");
+ return -1;
+ }
+
+ makeRandomBD(txt);
+
+ ret = write(fd, txt, BD_ADDR_LEN);
+ if (ret != BD_ADDR_LEN) {
+ printf("Unable to write device address\n");
+ close(fd);
+ unlink(BD_ADDR_FILE);
+ return -1;
+ }
+
+ lseek(fd, 0, SEEK_SET);
+ } else {
+ printf("%s is already existed\n", BD_ADDR_FILE);
+ }
+
+ ret = read(fd, nap, 5);
+ if (ret != 5)
+ goto err;
+
+ ret = read(fd, uap, 3);
+ if (ret != 3)
+ goto err;
+
+ ret = read(fd, lap, 7);
+ if (ret != 6)
+ goto err;
+
+ close(fd);
+
+ /* Unfortunately 00023fbf0a1a address is duplicated from the
+ * previous IMEI logic. So this address should be updated with
+ * random value.
+ *
+ * This is temporal code. And this would be reverted around a few week
+ * after the wrong addressed device has proper address.
+ */
+ if (strncmp(nap, "0002", 4) == 0 &&
+ strncmp(uap, "3f", 2) == 0 && strncmp(lap, "bf0a1a", 6) == 0) {
+ printf("%s has wrong address\n", BD_ADDR_FILE);
+ fd = open(BD_ADDR_FILE, O_RDWR | O_CREAT | O_TRUNC | O_SYNC,
+ 0644);
+
+ if (fd < 0) {
+ printf("Can't open address file\n");
+ return -1;
+ }
+
+ makeRandomBD(txt);
+ ret = write(fd, txt, BD_ADDR_LEN);
+ if (ret != BD_ADDR_LEN) {
+ printf("Unable to write device address\n");
+ close(fd);
+ unlink(BD_ADDR_FILE);
+ return -1;
+ }
+
+ lseek(fd, 0, SEEK_SET);
+ close(fd);
+ }
+
+ return ret;
+ err:
+ printf("read() failed, ret = %d\n", ret);
+ close(fd);
+ unlink(BD_ADDR_FILE);
+ return -1;
+}
+
+int main()
+{
+ printf("Bluetooth Address Setting\n");
+ if (make_bt_address() < 0)
+ return -1;
+
+ return 0;
+}
diff --git a/mobile/tools/CMakeLists.txt b/mobile/tools/CMakeLists.txt
new file mode 100644
index 0000000..85e215b
--- /dev/null
+++ b/mobile/tools/CMakeLists.txt
@@ -0,0 +1,25 @@
+CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
+PROJECT(bcmtool C)
+
+SET(SRCS_4330B1 bcmtool_4330b1.c)
+
+SET(BCMTOOL_4330B1 ${PROJECT_NAME}_4330b1)
+
+SET(PREFIX ${CMAKE_INSTALL_PREFIX})
+
+FIND_PROGRAM(UNAME NAMES uname)
+EXEC_PROGRAM("${UNAME}" ARGS "-m" OUTPUT_VARIABLE "ARCH")
+IF("${ARCH}" STREQUAL "arm")
+ ADD_DEFINITIONS("-DTARGET")
+ MESSAGE("add -DTARGET")
+ENDIF("${ARCH}" STREQUAL "arm")
+
+ADD_DEFINITIONS("-DPREFIX=\"${CMAKE_INSTALL_PREFIX}\"")
+ADD_DEFINITIONS("-DFACTORYFS=\"$ENV{FACTORYFS}\"")
+
+ADD_EXECUTABLE(${BCMTOOL_4330B1} ${SRCS_4330B1})
+
+TARGET_LINK_LIBRARIES(${BCMTOOL_4330B1} ${package_LDFLAGS})
+
+# install binary file
+INSTALL(TARGETS ${BCMTOOL_4330B1} DESTINATION ${PLUGIN_INSTALL_PREFIX}/bin)
diff --git a/mobile/tools/bcmtool_4330b1.c b/mobile/tools/bcmtool_4330b1.c
new file mode 100644
index 0000000..6917634
--- /dev/null
+++ b/mobile/tools/bcmtool_4330b1.c
@@ -0,0 +1,1034 @@
+/*
+ * Name: bcmtool_4330b1.c
+ *
+ * Description: Download a patchram files for the HCD format
+ *
+ * Copyright (c) 2012-2013, Broadcom Corp., All Rights Reserved.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <stdio.h>
+#include <errno.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <stdlib.h>
+#include <time.h>
+#include <string.h>
+#include <signal.h>
+#include <unistd.h>
+#include <sys/termios.h>
+#include <sys/ioctl.h>
+#include <limits.h>
+
+#define N_HCI 15
+#define HCI_UART_H4 0
+#define HCI_UART_BCSP 1
+#define HCI_UART_3WIRE 2
+#define HCI_UART_H4DS 3
+#define HCI_UART_LL 4
+#define HCIUARTSETPROTO _IOW('U', 200, int)
+#define HCIUARTGETPROTO _IOR('U', 201, int)
+#define HCIUARTGETDEVICE _IOR('U', 202, int)
+
+/* Pre baudrate change for fast download */
+#define HIGH_SPEED_PATCHRAM_DOWNLOAD TRUE
+
+/* Host Stack Idle Threshold */
+#define HCILP_IDLE_THRESHOLD 0x01
+
+/* Host Controller Idle Threshold */
+#define HCILP_HC_IDLE_THRESHOLD 0x01
+
+/* BT_WAKE Polarity - 0=Active Low, 1= Active High */
+#define HCILP_BT_WAKE_POLARITY 1
+
+/* HOST_WAKE Polarity - 0=Active Low, 1= Active High */
+#define HCILP_HOST_WAKE_POLARITY 1
+
+/* Local Feature */
+#define BCM_DISABLE_RF_PWRCTRL FALSE
+
+#define RELEASE_DATE "2011.02.07"
+#define DEBUG 1
+
+/* Broadcom AXI patch for BCM4335 chipset only */
+#define DEPLOY_4335A_AXI_BRIDGE_PATCH TRUE
+
+/* The fix for AXI bridge contention between BT and WLAN:
+ *
+ * Set this TRUE only when
+ * 1. the platform is using BCM4335A or BCM4335B0, and
+ * 2. Kernel source has implemented AXI BRIDGE lock logic.
+ */
+#ifndef DEPLOY_4335A_AXI_BRIDGE_PATCH
+#define DEPLOY_4335A_AXI_BRIDGE_PATCH FALSE
+#endif
+
+typedef unsigned char UINT8;
+typedef unsigned short UINT16;
+typedef unsigned long UINT32;
+typedef signed long INT32;
+typedef signed char INT8;
+typedef signed short INT16;
+typedef unsigned char BOOLEAN;
+
+#define FALSE 0
+#define TRUE (!FALSE)
+
+#define BD_ADDR_LEN 6 /* Device address length */
+typedef UINT8 BD_ADDR[BD_ADDR_LEN]; /* Device address */
+
+#define HCI_GRP_LINK_CONTROL_CMDS (0x01 << 10)
+#define HCI_GRP_LINK_POLICY_CMDS (0x02 << 10)
+#define HCI_GRP_HOST_CONT_BASEBAND_CMDS (0x03 << 10)
+#define HCI_GRP_INFORMATIONAL_PARAMS (0x04 << 10)
+#define HCI_GRP_STATUS_PARAMS (0x05 << 10)
+#define HCI_GRP_TESTING_CMDS (0x06 << 10)
+#define HCI_GRP_L2CAP_CMDS (0x07 << 10)
+#define HCI_GRP_L2CAP_HCI_EVTS (0x08 << 10)
+#define HCI_GRP_VENDOR_SPECIFIC (0x3F << 10)
+
+#define HCI_RESET (0x0003 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+#define HCI_SET_EVENT_FILTER (0x0005 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+#define HCI_READ_LOCAL_NAME (0x0014 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+#define HCI_READ_SCAN_ENABLE (0x0019 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+#define HCI_WRITE_SCAN_ENABLE (0x001A | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+
+#define HCI_READ_LOCAL_VERSION_INFO (0x0001 | HCI_GRP_INFORMATIONAL_PARAMS)
+#define HCI_READ_LOCAL_FEATURES (0x0003 | HCI_GRP_INFORMATIONAL_PARAMS)
+
+#define HCI_ENABLE_DEV_UNDER_TEST_MODE (0x0003 | HCI_GRP_TESTING_CMDS)
+
+#define HCI_BRCM_SUPER_PEEK_POKE (0x000A | HCI_GRP_VENDOR_SPECIFIC)
+#define VSC_WRITE_BD_ADDR (0x0001 | HCI_GRP_VENDOR_SPECIFIC)
+#define VSC_HCI_CMD_SET_LOC_FEATURES_CMD (0x000B | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_UPDATE_BAUDRATE_CMD (0x0018 | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_WRITE_SCO_PCM_INT_PARAM (0x001C | HCI_GRP_VENDOR_SPECIFIC)
+#define VSC_WRITE_PCM_DATA_FORMAT_PARAM (0x001E | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_WRITE_SLEEP_MODE (0x0027 | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_DOWNLOAD_MINI_DRV (0x002E | HCI_GRP_VENDOR_SPECIFIC)
+#define VSC_WRITE_UART_CLOCK_SETTING (0x0045 | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_VSC_WRITE_RAM (0x004C | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_VSC_LAUNCH_RAM (0x004E | HCI_GRP_VENDOR_SPECIFIC)
+
+#define VOICE_SETTING_MU_LAW_MD 0x0100
+#define VOICE_SETTING_LINEAR_MD 0x0060
+
+#define HCI_ARM_MEM_PEEK 0x04
+#define HCI_ARM_MEM_POKE 0x05
+
+#define BTUI_MAX_STRING_LENGTH_PER_LINE 255
+#define HCI_BRCM_WRITE_SLEEP_MODE_LENGTH 10
+
+#define HCI_BRCM_UPDATE_BAUD_RATE_ENCODED_LENGTH 0x02
+#define HCI_BRCM_UPDATE_BAUD_RATE_UNENCODED_LENGTH 0x06
+
+#define VSC_WRITE_UART_CLOCK_SETTING_LEN 1
+
+/* print string with time stamp */
+#define TDEBUG0(m) if(debug_mode) {print_time();fprintf(stderr,m);}
+#define TDEBUG1(m,n1) if(debug_mode) {print_time();fprintf(stderr,m,n1);}
+#define TDEBUG2(m,n1,n2) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2);}
+#define TDEBUG3(m,n1,n2,n3) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3);}
+#define TDEBUG4(m,n1,n2,n3,n4) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3,n4);}
+#define TDEBUG5(m,n1,n2,n3,n4,n5) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3,n4,n5);}
+#define TDEBUG6(m,n1,n2,n3,n4,n5,n6) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3,n4,n5,n6);}
+
+/* print just string */
+#define DEBUG0(m) if(debug_mode) {fprintf(stderr,m);}
+#define DEBUG1(m,n1) if(debug_mode) {fprintf(stderr,m,n1);}
+#define DEBUG2(m,n1,n2) if(debug_mode) {fprintf(stderr,m,n1,n2);}
+#define DEBUG3(m,n1,n2,n3) if(debug_mode) {fprintf(stderr,m,n1,n2,n3);}
+#define DEBUG4(m,n1,n2,n3,n4) if(debug_mode) {fprintf(stderr,m,n1,n2,n3,n4);}
+#define DEBUG5(m,n1,n2,n3,n4,n5) if(debug_mode) {fprintf(stderr,m,n1,n2,n3,n4,n5);}
+#define DEBUG6(m,n1,n2,n3,n4,n5,n6) if(debug_mode) {fprintf(stderr,m,n1,n2,n3,n4,n5,n6);}
+
+#define STREAM_TO_UINT8(u8, p) {u8 = (UINT8)(*(p)); (p) += 1;}
+#define STREAM_TO_UINT16(u16, p) {u16 = ((UINT16)(*(p)) + (((UINT16)(*((p) + 1))) << 8)); (p) += 2;}
+#define STREAM_TO_UINT32(u32, p) {u32 = (((UINT32)(*(p))) + ((((UINT32)(*((p) + 1)))) << 8) + ((((UINT32)(*((p) + 2)))) << 16) + ((((UINT32)(*((p) + 3)))) << 24)); (p) += 4;}
+
+#define ROTATE_BD_ADDR(p1, p2) \
+ do \
+ { \
+ p1[0] = p2[5]; \
+ p1[1] = p2[4]; \
+ p1[2] = p2[3]; \
+ p1[3] = p2[2]; \
+ p1[4] = p2[1]; \
+ p1[5] = p2[0]; \
+ } while (0)
+
+UINT8 vsc_for_pcm_config[5] = { 0x00, 0x00, 0x03, 0x03, 0x00 };
+
+/*
+ Byte1 -- 0 for MSb first
+ Byte2 -- 0 Fill value
+ Byte3 -- 1 Fill option (0:0's, 1:1's , 2:Signed, 3:Programmable)
+ Byte4 -- 1 Number of fill bits
+ Byte5 -- 1 Right justified (0 for left justified)
+*/
+
+UINT8 vsc_for_sco_pcm[5] = { 0x00, 0x01, 0x00, 0x01, 0x01 };
+
+/*
+ Neverland : PCM, 256, short, master ,master
+ Volance : PCM, 256, short, master ,master
+
+ Byte1 -- 0 for PCM 1 for UART or USB
+ Byte2 -- 0 : 128, 1: 256, 2:512, 3:1024, 4:2048 Khz
+ Byte3 -- 0 for short frame sync 1 for long frame sync
+ Byte4 -- 0 Clock direction 0 for same as sync 1 for opposite direction
+ Byte5 -- 0 for slave 1 for master
+*/
+
+int fd; /* HCI handle */
+
+BOOLEAN debug_mode = FALSE; /* Debug Mode Enable */
+
+BOOLEAN use_two_stop_bits = FALSE; /* Flag of two stop bits for tty */
+
+unsigned char buffer[1024];
+
+struct termios termios;
+
+void ChangeBaudRate(UINT32 baudrate);
+
+void exit_err(UINT8 err)
+{
+#if ( HIGH_SPEED_PATCHRAM_DOWNLOAD == TRUE )
+ ChangeBaudRate(115200);
+#endif
+ exit(err);
+}
+
+void print_time(void)
+{
+#if 0
+ struct timespec tp;
+ int rs;
+
+ rs = clock_gettime(CLOCK_REALTIME, &tp);
+ fprintf(stderr, "[%04d : %06d]\n", tp.tv_sec, tp.tv_nsec / 1000);
+ return;
+#endif
+}
+
+void dump(unsigned char *out, int len)
+{
+ int i;
+
+ for (i = 0; i < len; i++) {
+ if (!(i % 16)) {
+ DEBUG0("\n");
+ }
+ DEBUG1("%02x ", out[i]);
+ }
+ DEBUG0("\n\n");
+}
+
+UINT8 SendCommand(UINT16 opcode, UINT8 param_len, UINT8 * p_param_buf)
+{
+ UINT8 pbuf[255] = { 0, };
+ UINT8 i = 0;
+
+ pbuf[0] = 0x1;
+ pbuf[1] = (UINT8) (opcode);
+ pbuf[2] = (UINT8) (opcode >> 8);
+ pbuf[3] = param_len;
+
+ for (i = 0; i < param_len; i++) {
+ pbuf[i + 4] = *p_param_buf++;
+ }
+
+ DEBUG1("Send %d", param_len + 4);
+
+ dump(pbuf, param_len + 4);
+
+ write(fd, pbuf, param_len + 4);
+ return 0;
+}
+
+void expired(int sig)
+{
+ static UINT8 count = 0;
+ DEBUG0("expired try again\n");
+ SendCommand(HCI_RESET, 0, NULL);
+ alarm(1);
+ count++;
+
+ if (count > 3) {
+ fprintf(stderr, "[ERR] HCI reset time expired\n");
+ exit(1);
+ }
+}
+
+void read_event(int fd, unsigned char *buffer)
+{
+ int i = 0;
+ int len = 3;
+ int count;
+
+ while ((count = read(fd, &buffer[i], len)) < len) {
+ i += count;
+ len -= count;
+ }
+
+ i += count;
+ len = buffer[2];
+
+ while ((count = read(fd, &buffer[i], len)) < len) {
+ i += count;
+ len -= count;
+ }
+
+#ifdef DEBUG
+ count += i;
+
+ DEBUG1("\nreceived %d", count);
+ dump(buffer, count);
+#endif
+}
+
+INT32 filesize(char *name)
+{
+ INT32 size;
+ int flag;
+ struct stat buf;
+
+ flag = stat(name, &buf);
+ if (flag == -1)
+ return -1;
+
+ size = buf.st_size;
+ return (size);
+}
+
+void DisplayProgress(int total, int val)
+{
+#if 0
+#define PROGRESS_NUM 20
+
+ int p;
+ int i;
+ char text[PROGRESS_NUM + 2] = { 0, };
+
+ text[0] = '[';
+ text[PROGRESS_NUM + 1] = ']';
+ p = (val * PROGRESS_NUM) / total;
+
+ for (i = 1; i <= p; i++) {
+ text[i] = '=';
+ }
+
+ for (i = p + 1; i <= PROGRESS_NUM; i++) {
+ text[i] = ' ';
+ }
+
+ for (i = 0; i <= (PROGRESS_NUM + 1); i++) {
+ fprintf(stderr, "%c", text[i]);
+ }
+
+ if (p >= PROGRESS_NUM)
+ fprintf(stderr, " %6d/%6d\n", val, total);
+ else
+ fprintf(stderr, " %6d/%6d\r", val, total);
+#else
+ if (val == total)
+ fprintf(stderr, " %6d/%6d\n", val, total);
+ else
+ fprintf(stderr, " %6d/%6d\r", val, total);
+#endif
+}
+
+#if (DEPLOY_4335A_AXI_BRIDGE_PATCH == TRUE)
+/* 4335A/B0 AXI BRIDEG lock cookie */
+struct btlock {
+ int lock;
+ int cookie;
+};
+
+#define AXI_LOCK_COOKIE ('B' | 'T'<<8 | '3'<<16 | '5'<<24) /* BT35 */
+#define AXI_LOCK_FS_NODE "/dev/btlock"
+
+static const UINT8 bcm4335a_axi_patch_addr[4] =
+{
+ 0x00, 0x02, 0x0d, 0x00
+};
+
+static const UINT8 bcm4335a_axi_patch[] =
+{
+ 0x00, 0x02, 0x0d, 0x00, /* bcm4335a_axi_patch_addr */
+ 0x70, 0xb5, 0x0c, 0x49, 0x4c, 0xf6, 0x20, 0x30,
+ 0x8a, 0xf7, 0xbb, 0xf9, 0x01, 0x28, 0x0d, 0xd1,
+ 0x8a, 0xf7, 0x80, 0xf9, 0x08, 0xb1, 0x04, 0x25,
+ 0x00, 0xe0, 0x05, 0x25, 0x00, 0x24, 0x03, 0xe0,
+ 0x8a, 0xf7, 0x74, 0xf9, 0x64, 0x1c, 0xe4, 0xb2,
+ 0xac, 0x42, 0xf9, 0xd3, 0xbd, 0xe8, 0x70, 0x40,
+ 0x8a, 0xf7, 0x7f, 0xb9, 0xb0, 0x9b, 0x04, 0x00
+};
+
+/*******************************************************************************
+**
+** Function hw_4335_dl_axi_patch
+**
+** Description Download 4335Ax/4335B0 AXI BRIDGE patch
+**
+** Returns TRUE, if fw patch is sent
+** FALSE, otherwise
+**
+*******************************************************************************/
+static UINT8 hw_4335_dl_axi_patch(void)
+{
+ SendCommand(HCI_VSC_WRITE_RAM, sizeof(bcm4335a_axi_patch),
+ (UINT8 *) bcm4335a_axi_patch);
+ read_event(fd, buffer);
+
+ DEBUG0("hw_4335_dl_axi_patch downloading done");
+
+ SendCommand(HCI_VSC_LAUNCH_RAM, sizeof(bcm4335a_axi_patch_addr),
+ (UINT8 *) bcm4335a_axi_patch_addr);
+ read_event(fd, buffer);
+
+ DEBUG0("hw_4335_dl_axi_patch launching done");
+
+ return TRUE;
+}
+
+/*******************************************************************************
+**
+** Function hw_4335_release_axi_bridge_lock
+**
+** Description Notify kernel to release the AXI BRIDGE lock which was
+** acquired earlier in rfkill driver when powering on BT
+** Controller
+**
+** Returns None
+**
+*******************************************************************************/
+void hw_4335_axi_bridge_lock(void)
+{
+ int fd, ret;
+ struct btlock lock;
+
+ lock.cookie = AXI_LOCK_COOKIE;
+ lock.lock = 1;
+
+ fd = open(AXI_LOCK_FS_NODE, O_RDWR);
+ if (fd >= 0)
+ {
+ ret = write(fd, &lock, sizeof(lock));
+ DEBUG0("4335 AXI BRIDGE lock");
+ close(fd);
+ }
+ else
+ {
+ DEBUG1("Failed to unlock AXI LOCK -- can't open %s", AXI_LOCK_FS_NODE);
+ }
+}
+
+/*******************************************************************************
+**
+** Function hw_4335_release_axi_bridge_lock
+**
+** Description Notify kernel to release the AXI BRIDGE lock which was
+** acquired earlier in rfkill driver when powering on BT
+** Controller
+**
+** Returns None
+**
+*******************************************************************************/
+void hw_4335_release_axi_bridge_lock(void)
+{
+ int fd, ret;
+ struct btlock lock;
+
+ lock.cookie = AXI_LOCK_COOKIE;
+ lock.lock = 0;
+
+ fd = open(AXI_LOCK_FS_NODE, O_RDWR);
+ if (fd >= 0)
+ {
+ ret = write(fd, &lock, sizeof(lock));
+ DEBUG0("Releasing 4335 AXI BRIDGE lock");
+ close(fd);
+ }
+ else
+ {
+ DEBUG1("Failed to unlock AXI LOCK -- can't open %s", AXI_LOCK_FS_NODE);
+ }
+}
+#endif /* (DEPLOY_4335A_AXI_BRIDGE_PATCH == TRUE) */
+
+UINT8 DownloadPatchram(char *patchram1)
+{
+ UINT32 len;
+ char prm[128] = { 0, };
+ FILE *pFile = NULL;
+
+ INT32 FileSize = 0;
+ INT32 SentSize = 0;
+
+ DEBUG1("\n%s\n", patchram1);
+
+ /* HCI reset */
+ DEBUG0("HCI reset\n");
+ SendCommand(HCI_RESET, 0, NULL);
+ alarm(1);
+ read_event(fd, buffer);
+ alarm(0);
+
+#if (DEPLOY_4335A_AXI_BRIDGE_PATCH == TRUE)
+ char *p_tmp;
+
+ SendCommand(HCI_READ_LOCAL_NAME, 0, NULL);
+ read_event(fd, buffer);
+
+ p_tmp = strstr((char *)(buffer + 7), "BCM4335");
+ DEBUG1( "chip_name [%s]\n", p_tmp);
+
+ if ((p_tmp != NULL) &&
+ ((p_tmp[7] == 'A') /* 4335A */||
+ ((p_tmp[7] == 'B') && (p_tmp[8] == '0')) /* 4335B0 */)) {
+ hw_4335_dl_axi_patch();
+ }
+ hw_4335_release_axi_bridge_lock();
+#endif
+
+#if ( HIGH_SPEED_PATCHRAM_DOWNLOAD == TRUE )
+ ChangeBaudRate(921600);
+#endif
+
+ strcpy(prm, patchram1);
+
+ fprintf(stderr, "Download Start\n");
+
+ if ((pFile = fopen(prm, "r")) == NULL) {
+ fprintf(stderr, "file %s could not be opened, error %d\n", prm,
+ errno);
+ exit_err(1);
+ }
+ FileSize = filesize(prm);
+
+ SendCommand(HCI_BRCM_DOWNLOAD_MINI_DRV, 0, NULL);
+ read_event(fd, buffer);
+
+ usleep(50000);
+
+ while (fread(&buffer[1], sizeof(UINT8), 3, pFile)) {
+ buffer[0] = 0x01;
+
+ len = buffer[3];
+
+ fread(&buffer[4], sizeof(UINT8), len, pFile);
+
+ write(fd, buffer, len + 4);
+
+ /* dispaly progress */
+ SentSize += (len + 3);
+#if 0
+ DisplayProgress(FileSize, SentSize);
+#endif
+ /* dispaly progress */
+
+ read_event(fd, buffer);
+
+ }
+ fclose(pFile);
+
+ usleep(100000); /*100ms delay */
+
+ tcflush(fd, TCIOFLUSH);
+ tcgetattr(fd, &termios);
+ cfmakeraw(&termios);
+ termios.c_cflag |= CRTSCTS;
+
+ if (use_two_stop_bits)
+ termios.c_cflag |= CSTOPB;
+
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcflush(fd, TCIOFLUSH);
+ cfsetospeed(&termios, B115200);
+ cfsetispeed(&termios, B115200);
+ tcsetattr(fd, TCSANOW, &termios);
+
+ /* Send HCI_RESET Command and process event */
+ DEBUG0("HCI reset\n");
+ SendCommand(HCI_RESET, 0, NULL);
+ alarm(1);
+ read_event(fd, buffer);
+ alarm(0);
+ fprintf(stderr, "Download Complete\n");
+
+ return 0;
+}
+
+void SetScanEnable(void)
+{
+ UINT8 scan_data[1];
+
+ /* 0x00: No scan enabled */
+ /* 0x01: Inquiry scan enabled | Page scan disabled */
+ /* 0x02: Inquiry scan disabled | Page scan enabled */
+ /* 0x03: Inquiry scan enabled | Page scan enabled */
+
+ scan_data[0] = 0x03;
+ SendCommand(HCI_WRITE_SCAN_ENABLE, 1, &scan_data[0]);
+ read_event(fd, buffer);
+}
+
+void SetAudio(void)
+{
+ fprintf(stderr, "Write Audio parameter\n");
+
+ DEBUG5("vsc_for_sco_pcm = {%d,%d,%d,%d,%d}\n", vsc_for_sco_pcm[0],
+ vsc_for_sco_pcm[1], vsc_for_sco_pcm[2],
+ vsc_for_sco_pcm[3], vsc_for_sco_pcm[4]);
+
+ SendCommand(HCI_BRCM_WRITE_SCO_PCM_INT_PARAM, 5,
+ (UINT8 *) vsc_for_sco_pcm);
+ read_event(fd, buffer);
+
+ DEBUG5("vsc_for_pcm_config = {%d,%d,%d,%d,%d}\n", vsc_for_pcm_config[0],
+ vsc_for_pcm_config[1], vsc_for_pcm_config[2],
+ vsc_for_pcm_config[3], vsc_for_pcm_config[4]);
+
+ SendCommand(VSC_WRITE_PCM_DATA_FORMAT_PARAM, 5,
+ (UINT8 *) vsc_for_pcm_config);
+ read_event(fd, buffer);
+}
+
+void SetPcmConf(UINT8 p0, UINT8 p1, UINT8 p2, UINT8 p3, UINT8 p4)
+{
+ vsc_for_pcm_config[0] = p0;
+ vsc_for_pcm_config[1] = p1;
+ vsc_for_pcm_config[2] = p2;
+ vsc_for_pcm_config[3] = p3;
+ vsc_for_pcm_config[4] = p4;
+}
+
+void SetScoConf(UINT8 p0, UINT8 p1, UINT8 p2, UINT8 p3, UINT8 p4)
+{
+ vsc_for_sco_pcm[0] = p0;
+ vsc_for_sco_pcm[1] = p1;
+ vsc_for_sco_pcm[2] = p2;
+ vsc_for_sco_pcm[3] = p3;
+ vsc_for_sco_pcm[4] = p4;
+}
+
+void HCILP_Enable(BOOLEAN on)
+{
+ fprintf(stderr, "Set Low Power mode %d\n", on);
+ UINT8 data[HCI_BRCM_WRITE_SLEEP_MODE_LENGTH] = {
+ 0x01, /* Sleep Mode algorithm 1 */
+ HCILP_IDLE_THRESHOLD, /* Host Idle Treshold in 300ms */
+ HCILP_HC_IDLE_THRESHOLD, /* Host Controller Idle Treshold in 300ms *//* this should be less than scan interval. */
+ HCILP_BT_WAKE_POLARITY, /* BT_WAKE Polarity - 0=Active Low, 1= Active High */
+ HCILP_HOST_WAKE_POLARITY, /* HOST_WAKE Polarity - 0=Active Low, 1= Active High */
+ 0x01, /* Allow host Sleep during SCO */
+ 0x01, /* Combine Sleep Mode and LPM - The device will not sleep in mode 0 if this flag is set to 1, */
+ 0x00, /* UART_TXD Tri-State : 0x00 = Do not tri-state UART_TXD in sleep mode */
+ 0x00, /* NA to Mode 1 */
+ 0x00, /* NA to Mode 1 */
+ };
+
+ if (on) {
+ data[0] = 0x01;
+ } else {
+ data[0] = 0x00;
+ }
+
+ SendCommand(HCI_BRCM_WRITE_SLEEP_MODE, HCI_BRCM_WRITE_SLEEP_MODE_LENGTH,
+ (UINT8 *) data);
+ read_event(fd, buffer);
+}
+
+UINT32 uart_speed(UINT32 Speed)
+{
+ switch (Speed) {
+ case 115200:
+ return B115200;
+ case 230400:
+ return B230400;
+ case 460800:
+ return B460800;
+ case 921600:
+ return B921600;
+ case 1000000:
+ return B1000000;
+ case 1500000:
+ return B1500000;
+ case 2000000:
+ return B2000000;
+ case 2500000:
+ return B2500000;
+ case 3000000:
+ return B3000000;
+ case 4000000:
+ return B4000000;
+ default:
+ return B115200;
+ }
+}
+
+void ChangeBaudRate(UINT32 baudrate)
+{
+ UINT8 hci_data[HCI_BRCM_UPDATE_BAUD_RATE_UNENCODED_LENGTH] =
+ { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
+ UINT8 uart_clock_24 = 0x2; /* 0x1 - UART Clock 48MHz, 0x2 - UART Clock 24MHz */
+ UINT8 uart_clock_48 = 0x1; /* 0x1 - UART Clock 48MHz, 0x2 - UART Clock 24MHz */
+
+ switch (baudrate) {
+ case 115200:
+ case 230400:
+ case 460800:
+ case 921600:
+ case 1000000:
+ case 1500000:
+ case 2000000:
+ case 2500000:
+ /* Write UART Clock setting of 24MHz */
+ DEBUG0("Change UART_CLOCK 24Mhz\n");
+ SendCommand(VSC_WRITE_UART_CLOCK_SETTING,
+ VSC_WRITE_UART_CLOCK_SETTING_LEN,
+ (UINT8 *) & uart_clock_24);
+ read_event(fd, buffer);
+ break;
+
+ case 3000000:
+ case 4000000:
+ /* Write UART Clock setting of 48MHz */
+ DEBUG0("Change UART_CLOCK 48Mh\nz");
+ SendCommand(VSC_WRITE_UART_CLOCK_SETTING,
+ VSC_WRITE_UART_CLOCK_SETTING_LEN,
+ (UINT8 *) & uart_clock_48);
+ read_event(fd, buffer);
+ break;
+
+ default:
+ fprintf(stderr, "Not Support baudrate = %ld\n", baudrate);
+ exit_err(1);
+ break;
+ }
+
+ hci_data[2] = baudrate & 0xFF;
+ hci_data[3] = (baudrate >> 8) & 0xFF;
+ hci_data[4] = (baudrate >> 16) & 0xFF;
+ hci_data[5] = (baudrate >> 24) & 0xFF;
+
+ DEBUG1("Change Baudrate %ld\n", baudrate);
+
+ SendCommand(HCI_BRCM_UPDATE_BAUDRATE_CMD,
+ HCI_BRCM_UPDATE_BAUD_RATE_UNENCODED_LENGTH,
+ (UINT8 *) hci_data);
+ read_event(fd, buffer);
+
+ tcflush(fd, TCIOFLUSH);
+ tcgetattr(fd, &termios);
+ cfmakeraw(&termios);
+ termios.c_cflag |= CRTSCTS;
+
+ if (use_two_stop_bits)
+ termios.c_cflag |= CSTOPB;
+
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcflush(fd, TCIOFLUSH);
+ cfsetospeed(&termios, uart_speed(baudrate));
+ cfsetispeed(&termios, uart_speed(baudrate));
+ tcsetattr(fd, TCSANOW, &termios);
+
+}
+
+void EnableTestMode(void)
+{
+ UINT8 filter_data[] = { 0x02, 0x00, 0x02 };
+
+ /* bt sleep disable */
+ HCILP_Enable(FALSE);
+
+ /* Enable both Inquiry & Page Scans */
+ SetScanEnable();
+
+ /* Set Event Filter: Enable Auto Connect */
+ SendCommand(HCI_SET_EVENT_FILTER, 0x03, (UINT8 *) filter_data);
+ read_event(fd, buffer);
+
+ /* Enable Device under test */
+ SendCommand(HCI_ENABLE_DEV_UNDER_TEST_MODE, 0x0, NULL);
+ read_event(fd, buffer);
+
+ fprintf(stderr, "Enable Device Under Test\n");
+}
+
+void SetLocalFeatures(void)
+{
+ UINT8 *data = NULL;
+
+ DEBUG0("Read Local Feature\n");
+ SendCommand(HCI_READ_LOCAL_FEATURES, 0, NULL);
+ read_event(fd, buffer);
+
+ data = &buffer[7];
+
+#if (BCM_DISABLE_RF_PWRCTRL == TRUE)
+ fprintf(stderr, "Remove Power Control\n");
+ data[2] &= 0xFB; /* Power contrel */
+#endif
+ DEBUG0("Write Local Feature\n");
+ SendCommand(VSC_HCI_CMD_SET_LOC_FEATURES_CMD, 0x08, (UINT8 *) data);
+ read_event(fd, buffer);
+}
+
+void EnbleHCI(void)
+{
+ int i = N_HCI;
+ int proto = HCI_UART_H4;
+
+ if (ioctl(fd, TIOCSETD, &i) < 0) {
+ fprintf(stderr, "Can't set line discipline\n");
+ return;
+ }
+
+ if (ioctl(fd, HCIUARTSETPROTO, proto) < 0) {
+ fprintf(stderr, "Can't set hci protocol\n");
+ return;
+ }
+ fprintf(stderr, "Done setting line discpline\n");
+ return;
+
+}
+
+void print_usage(void)
+{
+ fprintf(stderr, "\n");
+ fprintf(stderr, "BRCM BT tool for Linux release %s\n", RELEASE_DATE);
+ fprintf(stderr, "\n");
+ fprintf(stderr,
+ " Usage: bcmtool <tty Device> <command> [command parameter],....\n\n");
+ fprintf(stderr,
+ " -FILE Patchram file name EX) -FILE=BCM43xx_xxx.hcd\n");
+ fprintf(stderr,
+ " -BAUD Set Baudrate EX) -BAUD=3000000\n");
+ fprintf(stderr,
+ " -ADDR BD addr file name EX) -ADDR=.bdaddr\n");
+ fprintf(stderr, " -SCO Enable SCO/PCM config EX) -SCO\n");
+ fprintf(stderr,
+ " -SETSCO SCO/PCM values verify EX) -SETSCO=0,1,0,1,1,0,0,3,3,0\n");
+ fprintf(stderr, " -LP Enable Low power EX) -LP\n");
+ fprintf(stderr, " -FEATURE Set local Feature EX) -FEATURE\n");
+ fprintf(stderr,
+ " -DUT Enable DUT mode(do not use with -LP) EX) -DUT\n");
+ fprintf(stderr,
+ " -ATTACH Attach BT controller to BlueZ stack EX) -ATTACH\n");
+ fprintf(stderr, " -DEBUG Debug message EX) -DEBUG\n");
+ fprintf(stderr, " -CSTOPB Set two stop bits for tty EX) -CSTOPB\n");
+ fprintf(stderr, "\n");
+}
+
+int main(int argc, char *argv[])
+{
+ UINT8 i = 0;
+
+ if (argc < 2) {
+ print_usage();
+ exit(1);
+ } else {
+ fprintf(stderr, "BRCM BT tool for Linux release %s\n",
+ RELEASE_DATE);
+ }
+
+#if (DEPLOY_4335A_AXI_BRIDGE_PATCH == TRUE)
+ hw_4335_axi_bridge_lock();
+ usleep(50000);
+#endif
+
+ /* Open dev port */
+ if ((fd = open(argv[1], O_RDWR | O_NOCTTY)) == -1) {
+ fprintf(stderr, "port %s could not be opened, error %d\n",
+ argv[1], errno);
+ exit(2);
+ }
+
+ tcflush(fd, TCIOFLUSH);
+ tcgetattr(fd, &termios);
+ cfmakeraw(&termios);
+ termios.c_cflag |= CRTSCTS;
+
+ if (use_two_stop_bits)
+ termios.c_cflag |= CSTOPB;
+
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcflush(fd, TCIOFLUSH);
+ cfsetospeed(&termios, B115200);
+ cfsetispeed(&termios, B115200);
+ tcsetattr(fd, TCSANOW, &termios);
+
+ signal(SIGALRM, expired);
+
+ for (i = 2; i < argc; i++) {
+ char *ptr = argv[i];
+
+ if (strstr(ptr, "-DEBUG")) {
+ debug_mode = TRUE;
+ DEBUG0("DEBUG On\n");
+ break;
+ }
+
+ if (strstr(ptr, "-CSTOPB")) {
+ use_two_stop_bits = TRUE;
+ DEBUG0("Use two stop bits for tty\n");
+ break;
+ }
+ }
+
+ for (i = 2; i < argc; i++) {
+ char *ptr = argv[i];
+
+ if (ptr == NULL)
+ continue;
+
+ fprintf(stderr, "[%d] %s\n", i - 1, ptr);
+
+ if (strstr(ptr, "-FILE=")) {
+ char prm_name[128];
+
+ ptr += 6;
+
+ strncpy(prm_name, ptr, 127);
+ DownloadPatchram(prm_name);
+
+ } else if (strstr(ptr, "-BAUD=")) {
+ UINT32 baudrate;
+
+ ptr += 6;
+ baudrate = atoi(ptr);
+
+ ChangeBaudRate(baudrate);
+ } else if (strstr(ptr, "-ADDR=")) {
+ char *bdaddr_filename;
+ FILE *pFile = NULL;
+
+ int bdaddr[10]; /* Displayed BD Address */
+
+ BD_ADDR local_addr; /* BD Address for write */
+
+#if 0
+ ptr += 6;
+ if (sscanf
+ (ptr, "%02X:%02X:%02X:%02X:%02X:%02X", &bdaddr[0],
+ &bdaddr[1], &bdaddr[2], &bdaddr[3], &bdaddr[4],
+ &bdaddr[5]) != 6) {
+ fprintf(stderr, "-ADDR: Parameter error");
+ exit_err(1);
+ }
+ bte_write_bdaddr(bdaddr);
+#endif
+ ptr += 6;
+ bdaddr_filename = ptr;
+
+ if (bdaddr_filename) {
+ pFile = fopen(bdaddr_filename, "r");
+ }
+
+ if (pFile) {
+ char text[BTUI_MAX_STRING_LENGTH_PER_LINE];
+
+ fgets(text, BTUI_MAX_STRING_LENGTH_PER_LINE,
+ pFile);
+ sscanf(text, "%02x%02x", &bdaddr[0],
+ &bdaddr[1]);
+
+ fgets(text, BTUI_MAX_STRING_LENGTH_PER_LINE,
+ pFile);
+ sscanf(text, "%02x", &bdaddr[2]);
+
+ fgets(text, BTUI_MAX_STRING_LENGTH_PER_LINE,
+ pFile);
+ sscanf(text, "%02x%02x%02x", &bdaddr[3],
+ &bdaddr[4], &bdaddr[5]);
+
+ fprintf(stderr,
+ "Writing B/D Address = %02X:%02X:%02X:%02X:%02X:%02X\n",
+ bdaddr[0], bdaddr[1], bdaddr[2],
+ bdaddr[3], bdaddr[4], bdaddr[5]);
+
+ ROTATE_BD_ADDR(local_addr, bdaddr);
+
+ SendCommand(VSC_WRITE_BD_ADDR, BD_ADDR_LEN,
+ (UINT8 *) local_addr);
+ read_event(fd, buffer);
+ } else {
+ fprintf(stderr, "-ADDR: file open fail\n");
+ exit_err(1);
+ }
+
+ } else if (strstr(ptr, "-SCO")) {
+ SetAudio();
+
+ } else if (strstr(ptr, "-SETSCO=")) {
+ ptr += 8;
+ int value[10];
+
+ if (sscanf
+ (ptr, "%d,%d,%d,%d,%d,%d,%d,%d,%d,%d", &value[0],
+ &value[1], &value[2], &value[3], &value[4],
+ &value[5], &value[6], &value[7], &value[8],
+ &value[9]) != 10) {
+ DEBUG0("PCM / SCO configuration value err\n");
+ DEBUG0
+ ("SCO_Routing,PCM_Interface_Rate,Frame_Type,Sync_Mode,Clock_Mode,LSB_First,Fill_bits,Fill_Method,Fill_Num,Right_Justify\n");
+ exit_err(1);
+ }
+
+ SetScoConf(value[0], value[1], value[2], value[3],
+ value[4]);
+ SetPcmConf(value[5], value[6], value[7], value[8],
+ value[9]);
+ SetAudio();
+ } else if (strstr(ptr, "-LP")) {
+ HCILP_Enable(TRUE);
+ } else if (strstr(ptr, "-DUT")) {
+ EnableTestMode();
+ } else if (strstr(ptr, "-FEATURE")) {
+ SetLocalFeatures();
+ } else if (strstr(ptr, "-ATTACH")) {
+ EnbleHCI();
+ while (1) {
+ sleep(UINT_MAX);
+ }
+ } else if (strstr(ptr, "-DEBUG")) {
+ } else if (strstr(ptr, "-CSTOPB")) {
+
+ } else {
+ fprintf(stderr, "Invalid parameter(s)!\n");
+ exit_err(1);
+ }
+ }
+
+ fprintf(stderr, "EXIT\n");
+ close(fd);
+ exit(0);
+
+ return 0;
+}
diff --git a/packaging/bluetooth-firmware-bcm.spec b/packaging/bluetooth-firmware-bcm.spec
new file mode 100644
index 0000000..4b63565
--- /dev/null
+++ b/packaging/bluetooth-firmware-bcm.spec
@@ -0,0 +1,143 @@
+Name: bluetooth-firmware-bcm
+Summary: firmware and tools for bluetooth
+# Version/Release/Group are based on mobile package
+Version: 0.2.29
+Release: 1
+Group: Hardware Support/Handset
+License: Apache License, Version 2.0
+Source0: bluetooth-firmware-bcm-%{version}.tar.gz
+
+BuildRequires: cmake
+
+%description
+firmware and tools for bluetooth
+
+%package c210
+Summary: c210 firmware and tools for bluetooth
+Group: TO_BE/FILLED
+
+%description c210
+c210 firmware and tools for bluetooth
+
+%package e4412
+Summary: e4412 firmware and tools for bluetooth
+Group: TO_BE/FILLED
+
+%description e4412
+e4412 firmware and tools for bluetooth
+
+%if %{_repository}=="wearable"
+%package msm8974
+Summary: msm8974 firmware and tools for bluetooth
+Group: TO_BE/FILLED
+
+%description msm8974
+firmware and tools for bluetooth for redwood msm8974
+%endif
+
+%prep
+%setup -q -n bluetooth-firmware-bcm-%{version}
+
+%build
+export CFLAGS+=" -fpie -fvisibility=hidden"
+export LDFLAGS+=" -Wl,--rpath=/usr/lib -Wl,--as-needed -Wl,--unresolved-symbols=ignore-in-shared-libs -pie"
+
+%if %{_repository}=="wearable"
+cd wearable
+%elseif %{_repository}=="mobile"
+cd mobile
+%endif
+
+cmake ./ -DCMAKE_INSTALL_PREFIX=%{_prefix} -DPLUGIN_INSTALL_PREFIX=%{_prefix}
+make %{?jobs:-j%jobs}
+
+%install
+rm -rf %{buildroot}
+
+%if %{_repository}=="wearable"
+cd wearable
+%elseif %{_repository}=="mobile"
+cd mobile
+%endif
+
+%make_install
+
+%if %{_repository}=="wearable"
+install -D -m 0644 LICENSE.APLv2 %{buildroot}%{_datadir}/license/bluetooth-firmware-bcm-c210
+install -D -m 0644 LICENSE.APLv2 %{buildroot}%{_datadir}/license/bluetooth-firmware-bcm-e4412
+install -D -m 0644 LICENSE.APLv2 %{buildroot}%{_datadir}/license/bluetooth-firmware-bcm-msm8974
+install -D -m 0644 LICENSE.Broadcom %{buildroot}%{_datadir}/license/bluetooth-firmware-bcm-c210
+install -D -m 0644 LICENSE.Broadcom %{buildroot}%{_datadir}/license/bluetooth-firmware-bcm-e4412
+install -D -m 0644 LICENSE.Broadcom %{buildroot}%{_datadir}/license/bluetooth-firmware-bcm-msm8974
+%elseif %{_repository}=="mobile"
+mkdir -p %{buildroot}/usr/share/license
+cp LICENSE.APLv2 %{buildroot}/usr/share/license/%{name}
+cat %{_builddir}/%{name}-%{version}/%{_repository}/LICENSE.Broadcom >> %{buildroot}/usr/share/license/%{name}
+%endif
+
+%post c210
+rm -rf %{_prefix}/etc/bluetooth/bt-dev-start.sh
+ln -s %{_prefix}/etc/bluetooth/bt-dev-start-c210.sh %{_prefix}/etc/bluetooth/bt-dev-start.sh
+
+%post e4412
+rm -rf %{_prefix}/etc/bluetooth/bt-dev-start.sh
+ln -s %{_prefix}/etc/bluetooth/bt-dev-start-e4412.sh %{_prefix}/etc/bluetooth/bt-dev-start.sh
+
+%if %{_repository}=="wearable"
+%post msm8974
+rm -rf %{_prefix}/etc/bluetooth/bt-dev-start.sh
+ln -s %{_prefix}/etc/bluetooth/bt-dev-start-msm8974.sh %{_prefix}/etc/bluetooth/bt-dev-start.sh
+%endif
+
+%files c210
+%manifest %{_repository}/bluetooth-firmware-bcm.manifest
+%defattr(-,root,root,-)
+%{_bindir}/bcmtool_4330b1
+%{_bindir}/setbd
+%if %{_repository}=="wearable"
+%{_prefix}/etc/bluetooth/BCM4330B1_002.001.003.0013.0000_SS-SLP7-B42_NoExtLNA_37_4MHz-TEST-ONLY.hcd
+%endif
+%{_prefix}/etc/bluetooth/BCM4330B1_002.001.003.0221.0265.hcd
+%attr(755,-,-) %{_prefix}/etc/bluetooth/bt-dev-end.sh
+%attr(755,-,-) %{_prefix}/etc/bluetooth/bt-dev-start-c210.sh
+%attr(755,-,-) %{_prefix}/etc/bluetooth/bt-set-addr.sh
+%if %{_repository}=="wearable"
+%{_datadir}/license/bluetooth-firmware-bcm-c210
+%elseif %{_repository}=="mobile"
+/usr/share/license/%{name}
+%endif
+
+%files e4412
+%manifest %{_repository}/bluetooth-firmware-bcm.manifest
+%defattr(-,root,root,-)
+%{_bindir}/bcmtool_4330b1
+%{_bindir}/setbd
+%if %{_repository}=="wearable"
+%{_prefix}/etc/bluetooth/BCM20710A1_001.002.014.0059.0060.hcd
+%{_prefix}/etc/bluetooth/BCM4334B0_002.001.013.1675.1676_B2_ORC.hcd
+#%{_prefix}/etc/bluetooth/BCM4334W_001.002.003.0874.0000_Samsung_Rinato_TEST_ONLY.hcd
+#%{_prefix}/etc/bluetooth/BCM43342A1_001.002.003.0874.0000_SEMCO_B58_TEST_ONLY.hcd
+%{_prefix}/etc/bluetooth/BCM4334W_Rinato_TestOnly.hcd
+%{_prefix}/etc/bluetooth/BCM4334W_001.002.003.0997.1027_B58_ePA.hcd
+%{_datadir}/license/bluetooth-firmware-bcm-e4412
+%elseif %{_repository}=="mobile"
+%{_prefix}/etc/bluetooth/BCM4334B0_002.001.013.0079.0081.hcd
+/usr/share/license/%{name}
+%endif
+%attr(755,-,-) %{_prefix}/etc/bluetooth/bt-dev-end.sh
+%attr(755,-,-) %{_prefix}/etc/bluetooth/bt-dev-start-e4412.sh
+%attr(755,-,-) %{_prefix}/etc/bluetooth/bt-set-addr.sh
+
+%if %{_repository}=="wearable"
+%files msm8974
+%manifest %{_repository}/bluetooth-firmware-bcm.manifest
+%defattr(-,root,root,-)
+%{_bindir}/bcmtool_4330b1
+%{_bindir}/setbd
+%{_prefix}/etc/bluetooth/BCM4335B0_002.001.006.0233.0234_ORC_RedWood.hcd
+%{_prefix}/etc/bluetooth/BCM4339_003.001.009.0030.0122_ORC_RedWood.hcd
+%attr(755,-,-) %{_prefix}/etc/bluetooth/bt-dev-end.sh
+%attr(755,-,-) %{_prefix}/etc/bluetooth/bt-dev-start-msm8974.sh
+%attr(755,-,-) %{_prefix}/etc/bluetooth/bt-set-addr.sh
+%{_datadir}/license/bluetooth-firmware-bcm-msm8974
+%endif
diff --git a/wearable/AUTHORS b/wearable/AUTHORS
new file mode 100644
index 0000000..1a599df
--- /dev/null
+++ b/wearable/AUTHORS
@@ -0,0 +1,4 @@
+Hocheol Seo <hocheol.seo@samsung.com>
+Girish Ashok Joshi <girish.joshi@samsung.com>
+Chanyeol Park <chanyeol.park@samsung.com>
+DoHyun Pyun <dh79.pyun@samsung.com>
diff --git a/wearable/CMakeLists.txt b/wearable/CMakeLists.txt
new file mode 100644
index 0000000..94e9747
--- /dev/null
+++ b/wearable/CMakeLists.txt
@@ -0,0 +1,12 @@
+CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
+
+FOREACH(flag ${package_CFLAGS})
+ SET(EXTRA_CFLAGS "${EXTRA_CFLAGS} ${flag}")
+ENDFOREACH(flag)
+
+SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_CFLAGS}")
+
+ADD_SUBDIRECTORY(set-address)
+ADD_SUBDIRECTORY(tools)
+ADD_SUBDIRECTORY(firmware)
+ADD_SUBDIRECTORY(scripts)
diff --git a/wearable/LICENSE.APLv2 b/wearable/LICENSE.APLv2
new file mode 100644
index 0000000..a06208b
--- /dev/null
+++ b/wearable/LICENSE.APLv2
@@ -0,0 +1,204 @@
+Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
+
+ Apache License
+ Version 2.0, January 2004
+ http://www.apache.org/licenses/
+
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+ 1. Definitions.
+
+ "License" shall mean the terms and conditions for use, reproduction,
+ and distribution as defined by Sections 1 through 9 of this document.
+
+ "Licensor" shall mean the copyright owner or entity authorized by
+ the copyright owner that is granting the License.
+
+ "Legal Entity" shall mean the union of the acting entity and all
+ other entities that control, are controlled by, or are under common
+ control with that entity. For the purposes of this definition,
+ "control" means (i) the power, direct or indirect, to cause the
+ direction or management of such entity, whether by contract or
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
+ outstanding shares, or (iii) beneficial ownership of such entity.
+
+ "You" (or "Your") shall mean an individual or Legal Entity
+ exercising permissions granted by this License.
+
+ "Source" form shall mean the preferred form for making modifications,
+ including but not limited to software source code, documentation
+ source, and configuration files.
+
+ "Object" form shall mean any form resulting from mechanical
+ transformation or translation of a Source form, including but
+ not limited to compiled object code, generated documentation,
+ and conversions to other media types.
+
+ "Work" shall mean the work of authorship, whether in Source or
+ Object form, made available under the License, as indicated by a
+ copyright notice that is included in or attached to the work
+ (an example is provided in the Appendix below).
+
+ "Derivative Works" shall mean any work, whether in Source or Object
+ form, that is based on (or derived from) the Work and for which the
+ editorial revisions, annotations, elaborations, or other modifications
+ represent, as a whole, an original work of authorship. For the purposes
+ of this License, Derivative Works shall not include works that remain
+ separable from, or merely link (or bind by name) to the interfaces of,
+ the Work and Derivative Works thereof.
+
+ "Contribution" shall mean any work of authorship, including
+ the original version of the Work and any modifications or additions
+ to that Work or Derivative Works thereof, that is intentionally
+ submitted to Licensor for inclusion in the Work by the copyright owner
+ or by an individual or Legal Entity authorized to submit on behalf of
+ the copyright owner. For the purposes of this definition, "submitted"
+ means any form of electronic, verbal, or written communication sent
+ to the Licensor or its representatives, including but not limited to
+ communication on electronic mailing lists, source code control systems,
+ and issue tracking systems that are managed by, or on behalf of, the
+ Licensor for the purpose of discussing and improving the Work, but
+ excluding communication that is conspicuously marked or otherwise
+ designated in writing by the copyright owner as "Not a Contribution."
+
+ "Contributor" shall mean Licensor and any individual or Legal Entity
+ on behalf of whom a Contribution has been received by Licensor and
+ subsequently incorporated within the Work.
+
+ 2. Grant of Copyright License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ copyright license to reproduce, prepare Derivative Works of,
+ publicly display, publicly perform, sublicense, and distribute the
+ Work and such Derivative Works in Source or Object form.
+
+ 3. Grant of Patent License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ (except as stated in this section) patent license to make, have made,
+ use, offer to sell, sell, import, and otherwise transfer the Work,
+ where such license applies only to those patent claims licensable
+ by such Contributor that are necessarily infringed by their
+ Contribution(s) alone or by combination of their Contribution(s)
+ with the Work to which such Contribution(s) was submitted. If You
+ institute patent litigation against any entity (including a
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
+ or a Contribution incorporated within the Work constitutes direct
+ or contributory patent infringement, then any patent licenses
+ granted to You under this License for that Work shall terminate
+ as of the date such litigation is filed.
+
+ 4. Redistribution. You may reproduce and distribute copies of the
+ Work or Derivative Works thereof in any medium, with or without
+ modifications, and in Source or Object form, provided that You
+ meet the following conditions:
+
+ (a) You must give any other recipients of the Work or
+ Derivative Works a copy of this License; and
+
+ (b) You must cause any modified files to carry prominent notices
+ stating that You changed the files; and
+
+ (c) You must retain, in the Source form of any Derivative Works
+ that You distribute, all copyright, patent, trademark, and
+ attribution notices from the Source form of the Work,
+ excluding those notices that do not pertain to any part of
+ the Derivative Works; and
+
+ (d) If the Work includes a "NOTICE" text file as part of its
+ distribution, then any Derivative Works that You distribute must
+ include a readable copy of the attribution notices contained
+ within such NOTICE file, excluding those notices that do not
+ pertain to any part of the Derivative Works, in at least one
+ of the following places: within a NOTICE text file distributed
+ as part of the Derivative Works; within the Source form or
+ documentation, if provided along with the Derivative Works; or,
+ within a display generated by the Derivative Works, if and
+ wherever such third-party notices normally appear. The contents
+ of the NOTICE file are for informational purposes only and
+ do not modify the License. You may add Your own attribution
+ notices within Derivative Works that You distribute, alongside
+ or as an addendum to the NOTICE text from the Work, provided
+ that such additional attribution notices cannot be construed
+ as modifying the License.
+
+ You may add Your own copyright statement to Your modifications and
+ may provide additional or different license terms and conditions
+ for use, reproduction, or distribution of Your modifications, or
+ for any such Derivative Works as a whole, provided Your use,
+ reproduction, and distribution of the Work otherwise complies with
+ the conditions stated in this License.
+
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
+ any Contribution intentionally submitted for inclusion in the Work
+ by You to the Licensor shall be under the terms and conditions of
+ this License, without any additional terms or conditions.
+ Notwithstanding the above, nothing herein shall supersede or modify
+ the terms of any separate license agreement you may have executed
+ with Licensor regarding such Contributions.
+
+ 6. Trademarks. This License does not grant permission to use the trade
+ names, trademarks, service marks, or product names of the Licensor,
+ except as required for reasonable and customary use in describing the
+ origin of the Work and reproducing the content of the NOTICE file.
+
+ 7. Disclaimer of Warranty. Unless required by applicable law or
+ agreed to in writing, Licensor provides the Work (and each
+ Contributor provides its Contributions) on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ implied, including, without limitation, any warranties or conditions
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+ PARTICULAR PURPOSE. You are solely responsible for determining the
+ appropriateness of using or redistributing the Work and assume any
+ risks associated with Your exercise of permissions under this License.
+
+ 8. Limitation of Liability. In no event and under no legal theory,
+ whether in tort (including negligence), contract, or otherwise,
+ unless required by applicable law (such as deliberate and grossly
+ negligent acts) or agreed to in writing, shall any Contributor be
+ liable to You for damages, including any direct, indirect, special,
+ incidental, or consequential damages of any character arising as a
+ result of this License or out of the use or inability to use the
+ Work (including but not limited to damages for loss of goodwill,
+ work stoppage, computer failure or malfunction, or any and all
+ other commercial damages or losses), even if such Contributor
+ has been advised of the possibility of such damages.
+
+ 9. Accepting Warranty or Additional Liability. While redistributing
+ the Work or Derivative Works thereof, You may choose to offer,
+ and charge a fee for, acceptance of support, warranty, indemnity,
+ or other liability obligations and/or rights consistent with this
+ License. However, in accepting such obligations, You may act only
+ on Your own behalf and on Your sole responsibility, not on behalf
+ of any other Contributor, and only if You agree to indemnify,
+ defend, and hold each Contributor harmless for any liability
+ incurred by, or claims asserted against, such Contributor by reason
+ of your accepting any such warranty or additional liability.
+
+ END OF TERMS AND CONDITIONS
+
+ APPENDIX: How to apply the Apache License to your work.
+
+ To apply the Apache License to your work, attach the following
+ boilerplate notice, with the fields enclosed by brackets "[]"
+ replaced with your own identifying information. (Don't include
+ the brackets!) The text should be enclosed in the appropriate
+ comment syntax for the file format. We also recommend that a
+ file or class name and description of purpose be included on the
+ same "printed page" as the copyright notice for easier
+ identification within third-party archives.
+
+ Copyright [yyyy] [name of copyright owner]
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+
diff --git a/wearable/LICENSE.Broadcom b/wearable/LICENSE.Broadcom
new file mode 100644
index 0000000..acf4e62
--- /dev/null
+++ b/wearable/LICENSE.Broadcom
@@ -0,0 +1,64 @@
+SOFTWARE LICENSE AGREEMENT
+
+The accompanying software in binary code form ("Software"), is licensed to you,
+or, if you are accepting on behalf of an entity, the entity and its affiliates
+exercising rights hereunder ("Licensee") subject to the terms of this software
+license agreement ("Agreement"), unless Licensee and Broadcom Corporation
+("Broadcom") execute a separate written software license agreement governing
+use of the Software. ANY USE, REPRODUCTION, OR DISTRIBUTION OF THE SOFTWARE
+CONSTITUTES LICENSEE'S ACCEPTANCE OF THIS AGREEMENT.
+
+1. License. Subject to the terms and conditions of this Agreement,
+Broadcom hereby grants to Licensee a limited, non-exclusive, non-transferable,
+royalty-free license: (i) to use and integrate the Software with any other
+software; and (ii) to reproduce and distribute the Software complete,
+unmodified, and as provided by Broadcom, solely for use with Broadcom
+proprietary integrated circuit product(s) sold by Broadcom with which the
+Software was designed to be used, or their successors.
+
+2. Restrictions. Licensee shall distribute Software with a copy of this
+Agreement. Licensee shall not remove, efface or obscure any copyright or
+trademark notices from the Software. Reproductions of the Broadcom copyright
+notice shall be included with each copy of the Software, except where such
+Software is embedded in a manner not readily accessible to the end user.
+Licensee shall not: (i) use, license, sell or otherwise distribute the Software
+except as provided in this Agreement; (ii) attempt to modify in any way,
+reverse engineer, decompile or disassemble any portion of the Software; or
+(iii) use the Software or other material in violation of any applicable law or
+regulation, including but not limited to any regulatory agency. This Agreement
+shall automatically terminate upon Licensee’s failure to comply with any of the
+terms of this Agreement. In such event, Licensee will destroy all copies of the
+Software and its component parts.
+
+3. Ownership. The Software is licensed and not sold. Title to and
+ownership of the Software, including all intellectual property rights thereto,
+and any portion thereof remain with Broadcom or its licensors. Licensee hereby
+covenants that it will not assert any claim that the Software created by or for
+Broadcom infringe any intellectual property right owned or controlled by
+Licensee.
+
+4. Disclaimer. THE SOFTWARE IS OFFERED "AS IS," AND BROADCOM PROVIDES AND
+GRANTS AND LICENSEE RECEIVES NO SUPPORT AND NO WARRANTIES OF ANY KIND, EXPRESS
+OR IMPLIED, BY STATUTE, COMMUNICATION OR CONDUCT WITH LICENSEE, OR OTHERWISE.
+BROADCOM SPECIFICALLY DISCLAIMS ANY IMPLIED WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A SPECIFIC PURPOSE, OR NONINFRINGEMENT CONCERNING THE SOFTWARE OR
+ANY UPGRADES TO OR DOCUMENTATION FOR THE SOFTWARE. WITHOUT LIMITATION OF THE
+ABOVE, BROADCOM GRANTS NO WARRANTY THAT THE SOFTWARE IS ERROR-FREE OR WILL
+OPERATE WITHOUT INTERRUPTION, AND GRANTS NO WARRANTY REGARDING ITS USE OR THE
+RESULTS THEREFROM INCLUDING, WITHOUT LIMITATION, ITS CORRECTNESS, ACCURACY, OR
+RELIABILITY. TO THE MAXIMUM EXTENT PERMITTED BY LAW, IN NO EVENT SHALL BROADCOM
+OR ANY OF ITS LICENSORS HAVE ANY LIABILITY FOR ANY DIRECT, INDIRECT,
+INCIDENTAL, SPECIAL, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND ON ANY THEORY
+OF LIABILITY, WHETHER FOR BREACH OF CONTRACT, TORT (INCLUDING NEGLIGENCE) OR
+OTHERWISE, ARISING OUT OF THIS AGREEMENT OR USE, REPRODUCTION, OR DISTRIBUTION
+OF THE SOFTWARE, INCLUDING BUT NOT LIMITED TO LOSS OF DATA AND LOSS OF PROFITS,
+EVEN IF SUCH PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. THESE
+LIMITATIONS SHALL APPLY NOTWITHSTANDING ANY FAILURE OF ESSENTIAL PURPOSE OF ANY
+LIMITED REMEDY.
+
+5. Export Laws. LICENSEE UNDERSTANDS AND AGREES THAT THE SOFTWARE IS
+SUBJECT TO UNITED STATES AND OTHER APPLICABLE EXPORT-RELATED LAWS AND
+REGULATIONS AND THAT LICENSEE MAY NOT EXPORT, RE-EXPORT OR TRANSFER THE
+SOFTWARE OR ANY DIRECT PRODUCT OF THE SOFTWARE EXCEPT AS PERMITTED UNDER THOSE
+LAWS. WITHOUT LIMITING THE FOREGOING, EXPORT, RE-EXPORT, OR TRANSFER OF THE
+SOFTWARE TO CUBA, IRAN, NORTH KOREA, SUDAN, AND SYRIA IS PROHIBITED.
diff --git a/wearable/NOTICE b/wearable/NOTICE
new file mode 100644
index 0000000..411d0c9
--- /dev/null
+++ b/wearable/NOTICE
@@ -0,0 +1,10 @@
+Copyright (c) 2012 Samsung Electronics Co., Ltd. All rights reserved.
+Except as noted, this software is licensed under Apache License, Version 2.
+Please, see the LICENSE.APLv2 file for Apache License terms and conditions.
+
+The following files are copyrighted by Broadcom and licensed under
+a separate license. Please, see the LICENSE.Broadcom file for
+license terms and conditions.
+
+Copyright (c) 2012 Broadcom Co., Ltd. All rights reserved.
+- firmware/*.hcd
diff --git a/wearable/bluetooth-firmware-bcm.manifest b/wearable/bluetooth-firmware-bcm.manifest
new file mode 100644
index 0000000..a3dc534
--- /dev/null
+++ b/wearable/bluetooth-firmware-bcm.manifest
@@ -0,0 +1,8 @@
+<manifest>
+ <define>
+ <domain name="bt_firmware"/>
+ </define>
+ <request>
+ <domain name="bt_firmware"/>
+ </request>
+</manifest>
diff --git a/wearable/debian/bluetooth-firmware-bcm-c210.install b/wearable/debian/bluetooth-firmware-bcm-c210.install
new file mode 100644
index 0000000..2490361
--- /dev/null
+++ b/wearable/debian/bluetooth-firmware-bcm-c210.install
@@ -0,0 +1,3 @@
+usr/bin/*
+usr/etc/bluetooth/BCM4330B1_002.001.003.0013.0000_SS-SLP7-B42_NoExtLNA_37_4MHz-TEST-ONLY.hcd
+usr/etc/bluetooth/BCM4330B1_002.001.003.0221.0265.hcd
diff --git a/wearable/debian/bluetooth-firmware-bcm-c210.postinst.in b/wearable/debian/bluetooth-firmware-bcm-c210.postinst.in
new file mode 100644
index 0000000..93d80e5
--- /dev/null
+++ b/wearable/debian/bluetooth-firmware-bcm-c210.postinst.in
@@ -0,0 +1,12 @@
+#!/bin/sh
+
+# Change File Permission
+chmod 644 @PREFIX@/etc/bluetooth/BCM4330B1_002.001.003.0013.0000_SS-SLP7-B42_NoExtLNA_37_4MHz-TEST-ONLY.hcd
+chmod 644 @PREFIX@/etc/bluetooth/BCM4330B1_002.001.003.0221.0265.hcd
+
+# root case
+if [ ${USER} = "root" ]
+then
+ chown root:root @PREFIX@/etc/bluetooth/BCM4330B1_002.001.003.0013.0000_SS-SLP7-B42_NoExtLNA_37_4MHz-TEST-ONLY.hcd
+ chown root:root @PREFIX@/etc/bluetooth/BCM4330B1_002.001.003.0221.0265.hcd
+fi
diff --git a/wearable/debian/bluetooth-firmware-bcm-e4412.install b/wearable/debian/bluetooth-firmware-bcm-e4412.install
new file mode 100644
index 0000000..7bd2b2c
--- /dev/null
+++ b/wearable/debian/bluetooth-firmware-bcm-e4412.install
@@ -0,0 +1,3 @@
+usr/bin/*
+usr/etc/bluetooth/BCM4334B0_002.001.013.0079.0081.hcd
+usr/etc/bluetooth/BCM4334B0_002.001.013.0079.0084.hcd
diff --git a/wearable/debian/bluetooth-firmware-bcm-e4412.postinst.in b/wearable/debian/bluetooth-firmware-bcm-e4412.postinst.in
new file mode 100644
index 0000000..6007780
--- /dev/null
+++ b/wearable/debian/bluetooth-firmware-bcm-e4412.postinst.in
@@ -0,0 +1,12 @@
+#!/bin/sh
+
+# Change File Permission
+chmod 644 @PREFIX@/etc/bluetooth/BCM4334B0_002.001.013.0079.0081.hcd
+chmod 644 @PREFIX@/etc/bluetooth/BCM4334B0_002.001.013.0079.0084.hcd
+
+# root case
+if [ ${USER} = "root" ]
+then
+ chown root:root @PREFIX@/etc/bluetooth/BCM4334B0_002.001.013.0079.0081.hcd
+ chown root:root @PREFIX@/etc/bluetooth/BCM4334B0_002.001.013.0079.0084.hcd
+fi
diff --git a/wearable/debian/changelog b/wearable/debian/changelog
new file mode 100644
index 0000000..208ef48
--- /dev/null
+++ b/wearable/debian/changelog
@@ -0,0 +1,127 @@
+bluetooth-firmware-bcm (0.2.38-2) unstable; urgency=low
+
+ * Tagging and upload the package
+ * Git: magnolia/adaptation/devices/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.38-2
+
+ -- Sangki Park <sangki79.park@samsung.com> Wed, 06 Mar 2013 10:02:22 +0900
+
+bluetooth-firmware-bcm (0.2.38) unstable; urgency=low
+
+ * update SEMCO SWB-B52 module patchram for Redwood45_3G
+ * Git: magnolia/adaptation/devices/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.38
+
+ -- Sangki Park <sangki79.park@samsung.com> Tue, 05 Mar 2013 11:33:46 +0900
+
+bluetooth-firmware-bcm (0.2.37) unstable; urgency=low
+
+ * update Murata module patchram for Redwood45_LTE_JPN
+ * Git: magnolia/adaptation/devices/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.37
+
+ -- Sangki Park <sangki79.park@samsung.com> Tue, 26 Feb 2013 10:12:50 +0900
+
+bluetooth-firmware-bcm (0.2.36) unstable; urgency=low
+
+ * Create folder on runtime
+ * Git: magnolia/adaptation/devices/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.36
+
+ -- InJun Yang <injun.yang@samsung.com> Fri, 22 Feb 2013 12:26:45 +0900
+
+bluetooth-firmware-bcm (0.2.34) unstable; urgency=low
+
+ * Change bd_addr file path
+ * Git: magnolia/adaptation/devices/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.35
+
+ -- InJun Yang <injun.yang@samsung.com> Thu, 21 Feb 2013 14:22:31 +0900
+
+bluetooth-firmware-bcm (0.2.33) unstable; urgency=low
+
+ * Apply the visibility hidden option
+ * Git: magnolia/adaptation/devices/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.33
+
+ -- DoHyun Pyun <dh79.pyun@samsung.com> Tue, 05 Feb 2013 18:54:06 +0900
+
+bluetooth-firmware-bcm (0.2.32) precise; urgency=low
+
+ * Remove link package method
+ * Git: magnolia/adaptation/devices/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.31
+
+ -- Jaekyun Lee <jkyun.lee@samsung.com> Thu, 10 Jan 2013 15:25:37 +0900
+
+bluetooth-firmware-bcm (0.2.30) unstable; urgency=low
+
+ * Fix power consumption issue after BT off.
+ * Git: magnolia/adaptation/devices/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.30
+
+ -- Sangki Park <sangki79.park@samsung.com> Thu, 10 Jan 2013 07:34:33 +0900
+
+bluetooth-firmware-bcm (0.2.29) unstable; urgency=low
+
+ * Update bluetooth firmware
+ * Git: magnolia/adaptation/devices/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.29
+
+ -- Sangki Park <sangki79.park@samsung.com> Fri, 21 Dec 2012 15:01:26 +0900
+
+bluetooth-firmware-bcm (0.2.28) unstable; urgency=low
+
+ * Copy the license file in target
+ * Git: magnolia/adaptation/devices/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.28
+
+ -- Jaekyun Lee <jkyun.lee@samsung.com> Thu, 11 Oct 2012 15:55:57 +0900
+
+bluetooth-firmware-bcm (0.2.27) unstable; urgency=low
+
+ * Apply smack manifest file
+ * Git: slp/pkgs/b/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.27
+
+ -- Sangki Park <sangki79.park@samsung.com> Fri, 21 Sep 2012 09:15:16 +0900
+
+bluetooth-firmware-bcm (0.2.26) unstable; urgency=low
+
+ * change a UART baudrate from 921K to 3M
+ * Git: slp/pkgs/b/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.26
+
+ -- sangki79.park <sangki79-park@sangki> Tue, 10 Jul 2012 14:25:45 +0900
+
+bluetooth-firmware-bcm (0.2.25) unstable; urgency=low
+
+ * Fix set bd bug as TAPI IMEI API deprecated
+ * Git: slp/pkgs/b/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.25
+
+ -- Chanyeol Park <chanyeol.park@samsung.com> Sun, 25 Mar 2012 17:31:22 +0900
+
+bluetooth-firmware-bcm (0.2.24) unstable; urgency=low
+
+ * Change BT firmware PCM from "Master" to "Slave".
+ * Git: slp/pkgs/b/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.24
+
+ -- Chanyeol Park <chanyeol.park@samsung.com> Thu, 22 Mar 2012 17:08:10 +0900
+
+bluetooth-firmware-bcm (0.2.23) unstable; urgency=low
+
+ * rename es4412 to e4412
+ * Git: slp/pkgs/b/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.23
+
+ -- Jaekyun Lee <jkyun.lee@samsung.com> Mon, 12 Mar 2012 14:31:49 +0900
+
+bluetooth-firmware-bcm (0.2.22) unstable; urgency=low
+
+ * split firmware from bluetooth-dev-tool
+ * Git: slp/pkgs/b/bluetooth-firmware-bcm
+ * Tag: bluetooth-firmware-bcm_0.2.22
+
+ -- Jaekyun Lee <jkyun.lee@samsung.com> Mon, 05 Mar 2012 15:08:22 +0900
diff --git a/wearable/debian/compat b/wearable/debian/compat
new file mode 100644
index 0000000..7ed6ff8
--- /dev/null
+++ b/wearable/debian/compat
@@ -0,0 +1 @@
+5
diff --git a/wearable/debian/control b/wearable/debian/control
new file mode 100644
index 0000000..8e26bb4
--- /dev/null
+++ b/wearable/debian/control
@@ -0,0 +1,44 @@
+Source: bluetooth-firmware-bcm
+Section: devel
+Priority: optional
+Maintainer: DoHyun Pyun <dh79.pyun@samsung.com>, ChanYeol Park <chanyeol.park@samsung.com>, Girish A J <girish.joshi@samsung.com>, Jaekyun Lee <jkyun.lee@samsung.com>
+Uploaders: Sunil Behera <sunil.behera@samsung.com>
+Build-Depends: debhelper (>= 5), libglib2.0-dev, libvconf-dev
+Standards-Version: 3.7.2
+Homepage: N/A
+
+Package: bluetooth-firmware-bcm-c210
+Architecture: any
+Section: utils
+Depends: ${shlibs:Depends}, ${misc:Depends}, bluetooth-tools
+Conflicts: bluetooth-firmware-bcm-e4412
+Breaks: bluetooth-firmware-bcm-e4412
+Replaces: bluetooth-firmware-bcm-e4412
+Description: firmware and tools for C210 devices
+ firmware and tools for C210 devices
+
+Package: bluetooth-firmware-bcm-e4412
+Architecture: any
+Section: utils
+Depends: ${shlibs:Depends}, ${misc:Depends}, bluetooth-tools
+Conflicts: bluetooth-firmware-bcm-c210
+Breaks: bluetooth-firmware-bcm0-c210
+Replaces: bluetooth-firmware-bcm0-c210
+Description: firmware and tools for e4412 devices
+ firmware and tools for e4412 devices
+
+Package: bluetooth-firmware-bcm-c210-dbg
+Section: debug
+Architecture: any
+Depends: ${shlibs:Depends}, ${misc:Depends}, bluetooth-firmware-bcm-c210 (= ${Source-Version})
+Description: Tools for bluetooth-firmware-bcm (unstripped)
+ The package contains detached debugging symbols for the binary packages
+ produced by the bluetooth-firmware-bcm soruce.
+
+Package: bluetooth-firmware-bcm-e4412-dbg
+Section: debug
+Architecture: any
+Depends: ${shlibs:Depends}, ${misc:Depends}, bluetooth-firmware-bcm-e4412 (= ${Source-Version})
+Description: Tools for bluetooth-firmware-bcm (unstripped)
+ The package contains detached debugging symbols for the binary packages
+ produced by the bluetooth-firmware-bcm soruce.
diff --git a/wearable/debian/rules b/wearable/debian/rules
new file mode 100755
index 0000000..d92d709
--- /dev/null
+++ b/wearable/debian/rules
@@ -0,0 +1,125 @@
+#!/usr/bin/make -f
+
+# Uncomment this to turn on verbose mode.
+#export DH_VERBOSE=1
+
+CFLAGS ?= -Wall -g
+LDFLAGS ?=
+PREFIX ?= /usr
+DATADIR ?= /opt
+PLUGIN_PREFIX ?= /usr
+
+CMAKE_BUILD_DIR ?= $(CURDIR)/cmake_build_tmp
+
+ifneq (,$(findstring noopt,$(DEB_BUILD_OPTIONS)))
+ CFLAGS += -O0
+else
+ CFLAGS += -O2
+endif
+
+LDFLAGS += -Wl,--rpath=$(PREFIX)/lib -Wl,--as-needed -Wl,--unresolved-symbols=ignore-in-shared-libs
+
+configure: configure-stamp
+configure-stamp:
+ dh_testdir
+ # Add here commands to configure the package.
+ mkdir -p $(CMAKE_BUILD_DIR) && \
+ cd $(CMAKE_BUILD_DIR) && \
+ CFLAGS="$(CFLAGS) -fpie" LDFLAGS="$(LDFLAGS) -pie" \
+ cmake .. -DCMAKE_INSTALL_PREFIX=$(PREFIX) -DPLUGIN_INSTALL_PREFIX=$(PLUGIN_PREFIX)
+
+ touch configure-stamp
+
+build: build-stamp
+
+build-stamp: configure-stamp
+ dh_testdir
+
+ # Add here commands to compile the package.
+ cd $(CMAKE_BUILD_DIR) && $(MAKE)
+
+ for f in `find $(CURDIR)/debian/ -name "*.in"`; do \
+ cat $$f > $${f%.in}; \
+ sed -i -e "s#@PREFIX@#$(PREFIX)#g" $${f%.in}; \
+ sed -i -e "s#@DATADIR@#$(DATADIR)#g" $${f%.in}; \
+ sed -i -e "s#@PLUGIN_PREFIX@#$(PLUGIN_PREFIX)#g" $${f%.in}; \
+ done
+
+ touch $@
+
+clean:
+ dh_testdir
+ dh_testroot
+ rm -f build-stamp configure-stamp
+
+ # Add here commands to clean up after the build process.
+ -rm -rf $(CMAKE_BUILD_DIR)
+ for f in `find $(CURDIR)/debian/ -name "*.in"`; do \
+ rm -f $${f%.in}; \
+ done
+
+ dh_clean
+
+install: build
+ dh_testdir
+ dh_testroot
+ dh_clean -k
+ dh_installdirs
+
+ # Add here commands to install the package into debian/wavplayer.
+ cd $(CMAKE_BUILD_DIR) && $(MAKE) DESTDIR=$(CURDIR)/debian/tmp install
+
+
+
+ # Booting script
+
+# Build architecture-independent files here.
+binary-indep: build install
+# We have nothing to do by default.
+
+# Build architecture-dependent files here.
+binary-arch: build install
+ dh_testdir
+ dh_testroot
+ dh_installchangelogs
+ dh_installdocs
+ dh_installexamples
+ dh_install --sourcedir=debian/tmp
+
+ # Install extra shell script
+ mkdir -p $(CURDIR)/debian/bluetooth-firmware-bcm-c210/usr/etc/bluetooth/
+ mkdir -p $(CURDIR)/debian/bluetooth-firmware-bcm-e4412/usr/etc/bluetooth/
+
+ cp -a $(CURDIR)/debian/tmp/usr/etc/bluetooth/bt-dev-end.sh $(CURDIR)/debian/bluetooth-firmware-bcm-c210/usr/etc/bluetooth/bt-dev-end.sh
+ cp -a $(CURDIR)/debian/tmp/usr/etc/bluetooth/bt-dev-start-c210.sh $(CURDIR)/debian/bluetooth-firmware-bcm-c210/usr/etc/bluetooth/bt-dev-start.sh
+ cp -a $(CURDIR)/debian/tmp/usr/etc/bluetooth/bt-set-addr.sh $(CURDIR)/debian/bluetooth-firmware-bcm-c210/usr/etc/bluetooth/bt-set-addr.sh
+
+ cp -a $(CURDIR)/debian/tmp/usr/etc/bluetooth/bt-dev-end.sh $(CURDIR)/debian/bluetooth-firmware-bcm-e4412/usr/etc/bluetooth/bt-dev-end.sh
+ cp -a $(CURDIR)/debian/tmp/usr/etc/bluetooth/bt-dev-start-e4412.sh $(CURDIR)/debian/bluetooth-firmware-bcm-e4412/usr/etc/bluetooth/bt-dev-start.sh
+ cp -a $(CURDIR)/debian/tmp/usr/etc/bluetooth/bt-set-addr.sh $(CURDIR)/debian/bluetooth-firmware-bcm-e4412/usr/etc/bluetooth/bt-set-addr.sh
+
+# dh_installmenu
+# dh_installdebconf
+# dh_installlogrotate
+# dh_installemacsen
+# dh_installpam
+# dh_installmime
+# dh_python
+# dh_installinit
+# dh_installcron
+# dh_installinfo
+ dh_installman
+ dh_link
+ dh_strip --dbg-package=bluetooth-firmware-bcm-c210-dbg --dbg-package=bluetooth-firmware-bcm-e4412-dbg
+ dh_compress
+ dh_fixperms
+# dh_perl
+ dh_makeshlibs
+ dh_installdeb
+ dh_shlibdeps
+ dh_gencontrol
+ dh_md5sums
+ dh_builddeb
+
+binary: binary-indep binary-arch
+.PHONY: build clean binary-indep binary-arch binary install configure
diff --git a/wearable/firmware/BCM20710A1_001.002.014.0028.0048.hcd b/wearable/firmware/BCM20710A1_001.002.014.0028.0048.hcd
new file mode 100644
index 0000000..86f5319
--- /dev/null
+++ b/wearable/firmware/BCM20710A1_001.002.014.0028.0048.hcd
Binary files differ
diff --git a/wearable/firmware/BCM20710A1_001.002.014.0052.0000_Samsung_Tizen_Lite_TEST_ONLY.hcd b/wearable/firmware/BCM20710A1_001.002.014.0052.0000_Samsung_Tizen_Lite_TEST_ONLY.hcd
new file mode 100644
index 0000000..c00a05a
--- /dev/null
+++ b/wearable/firmware/BCM20710A1_001.002.014.0052.0000_Samsung_Tizen_Lite_TEST_ONLY.hcd
Binary files differ
diff --git a/wearable/firmware/BCM20710A1_001.002.014.0056.0000_Samsung_Tizen_Lite_TEST_ONLY.hcd b/wearable/firmware/BCM20710A1_001.002.014.0056.0000_Samsung_Tizen_Lite_TEST_ONLY.hcd
new file mode 100644
index 0000000..074959f
--- /dev/null
+++ b/wearable/firmware/BCM20710A1_001.002.014.0056.0000_Samsung_Tizen_Lite_TEST_ONLY.hcd
Binary files differ
diff --git a/wearable/firmware/BCM20710A1_001.002.014.0059.0060.hcd b/wearable/firmware/BCM20710A1_001.002.014.0059.0060.hcd
new file mode 100644
index 0000000..15921ed
--- /dev/null
+++ b/wearable/firmware/BCM20710A1_001.002.014.0059.0060.hcd
Binary files differ
diff --git a/wearable/firmware/BCM4330B1_002.001.003.0013.0000_SS-SLP7-B42_NoExtLNA_37_4MHz-TEST-ONLY.hcd b/wearable/firmware/BCM4330B1_002.001.003.0013.0000_SS-SLP7-B42_NoExtLNA_37_4MHz-TEST-ONLY.hcd
new file mode 100644
index 0000000..7b3f3ab
--- /dev/null
+++ b/wearable/firmware/BCM4330B1_002.001.003.0013.0000_SS-SLP7-B42_NoExtLNA_37_4MHz-TEST-ONLY.hcd
Binary files differ
diff --git a/wearable/firmware/BCM4330B1_002.001.003.0221.0265.hcd b/wearable/firmware/BCM4330B1_002.001.003.0221.0265.hcd
new file mode 100644
index 0000000..a8c7f30
--- /dev/null
+++ b/wearable/firmware/BCM4330B1_002.001.003.0221.0265.hcd
Binary files differ
diff --git a/wearable/firmware/BCM4334B0_002.001.013.0079.0081.hcd b/wearable/firmware/BCM4334B0_002.001.013.0079.0081.hcd
new file mode 100644
index 0000000..ff13214
--- /dev/null
+++ b/wearable/firmware/BCM4334B0_002.001.013.0079.0081.hcd
Binary files differ
diff --git a/wearable/firmware/BCM4334B0_002.001.013.0079.0083.hcd b/wearable/firmware/BCM4334B0_002.001.013.0079.0083.hcd
new file mode 100644
index 0000000..bb49859
--- /dev/null
+++ b/wearable/firmware/BCM4334B0_002.001.013.0079.0083.hcd
Binary files differ
diff --git a/wearable/firmware/BCM4334B0_002.001.013.0079.0084.hcd b/wearable/firmware/BCM4334B0_002.001.013.0079.0084.hcd
new file mode 100644
index 0000000..72c588b
--- /dev/null
+++ b/wearable/firmware/BCM4334B0_002.001.013.0079.0084.hcd
Binary files differ
diff --git a/wearable/firmware/BCM4334B0_002.001.013.0779.0950.hcd b/wearable/firmware/BCM4334B0_002.001.013.0779.0950.hcd
new file mode 100644
index 0000000..e638b17
--- /dev/null
+++ b/wearable/firmware/BCM4334B0_002.001.013.0779.0950.hcd
Binary files differ
diff --git a/wearable/firmware/BCM4334B0_002.001.013.0942.1036.hcd b/wearable/firmware/BCM4334B0_002.001.013.0942.1036.hcd
new file mode 100644
index 0000000..b220558
--- /dev/null
+++ b/wearable/firmware/BCM4334B0_002.001.013.0942.1036.hcd
Binary files differ
diff --git a/wearable/firmware/BCM4334B0_002.001.013.1024.1064.hcd b/wearable/firmware/BCM4334B0_002.001.013.1024.1064.hcd
new file mode 100644
index 0000000..8c5a5fd
--- /dev/null
+++ b/wearable/firmware/BCM4334B0_002.001.013.1024.1064.hcd
Binary files differ
diff --git a/wearable/firmware/CMakeLists.txt b/wearable/firmware/CMakeLists.txt
new file mode 100644
index 0000000..f4aa7e8
--- /dev/null
+++ b/wearable/firmware/CMakeLists.txt
@@ -0,0 +1,14 @@
+# install firmware
+# files for c210
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/BCM4330B1_002.001.003.0013.0000_SS-SLP7-B42_NoExtLNA_37_4MHz-TEST-ONLY.hcd DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/BCM4330B1_002.001.003.0221.0265.hcd DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+
+# files for e4112 (W)
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/BCM20710A1_001.002.014.0059.0060.hcd DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/bcm4334w/BCM4334B0_002.001.013.1675.1676_B2_ORC.hcd DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/bcm4334w/BCM4334W_Rinato_TestOnly.hcd DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/bcm4334w/BCM4334W_001.002.003.0997.1027_B58_ePA.hcd DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+
+# files for msm8974
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/bcm4335/BCM4335B0_002.001.006.0233.0234_ORC_RedWood.hcd DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/bcm4339/BCM4339_003.001.009.0030.0122_ORC_RedWood.hcd DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
diff --git a/wearable/firmware/bcm4334w/BCM43342A1_001.002.003.0874.0000_SEMCO_B58_TEST_ONLY.hcd b/wearable/firmware/bcm4334w/BCM43342A1_001.002.003.0874.0000_SEMCO_B58_TEST_ONLY.hcd
new file mode 100644
index 0000000..7bf762a
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM43342A1_001.002.003.0874.0000_SEMCO_B58_TEST_ONLY.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4334w/BCM43342A1_001.002.003.0987.0000_Samsung_Rinato_Tizen_ePA_RFtest_LE_7dBm.hcd b/wearable/firmware/bcm4334w/BCM43342A1_001.002.003.0987.0000_Samsung_Rinato_Tizen_ePA_RFtest_LE_7dBm.hcd
new file mode 100644
index 0000000..52bba4e
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM43342A1_001.002.003.0987.0000_Samsung_Rinato_Tizen_ePA_RFtest_LE_7dBm.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4334w/BCM4334B0_002.001.013.1675.1676_B2_ORC.hcd b/wearable/firmware/bcm4334w/BCM4334B0_002.001.013.1675.1676_B2_ORC.hcd
new file mode 100644
index 0000000..3d4af56
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM4334B0_002.001.013.1675.1676_B2_ORC.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0874.0000_Samsung_Rinato_TEST_ONLY.hcd b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0874.0000_Samsung_Rinato_TEST_ONLY.hcd
new file mode 100644
index 0000000..cff7470
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0874.0000_Samsung_Rinato_TEST_ONLY.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0874.0000_ePA_SEMCO_B58_TEST_ONLY.hcd b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0874.0000_ePA_SEMCO_B58_TEST_ONLY.hcd
new file mode 100644
index 0000000..889525e
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0874.0000_ePA_SEMCO_B58_TEST_ONLY.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0987.0000_Samsung_Rinato_M7_TEST_ONLY_GGPatch.hcd b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0987.0000_Samsung_Rinato_M7_TEST_ONLY_GGPatch.hcd
new file mode 100755
index 0000000..240374a
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0987.0000_Samsung_Rinato_M7_TEST_ONLY_GGPatch.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0987.1017.hcd b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0987.1017.hcd
new file mode 100755
index 0000000..e258c55
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0987.1017.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0995.1021_B58_ePA.HCD b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0995.1021_B58_ePA.HCD
new file mode 100644
index 0000000..0ce92aa
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0995.1021_B58_ePA.HCD
Binary files differ
diff --git a/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0997.1024_B58_ePA.hcd b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0997.1024_B58_ePA.hcd
new file mode 100644
index 0000000..641de30
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0997.1024_B58_ePA.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0997.1027_B58_ePA.hcd b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0997.1027_B58_ePA.hcd
new file mode 100644
index 0000000..bd8a0f0
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM4334W_001.002.003.0997.1027_B58_ePA.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4334w/BCM4334W_Generic_37_4MHz_wlcsp_Rinato_ePA_TestOnly.hcd b/wearable/firmware/bcm4334w/BCM4334W_Generic_37_4MHz_wlcsp_Rinato_ePA_TestOnly.hcd
new file mode 100644
index 0000000..006a4f0
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM4334W_Generic_37_4MHz_wlcsp_Rinato_ePA_TestOnly.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4334w/BCM4334W_Rinato_TestOnly.hcd b/wearable/firmware/bcm4334w/BCM4334W_Rinato_TestOnly.hcd
new file mode 100644
index 0000000..cfc3228
--- /dev/null
+++ b/wearable/firmware/bcm4334w/BCM4334W_Rinato_TestOnly.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4334w/configdata_wlcsp_Semco_B58_ePA_TestOnly.hcd b/wearable/firmware/bcm4334w/configdata_wlcsp_Semco_B58_ePA_TestOnly.hcd
new file mode 100755
index 0000000..16ccaec
--- /dev/null
+++ b/wearable/firmware/bcm4334w/configdata_wlcsp_Semco_B58_ePA_TestOnly.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4335/BCM4335B0_002.001.006.0203.0206_ORC_JF-LTE.hcd b/wearable/firmware/bcm4335/BCM4335B0_002.001.006.0203.0206_ORC_JF-LTE.hcd
new file mode 100644
index 0000000..549b2c0
--- /dev/null
+++ b/wearable/firmware/bcm4335/BCM4335B0_002.001.006.0203.0206_ORC_JF-LTE.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4335/BCM4335B0_002.001.006.0233.0234_ORC_RedWood.hcd b/wearable/firmware/bcm4335/BCM4335B0_002.001.006.0233.0234_ORC_RedWood.hcd
new file mode 100644
index 0000000..f8a7e30
--- /dev/null
+++ b/wearable/firmware/bcm4335/BCM4335B0_002.001.006.0233.0234_ORC_RedWood.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4335/ReleaseNotes_BCM4335B0_002.001.006.0233.0234_ORC_Samsung_RedWood_BT4.0_37_4MHz.txt b/wearable/firmware/bcm4335/ReleaseNotes_BCM4335B0_002.001.006.0233.0234_ORC_Samsung_RedWood_BT4.0_37_4MHz.txt
new file mode 100644
index 0000000..7d89def
--- /dev/null
+++ b/wearable/firmware/bcm4335/ReleaseNotes_BCM4335B0_002.001.006.0233.0234_ORC_Samsung_RedWood_BT4.0_37_4MHz.txt
@@ -0,0 +1,45 @@
+###############################################################################
+#
+# THIS INFORMATION IS PROPRIETARY TO BROADCOM CORPORATION
+#
+# Product: Generic
+#
+# Mode: UART, Class 1, 37.4Mhz, RedWood(SEMCO-B62)
+#
+# Master CSP: 524543
+#
+# Description : MSM8974 / Tyzen OS(SLP) / BlueZ
+# WBS / PCM Slave / No FMRX
+#
+###############################################################################
+
+
+This is an ORC(Official Release Candidate) version based on .0233.0000 baseline for RedWood.
+
+====================
+ Release Notes
+====================
+
+07/03/2013
+
+1. This customer specific release is based on the following baseline
+
+ BCM4335B0_002.001.006.0203.0000\Generic\UART\37_4MHz\wlcsp_Semco_B62
+
+
+2. Customization:
+============================
+(1) Program name: Samsung RedWood(Semco B62)
+(2) Clock source: 37.4Mhz XTAL
+(3) Radio power class: 1.5
+(4) BT4.0
+(5) BB Register Bit Fields settings for Sleep mode BT_GPIO0/BT_GPIO1
+(6) disableDriftPrediction
+(7) Enable enableNullEscoPatch
+(8) Config cfg_skip_pri_adjust_a2dp_in_pause=1
+(9) Tuned AFH parameters
+(10) Limited output power
+(11) Enable 2 stopbits setting for QCOM AP
+(12) Increasing EDR relative power for Benz carkit A2DP choppiness @ Gumi
+(13) le_power_value=0x12 to compensate filter loss
+
diff --git a/wearable/firmware/bcm4339/BCM4339_003.001.009.0025.0053_ORC_H-LTE.hcd b/wearable/firmware/bcm4339/BCM4339_003.001.009.0025.0053_ORC_H-LTE.hcd
new file mode 100644
index 0000000..eff6033
--- /dev/null
+++ b/wearable/firmware/bcm4339/BCM4339_003.001.009.0025.0053_ORC_H-LTE.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4339/BCM4339_003.001.009.0028.0085_RedWood.hcd b/wearable/firmware/bcm4339/BCM4339_003.001.009.0028.0085_RedWood.hcd
new file mode 100644
index 0000000..dafb51c
--- /dev/null
+++ b/wearable/firmware/bcm4339/BCM4339_003.001.009.0028.0085_RedWood.hcd
Binary files differ
diff --git a/wearable/firmware/bcm4339/BCM4339_003.001.009.0030.0122_ORC_RedWood.hcd b/wearable/firmware/bcm4339/BCM4339_003.001.009.0030.0122_ORC_RedWood.hcd
new file mode 100644
index 0000000..e9c72be
--- /dev/null
+++ b/wearable/firmware/bcm4339/BCM4339_003.001.009.0030.0122_ORC_RedWood.hcd
Binary files differ
diff --git a/wearable/scripts/CMakeLists.txt b/wearable/scripts/CMakeLists.txt
new file mode 100644
index 0000000..6837b9c
--- /dev/null
+++ b/wearable/scripts/CMakeLists.txt
@@ -0,0 +1,6 @@
+# install firmware
+INSTALL(PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR}/bt-dev-end.sh DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR}/bt-dev-start-c210.sh DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR}/bt-dev-start-e4412.sh DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR}/bt-dev-start-msm8974.sh DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
+INSTALL(PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR}/bt-set-addr.sh DESTINATION ${PLUGIN_INSTALL_PREFIX}/etc/bluetooth)
diff --git a/wearable/scripts/bt-dev-end.sh b/wearable/scripts/bt-dev-end.sh
new file mode 100755
index 0000000..8390a35
--- /dev/null
+++ b/wearable/scripts/bt-dev-end.sh
@@ -0,0 +1,22 @@
+#!/bin/sh
+
+#
+# Script for stopping Broadcom UART Bluetooth stack
+#
+
+# Device down
+/usr/sbin/hciconfig hci0 down
+
+# Turn off Bluetooth Chip
+rfkill block bluetooth
+
+killall hciattach
+
+#if [ -e /sys/class/gpio/gpio17/value ]
+#then
+# # Reset BT chip
+# echo 0 > /sys/class/gpio/gpio17/value
+# sleep 0.1
+# echo 1 > /sys/class/gpio/gpio17/value
+#fi
+
diff --git a/wearable/scripts/bt-dev-start-c210.sh b/wearable/scripts/bt-dev-start-c210.sh
new file mode 100755
index 0000000..0fbadbe
--- /dev/null
+++ b/wearable/scripts/bt-dev-start-c210.sh
@@ -0,0 +1,91 @@
+#!/bin/sh
+
+# Script for registering Broadcom UART BT device
+BT_UART_DEVICE=/dev/ttySAC0
+BT_CHIP_TYPE=bcm2035
+BCM_TOOL=/usr/bin/bcmtool_4330b1
+BT_ADDR=/csa/bluetooth/.bd_addr
+
+BT_PLATFORM_DEFAULT_HCI_NAME="SLP2.0_BT"
+UART_SPEED=3000000
+
+#set default firmware
+#for SLP7_C210, SLP10_C210
+BCM_FIRMWARE=BCM4330B1_002.001.003.0013.0000_SS-SLP7-B42_NoExtLNA_37_4MHz-TEST-ONLY.hcd
+
+REVISION_NUM=`grep Revision /proc/cpuinfo | awk "{print \\$3}"`
+REVISION_HIGH=`echo $REVISION_NUM| cut -c1-2`
+REVISION_LOW=`echo $REVISION_NUM| cut -c3-`
+
+HARDWARE=`grep Hardware /proc/cpuinfo | awk "{print \\$3}"`
+
+if [ "$HARDWARE" = "U1SLP" ] ||
+ [ "$HARDWARE" = "U1HD" ]; then
+ echo $HARDWARE "BCM4330 B1"
+ BCM_FIRMWARE=BCM4330B1_002.001.003.0221.0265.hcd
+fi
+echo $BCM_FIRMWARE
+
+if [ ! -e "$BT_UART_DEVICE" ]
+then
+ mknod $BT_UART_DEVICE c 204 64
+fi
+
+# Set BT address: This will internally check for the file presence
+/usr/bin/setbd
+
+#if the setbd return non 0, which means incorrect bd address file, then exit
+if [ $? -ne 0 ]
+then
+ exit 1
+fi
+
+# Trun-on Bluetooth Chip
+rfkill unblock bluetooth
+
+echo "Check for Bluetooth device status"
+if (/usr/sbin/hciconfig | grep hci); then
+ echo "Bluetooth device is UP"
+ /usr/sbin/hciconfig hci0 up
+else
+ echo "Bluetooth device is DOWN"
+ echo "Registering Bluetooth device"
+
+ $BCM_TOOL $BT_UART_DEVICE -FILE=/usr/etc/bluetooth/$BCM_FIRMWARE -BAUD=$UART_SPEED -ADDR=$BT_ADDR -SETSCO=0,0,0,0,0,0,0,3,3,0 -LP > /dev/null 2>&1 &
+ bcmtool_pid=$!
+ #Check next 2.4 seconds for bcmtool success
+ for (( i=1; i<=24; i++))
+ do
+ sleep 0.1
+ kill -0 $bcmtool_pid
+ bcmtool_alive=$?
+
+ if [ $i -eq 24 ]
+ then
+ echo "time expired happen $i"
+ kill -TERM $bcmtool_pid
+ rfkill block bluetooth
+ exit 1
+ fi
+
+ if [ $bcmtool_alive -eq 0 ]
+ then
+ echo "Continue....$i"
+ continue
+ else
+ echo "Break.......$i"
+ break
+ fi
+ done
+
+ # Attaching Broadcom device
+ if (/usr/sbin/hciattach $BT_UART_DEVICE -s $UART_SPEED $BT_CHIP_TYPE $UART_SPEED flow); then
+ sleep 0.1
+ echo "HCIATTACH success"
+ else
+ echo "HCIATTACH failed"
+ rfkill block bluetooth
+ fi
+fi
+
+#/usr/sbin/hciconfig hci0 down
diff --git a/wearable/scripts/bt-dev-start-e4412.sh b/wearable/scripts/bt-dev-start-e4412.sh
new file mode 100755
index 0000000..5c4e596
--- /dev/null
+++ b/wearable/scripts/bt-dev-start-e4412.sh
@@ -0,0 +1,135 @@
+#!/bin/sh
+
+#
+# Script for registering Broadcom UART BT device
+#
+BT_UART_DEVICE=/dev/ttySAC0
+BT_CHIP_TYPE=bcm2035
+BCM_TOOL=/usr/bin/bcmtool_4330b1
+
+BT_ADDR=/csa/bluetooth/.bd_addr
+
+UART_SPEED=3000000
+TIMEOUT=24
+
+# defult firmware
+# SEMCO external LNA, I2S slave, fix high sleep current
+BCM_FIRMWARE=BCM20710A1_001.002.014.0059.0060.hcd
+
+#B2 - REV_01 - 4334W SEMCO B58 module with iPA(internal PA)
+#B2 - REV_02 - 4334W SEMCO B58 module with ePA(external PA)
+BCM_B2_FIRMWARE=BCM4334B0_002.001.013.1675.1676_B2_ORC.hcd
+BCM_B2_SEC_FIRMWARE_REV_01=BCM4334W_Rinato_TestOnly.hcd
+BCM_B2_SEC_FIRMWARE_REV_02=BCM4334W_001.002.003.0997.1027_B58_ePA.hcd
+
+HOST_NAME=`grep Hardware /proc/cpuinfo | awk "{print \\$3}"`
+REVISION_NUM=`grep Revision /proc/cpuinfo | awk "{print \\$3}"`
+
+if [ "$HOST_NAME" == "B2" ]; then
+ if [ "$REVISION_NUM" == "0000" ]; then
+ BCM_FIRMWARE=$BCM_B2_FIRMWARE
+ else
+ if [ "$REVISION_NUM" == "0001" ]; then
+ BCM_FIRMWARE=$BCM_B2_SEC_FIRMWARE_REV_01
+ else
+ BCM_FIRMWARE=$BCM_B2_SEC_FIRMWARE_REV_02
+ fi
+ fi
+fi
+
+echo $BCM_FIRMWARE
+
+if [ ! -e "$BT_UART_DEVICE" ]
+then
+ mknod $BT_UART_DEVICE c 204 64
+fi
+
+# Set BT address: This will internally check for the file presence
+/usr/bin/setbd
+
+#if the setbd return non 0, which means incorrect bd address file, then exit
+if [ $? -ne 0 ]
+then
+ exit 1
+fi
+
+rfkill unblock bluetooth
+
+echo "Check for Bluetooth device status"
+if (/usr/sbin/hciconfig | grep hci); then
+ echo "Bluetooth device is UP"
+ /usr/sbin/hciconfig hci0 up
+else
+ echo "Bluetooth device is DOWN"
+ echo "Registering Bluetooth device"
+
+ # In tizenW hardware first time bcmtool download may not success, hence we need to try more times
+ MAXBCMTOOLTRY=5
+ flag=0
+ for (( c=1; c<=$MAXBCMTOOLTRY; c++))
+ do
+ echo "******* Bcmtool download attempt $c ********"
+
+ $BCM_TOOL $BT_UART_DEVICE -FILE=/usr/etc/bluetooth/$BCM_FIRMWARE -BAUD=$UART_SPEED -ADDR=$BT_ADDR -SETSCO=0,0,0,0,0,0,0,3,3,0 -LP &
+ bcmtool_pid=$!
+ #Check next timeout seconds for bcmtool success
+ for (( i=1; i<=$TIMEOUT; i++))
+ do
+ sleep 0.1
+ kill -0 $bcmtool_pid
+ bcmtool_alive=$?
+
+ if [ $i -eq $TIMEOUT ]
+ then
+ echo "time expired happen $i"
+ kill -TERM $bcmtool_pid
+ break
+# rfkill block bluetooth
+# exit 1
+ fi
+
+ if [ $bcmtool_alive -eq 0 ]
+ then
+ echo "Continue....$i"
+ continue
+ else
+ echo "Break.......$i"
+ flag=1
+ break
+ fi
+ done
+
+ if [ $flag -eq 1 ]
+ then
+ echo "Break bcmtool download loop on $c attempt"
+ break
+ else
+ sleep 1
+ echo "sleep done"
+ fi
+
+
+ if [ $c -eq $MAXBCMTOOLTRY ]
+ then
+ echo "***** No Chance to activate, count=$c ******"
+ rfkill block bluetooth
+ exit 1
+ fi
+
+ done
+
+ echo "Try for hciattach"
+
+ # Attaching Broadcom device
+ if (/usr/sbin/hciattach $BT_UART_DEVICE -s $UART_SPEED $BT_CHIP_TYPE $UART_SPEED flow); then
+ sleep 0.1
+ echo "HCIATTACH success"
+ else
+ echo "HCIATTACH failed"
+ rfkill block bluetooth
+ cp /var/log/messages /var/lib/bluetooth/
+ fi
+fi
+
+#/usr/sbin/hciconfig hci0 down
+
diff --git a/wearable/scripts/bt-dev-start-msm8974.sh b/wearable/scripts/bt-dev-start-msm8974.sh
new file mode 100755
index 0000000..253b84d
--- /dev/null
+++ b/wearable/scripts/bt-dev-start-msm8974.sh
@@ -0,0 +1,66 @@
+#!/bin/sh
+
+#
+# Script for registering Broadcom UART BT device
+#
+BT_UART_DEVICE=/dev/ttyHS0
+BT_CHIP_TYPE=bcm2035
+BCM_TOOL=/usr/bin/bcmtool_4330b1
+
+BT_ADDR=/csa/bluetooth/.bd_addr
+
+UART_SPEED=3000000
+
+# defult firmware
+# SEMCO external LNA, I2S slave
+# For host name REDWOOD
+BCM_4335_FIRMWARE=BCM4335B0_002.001.006.0233.0234_ORC_RedWood.hcd
+BCM_4339_FIRMWARE=BCM4339_003.001.009.0030.0122_ORC_RedWood.hcd
+
+HOST_NAME=`grep Hardware /proc/cpuinfo | awk "{print \\$3}"`
+REVISION=`grep Revision /proc/cpuinfo | awk "{print \\$3}"`
+
+BCM_FIRMWARE=$BCM_4339_FIRMWARE
+
+if [ "$HOST_NAME" == "RedwoodLTE_MSM_EUR" ]; then
+ if [ "$REVISION" == "0000" ] || [ "$REVISION" == "0001" ] || [ "$REVISION" == "0004" ]; then
+ BCM_FIRMWARE=$BCM_4335_FIRMWARE
+ fi
+fi
+
+echo $BCM_FIRMWARE
+
+# Set BT address: This will internally check for the file presence
+/usr/bin/setbd
+
+#if the setbd return non 0, which means incorrect bd address file, then exit
+if [ $? -ne 0 ]
+then
+ exit 1
+fi
+
+rfkill unblock bluetooth
+
+echo "Check for Bluetooth device status"
+if (/usr/sbin/hciconfig | grep hci); then
+ echo "Bluetooth device is UP"
+ /usr/sbin/hciconfig hci0 up
+else
+ echo "Bluetooth device is DOWN"
+ echo "Registering Bluetooth device"
+
+ $BCM_TOOL $BT_UART_DEVICE -DEBUG -CSTOPB -FILE=/usr/etc/bluetooth/$BCM_FIRMWARE -BAUD=$UART_SPEED -ADDR=$BT_ADDR -SETSCO=0,0,0,0,0,0,0,3,3,0 -LP
+
+ # Attaching Broadcom device
+ if (/usr/sbin/hciattach $BT_UART_DEVICE -s $UART_SPEED $BT_CHIP_TYPE $UART_SPEED flow); then
+ sleep 0.1
+ echo "HCIATTACH success"
+ else
+ echo "HCIATTACH failed"
+ rfkill block bluetooth
+ cp /var/log/messages /var/lib/bluetooth/
+ fi
+fi
+
+#/usr/sbin/hciconfig hci0 down
+
diff --git a/wearable/scripts/bt-set-addr.sh b/wearable/scripts/bt-set-addr.sh
new file mode 100755
index 0000000..fd553cd
--- /dev/null
+++ b/wearable/scripts/bt-set-addr.sh
@@ -0,0 +1,16 @@
+#!/bin/sh
+
+#
+# Script for setting Bluetooth Address
+#
+
+#if [ -e /opt/etc/.bd_addr ]
+#then
+# echo "Already .bd_addr exists"
+# exit 0
+#fi
+
+/usr/bin/setbd
+
+echo "Set BT address successes"
+
diff --git a/wearable/set-address/CMakeLists.txt b/wearable/set-address/CMakeLists.txt
new file mode 100644
index 0000000..c3e04db
--- /dev/null
+++ b/wearable/set-address/CMakeLists.txt
@@ -0,0 +1,21 @@
+CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
+PROJECT(setbd C)
+
+SET(SRCS setbd.c)
+
+SET(PREFIX ${CMAKE_INSTALL_PREFIX})
+
+FIND_PROGRAM(UNAME NAMES uname)
+EXEC_PROGRAM("${UNAME}" ARGS "-m" OUTPUT_VARIABLE "ARCH")
+IF("${ARCH}" STREQUAL "arm")
+ ADD_DEFINITIONS("-DTARGET")
+ MESSAGE("add -DTARGET")
+ENDIF("${ARCH}" STREQUAL "arm")
+
+ADD_DEFINITIONS("-DPREFIX=\"${CMAKE_INSTALL_PREFIX}\"")
+
+ADD_EXECUTABLE(${PROJECT_NAME} ${SRCS})
+TARGET_LINK_LIBRARIES(${PROJECT_NAME} ${package_LDFLAGS})
+
+INSTALL(TARGETS ${PROJECT_NAME} DESTINATION bin)
+
diff --git a/wearable/set-address/setbd.c b/wearable/set-address/setbd.c
new file mode 100644
index 0000000..35b1d3c
--- /dev/null
+++ b/wearable/set-address/setbd.c
@@ -0,0 +1,190 @@
+/*
+ * setbd.c
+ *
+ * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved
+ *
+ * Contact: Hocheol Seo <hocheol.seo@samsung.com>
+ * GirishAshok Joshi <girish.joshi@samsung.com>
+ * DoHyun Pyun <dh79.pyun@samsung.com>
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <errno.h>
+#include <fcntl.h>
+#include <unistd.h>
+#include <time.h>
+#include <sys/time.h>
+#include <dirent.h>
+#include <sys/stat.h>
+
+#define BD_ADDR_PATH "/csa/bluetooth"
+#define BD_ADDR_FILE "/csa/bluetooth/.bd_addr"
+
+#define BD_ADDR_LEN 14
+#define BD_PREFIX "0002\n"
+
+void makeRandomBD(unsigned char *buf)
+{
+ int ran;
+ int i;
+ unsigned int seed;
+ struct timeval tv;
+
+ memcpy(buf, BD_PREFIX, 5);
+ i = gettimeofday(&tv, NULL);
+
+ if (i < 0) {
+ perror("Fail to call gettimeofday()");
+ seed = time(NULL);
+ } else
+ seed = (unsigned int)tv.tv_usec;
+
+ for (i = 5; i < BD_ADDR_LEN; i++) {
+ if (7 == i) {
+ buf[i] = '\n';
+ continue;
+ }
+ ran = rand_r(&seed) % 16;
+ if (10 > ran)
+ ran += 0x30;
+ else
+ ran += 0x57;
+ buf[i] = ran;
+ }
+ printf("Random number is\r\n");
+ for (i = 0; i < BD_ADDR_LEN; i++) {
+ printf("%c", buf[i]);
+ }
+ printf("\r\n");
+}
+
+void make_bt_address_folder(void)
+{
+ DIR *dp;
+ int err;
+
+ dp = opendir(BD_ADDR_PATH);
+ if (dp == NULL) {
+ if (mkdir(BD_ADDR_PATH, 0755) < 0) {
+ err = -errno;
+ printf("mkdir: %s(%d)", strerror(-err), -err);
+ }
+ return;
+ }
+
+ closedir(dp);
+}
+
+int make_bt_address(void)
+{
+ int fd;
+ unsigned char txt[BD_ADDR_LEN];
+ char nap[4 + 1], uap[2 + 1], lap[6 + 1];
+ int ret;
+
+ make_bt_address_folder();
+
+ fd = open(BD_ADDR_FILE, O_RDONLY | O_SYNC);
+
+ if (fd < 0) {
+ printf("File not exist\n");
+
+ fd = open(BD_ADDR_FILE, O_RDWR | O_CREAT | O_TRUNC | O_SYNC,
+ 0644);
+
+ if (fd < 0) {
+ printf("Can't open address file\n");
+ return -1;
+ }
+
+ makeRandomBD(txt);
+
+ ret = write(fd, txt, BD_ADDR_LEN);
+ if (ret != BD_ADDR_LEN) {
+ printf("Unable to write device address\n");
+ close(fd);
+ unlink(BD_ADDR_FILE);
+ return -1;
+ }
+
+ lseek(fd, 0, SEEK_SET);
+ } else {
+ printf("%s is already existed\n", BD_ADDR_FILE);
+ }
+
+ ret = read(fd, nap, 5);
+ if (ret != 5)
+ goto err;
+
+ ret = read(fd, uap, 3);
+ if (ret != 3)
+ goto err;
+
+ ret = read(fd, lap, 7);
+ if (ret != 6)
+ goto err;
+
+ close(fd);
+
+ /* Unfortunately 00023fbf0a1a address is duplicated from the
+ * previous IMEI logic. So this address should be updated with
+ * random value.
+ *
+ * This is temporal code. And this would be reverted around a few week
+ * after the wrong addressed device has proper address.
+ */
+ if (strncmp(nap, "0002", 4) == 0 &&
+ strncmp(uap, "3f", 2) == 0 && strncmp(lap, "bf0a1a", 6) == 0) {
+ printf("%s has wrong address\n", BD_ADDR_FILE);
+ fd = open(BD_ADDR_FILE, O_RDWR | O_CREAT | O_TRUNC | O_SYNC,
+ 0644);
+
+ if (fd < 0) {
+ printf("Can't open address file\n");
+ return -1;
+ }
+
+ makeRandomBD(txt);
+ ret = write(fd, txt, BD_ADDR_LEN);
+ if (ret != BD_ADDR_LEN) {
+ printf("Unable to write device address\n");
+ close(fd);
+ unlink(BD_ADDR_FILE);
+ return -1;
+ }
+
+ lseek(fd, 0, SEEK_SET);
+ close(fd);
+ }
+
+ return ret;
+ err:
+ printf("read() failed, ret = %d\n", ret);
+ close(fd);
+ unlink(BD_ADDR_FILE);
+ return -1;
+}
+
+int main()
+{
+ printf("Bluetooth Address Setting\n");
+ if (make_bt_address() < 0)
+ return -1;
+
+ return 0;
+}
diff --git a/wearable/tools/CMakeLists.txt b/wearable/tools/CMakeLists.txt
new file mode 100644
index 0000000..85e215b
--- /dev/null
+++ b/wearable/tools/CMakeLists.txt
@@ -0,0 +1,25 @@
+CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
+PROJECT(bcmtool C)
+
+SET(SRCS_4330B1 bcmtool_4330b1.c)
+
+SET(BCMTOOL_4330B1 ${PROJECT_NAME}_4330b1)
+
+SET(PREFIX ${CMAKE_INSTALL_PREFIX})
+
+FIND_PROGRAM(UNAME NAMES uname)
+EXEC_PROGRAM("${UNAME}" ARGS "-m" OUTPUT_VARIABLE "ARCH")
+IF("${ARCH}" STREQUAL "arm")
+ ADD_DEFINITIONS("-DTARGET")
+ MESSAGE("add -DTARGET")
+ENDIF("${ARCH}" STREQUAL "arm")
+
+ADD_DEFINITIONS("-DPREFIX=\"${CMAKE_INSTALL_PREFIX}\"")
+ADD_DEFINITIONS("-DFACTORYFS=\"$ENV{FACTORYFS}\"")
+
+ADD_EXECUTABLE(${BCMTOOL_4330B1} ${SRCS_4330B1})
+
+TARGET_LINK_LIBRARIES(${BCMTOOL_4330B1} ${package_LDFLAGS})
+
+# install binary file
+INSTALL(TARGETS ${BCMTOOL_4330B1} DESTINATION ${PLUGIN_INSTALL_PREFIX}/bin)
diff --git a/wearable/tools/bcmtool.c b/wearable/tools/bcmtool.c
new file mode 100644
index 0000000..544a356
--- /dev/null
+++ b/wearable/tools/bcmtool.c
@@ -0,0 +1,897 @@
+/*****************************************************************************
+**
+** Name: bcmtool.c
+**
+** Description: This program downloads a patchram files in the HCD format
+** for Linux projects
+**
+** Copyright (c) 2000-2009, Broadcom Corp., All Rights Reserved.
+** WIDCOMM Bluetooth Core. Proprietary and confidential.
+******************************************************************************/
+
+#include <stdio.h>
+#include <errno.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <stdlib.h>
+#include <time.h>
+#include <string.h>
+#include <signal.h>
+#ifdef ANDROID
+#include <termios.h>
+#else
+#include <sys/termios.h>
+#endif
+
+/* Patch auto select for BCM4325 D0,D1 */
+#define PRM_SELECT_PATCHRAM_INCLUDED FALSE
+
+/* Pre baudrate change for fast download */
+#define HIGH_SPEED_PATCHRAM_DOWNLOAD TRUE
+
+/* Host Stack Idle Threshold */
+#define HCILP_IDLE_THRESHOLD 0x01
+
+/* Host Controller Idle Threshold */
+#define HCILP_HC_IDLE_THRESHOLD 0x01
+
+/* BT_WAKE Polarity - 0=Active Low, 1= Active High */
+#define HCILP_BT_WAKE_POLARITY 1
+
+/* HOST_WAKE Polarity - 0=Active Low, 1= Active High */
+#define HCILP_HOST_WAKE_POLARITY 1
+
+
+
+#define DEBUG 1
+
+typedef unsigned char UINT8;
+typedef unsigned short UINT16;
+typedef unsigned long UINT32;
+typedef signed long INT32;
+typedef signed char INT8;
+typedef signed short INT16;
+typedef unsigned char BOOLEAN;
+
+#define FALSE 0
+#define TRUE (!FALSE)
+
+#define BD_ADDR_LEN 6 /* Device address length */
+typedef UINT8 BD_ADDR[BD_ADDR_LEN]; /* Device address */
+
+
+
+#define HCI_GRP_LINK_CONTROL_CMDS (0x01 << 10)
+#define HCI_GRP_LINK_POLICY_CMDS (0x02 << 10)
+#define HCI_GRP_HOST_CONT_BASEBAND_CMDS (0x03 << 10)
+#define HCI_GRP_INFORMATIONAL_PARAMS (0x04 << 10)
+#define HCI_GRP_STATUS_PARAMS (0x05 << 10)
+#define HCI_GRP_TESTING_CMDS (0x06 << 10)
+#define HCI_GRP_L2CAP_CMDS (0x07 << 10)
+#define HCI_GRP_L2CAP_HCI_EVTS (0x08 << 10)
+#define HCI_GRP_VENDOR_SPECIFIC (0x3F << 10)
+
+
+#define HCI_RESET (0x0003 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+#define HCI_SET_EVENT_FILTER (0x0005 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+#define HCI_READ_SCAN_ENABLE (0x0019 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+#define HCI_WRITE_SCAN_ENABLE (0x001A | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+
+#define HCI_READ_LOCAL_VERSION_INFO (0x0001 | HCI_GRP_INFORMATIONAL_PARAMS)
+
+#define HCI_ENABLE_DEV_UNDER_TEST_MODE (0x0003 | HCI_GRP_TESTING_CMDS)
+
+#define HCI_BRCM_SUPER_PEEK_POKE (0x000A | HCI_GRP_VENDOR_SPECIFIC)
+#define VSC_WRITE_BD_ADDR (0x0001 | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_UPDATE_BAUDRATE_CMD (0x0018 | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_WRITE_SCO_PCM_INT_PARAM (0x001C | HCI_GRP_VENDOR_SPECIFIC)
+#define VSC_WRITE_PCM_DATA_FORMAT_PARAM (0x001E | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_WRITE_SLEEP_MODE (0x0027 | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_DOWNLOAD_MINI_DRV (0x002E | HCI_GRP_VENDOR_SPECIFIC)
+#define VSC_WRITE_UART_CLOCK_SETTING (0x0045 | HCI_GRP_VENDOR_SPECIFIC)
+
+
+#define VOICE_SETTING_MU_LAW_MD 0x0100
+#define VOICE_SETTING_LINEAR_MD 0x0060
+
+#define HCI_ARM_MEM_PEEK 0x04
+#define HCI_ARM_MEM_POKE 0x05
+
+#define BTUI_MAX_STRING_LENGTH_PER_LINE 255
+#define HCI_BRCM_WRITE_SLEEP_MODE_LENGTH 10
+
+#define HCI_BRCM_UPDATE_BAUD_RATE_ENCODED_LENGTH 0x02
+#define HCI_BRCM_UPDATE_BAUD_RATE_UNENCODED_LENGTH 0x06
+
+#define VSC_WRITE_UART_CLOCK_SETTING_LEN 1
+
+
+#define BTA_PRM_SUBVER_BCM2045_B2 0x420B
+#define BTA_PRM_SUBVER_BCM2048_A1 0x2222
+#define BTA_PRM_SUBVER_BCM2048_B0 0x410B
+#define BTA_PRM_SUBVER_BCM2046_B0 0x4128
+#define BTA_PRM_SUBVER_BCM2046_B1 0x420E
+#define BTA_PRM_SUBVER_BCM2070_B0 0x4120
+#define BTA_PRM_SUBVER_BCM4325_D0 0x8107
+#define BTA_PRM_SUBVER_BCM4325_D1 0x8108 /* BE CAREFUL - Just set D1 as fake value, 0x8108 since found out D1 has same value with D0. */
+#define BTA_PRM_SUBVER_BCM 0x0000 /* NOT USED */
+
+/* ARM Memory Read :
+ * Access_Type uint8
+ * ARM_Memory_Address uint32(little endian) */
+#define VSC_SUPER_PEEK_POKE_CMD HCI_BRCM_SUPER_PEEK_POKE
+#define VSC_ARM_MEM_PEEK_CMD VSC_SUPER_PEEK_POKE_CMD
+#define VSC_ARM_MEM_PEEK_CMD_TYPE HCI_ARM_MEM_PEEK
+#define VSC_ARM_MEM_PEEK_CMD_ADDR_OFFSET 1
+#define VSC_ARM_MEM_PEEK_CMD_LEN 5
+
+/* BCM4325_SEL
+ * I'd recommend that you select a address between 0x1000 and 0x30000, where most code resides.
+ * For example, if you peek address 0x10000, on D0 you will get 0x21, and on D1 you will get 0x10. */
+#define PEEK_ADDR_4_BCM4325_SEL 0x00010000
+#define PEEK_VAL_4_BCM4325_D0 0x21
+#define PEEK_VAL_4_BCM4325_D1 0x10
+
+#define BTA_PRM_NAME_BCM4325_D0 "BCM4325D0"
+#define BTA_PRM_NAME_BCM4325_D1 "BCM4325D1"
+
+
+/* print string with time stamp */
+#define TDEBUG0(m) if(debug_mode) {print_time();fprintf(stderr,m);}
+#define TDEBUG1(m,n1) if(debug_mode) {print_time();fprintf(stderr,m,n1);}
+#define TDEBUG2(m,n1,n2) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2);}
+#define TDEBUG3(m,n1,n2,n3) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3);}
+#define TDEBUG4(m,n1,n2,n3,n4) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3,n4);}
+#define TDEBUG5(m,n1,n2,n3,n4,n5) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3,n4,n5);}
+#define TDEBUG6(m,n1,n2,n3,n4,n5,n6) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3,n4,n5,n6);}
+
+/* print just string */
+#define DEBUG0(m) if(debug_mode) {fprintf(stderr,m);}
+#define DEBUG1(m,n1) if(debug_mode) {fprintf(stderr,m,n1);}
+#define DEBUG2(m,n1,n2) if(debug_mode) {fprintf(stderr,m,n1,n2);}
+#define DEBUG3(m,n1,n2,n3) if(debug_mode) {fprintf(stderr,m,n1,n2,n3);}
+#define DEBUG4(m,n1,n2,n3,n4) if(debug_mode) {fprintf(stderr,m,n1,n2,n3,n4);}
+#define DEBUG5(m,n1,n2,n3,n4,n5) if(debug_mode) {fprintf(stderr,m,n1,n2,n3,n4,n5);}
+#define DEBUG6(m,n1,n2,n3,n4,n5,n6) if(debug_mode) {fprintf(stderr,m,n1,n2,n3,n4,n5,n6);}
+
+
+#define STREAM_TO_UINT8(u8, p) {u8 = (UINT8)(*(p)); (p) += 1;}
+#define STREAM_TO_UINT16(u16, p) {u16 = ((UINT16)(*(p)) + (((UINT16)(*((p) + 1))) << 8)); (p) += 2;}
+#define STREAM_TO_UINT32(u32, p) {u32 = (((UINT32)(*(p))) + ((((UINT32)(*((p) + 1)))) << 8) + ((((UINT32)(*((p) + 2)))) << 16) + ((((UINT32)(*((p) + 3)))) << 24)); (p) += 4;}
+
+#define ROTATE_BD_ADDR(p1, p2) \
+ do \
+ { \
+ p1[0] = p2[5]; \
+ p1[1] = p2[4]; \
+ p1[2] = p2[3]; \
+ p1[3] = p2[2]; \
+ p1[4] = p2[1]; \
+ p1[5] = p2[0]; \
+ } while (0)
+
+
+UINT8 vsc_for_pcm_config[5] = {0x00, 0x00, 0x03, 0x03, 0x00};
+/*
+ Byte1 -- 0 for MSb first
+ Byte2 -- 0 Fill value
+ Byte3 -- 1 Fill option (0:0's, 1:1's , 2:Signed, 3:Programmable)
+ Byte4 -- 1 Number of fill bits
+ Byte5 -- 1 Right justified (0 for left justified)
+*/
+
+UINT8 vsc_for_sco_pcm[5] = {0x00, 0x01, 0x00, 0x01, 0x01};
+/*
+ Neverland : PCM, 256, short, master ,master
+ Volance : PCM, 256, short, master ,master
+
+ Byte1 -- 0 for PCM 1 for UART or USB
+ Byte2 -- 0 : 128, 1: 256, 2:512, 3:1024, 4:2048 Khz
+ Byte3 -- 0 for short frame sync 1 for long frame sync
+ Byte4 -- 0 Clock direction 0 for same as sync 1 for opposite direction
+ Byte5 -- 0 for slave 1 for master
+*/
+
+int fd; /* HCI handle */
+
+BOOLEAN debug_mode = FALSE; /* Debug Mode Enable */
+
+unsigned char buffer[1024];
+
+struct termios termios;
+
+typedef struct
+{
+ UINT8 hci_version;
+ UINT16 hci_revision;
+ UINT8 lmp_version;
+ UINT16 manufacturer;
+ UINT16 lmp_subversion;
+} tBTM_VERSION_INFO;
+
+void ChangeBaudRate(UINT32 baudrate);
+
+void exit_err(UINT8 err)
+{
+#if ( HIGH_SPEED_PATCHRAM_DOWNLOAD == TRUE )
+ ChangeBaudRate(115200);
+#endif
+ exit(err);
+}
+
+#if 0
+void usleep(unsigned long u)
+{
+ clock_t end, start = clock();
+ if (start == (clock_t) -1) return;
+ end = start + CLOCKS_PER_SEC * (u / 1000000.0);
+ while (clock() != end) ;
+}
+#endif
+
+void print_time(void)
+{
+#if 0
+ struct timespec tp;
+ int rs;
+
+ rs = clock_gettime(CLOCK_REALTIME,&tp);
+ fprintf(stderr, "[%04d : %06d]\n", tp.tv_sec, tp.tv_nsec/1000);
+ return;
+#endif
+}
+
+
+void dump(unsigned char *out, int len)
+{
+ int i;
+
+ for (i = 0; i < len; i++)
+ {
+ if (!(i % 16))
+ {
+ DEBUG0( "\n");
+ }
+ DEBUG1( "%02x ", out[i]);
+ }
+ DEBUG0( "\n\n");
+}
+
+UINT8 SendCommand(UINT16 opcode, UINT8 param_len, UINT8 *p_param_buf)
+{
+ UINT8 pbuf[255] = {0,};
+ UINT8 i=0;
+
+ pbuf[0] = 0x1;
+ pbuf[1] = (UINT8)(opcode);
+ pbuf[2] = (UINT8)(opcode >>8);
+ pbuf[3] = param_len;
+
+ for (i=0; i<param_len; i++)
+ {
+ pbuf[i+4] = *p_param_buf++;
+ }
+
+ DEBUG1( "Send %d",param_len+4);
+
+ dump(pbuf, param_len+4);
+
+ write(fd, pbuf, param_len+4);
+ return 0;
+}
+
+void expired(int sig)
+{
+ static UINT8 count = 0;
+ DEBUG0( "expired try again\n");
+ SendCommand(HCI_RESET, 0, NULL);
+ alarm(1);
+ count++;
+
+ if(count > 3)
+ {
+ fprintf(stderr, "[ERR] HCI reset time expired\n");
+ exit(1);
+ }
+}
+
+void read_event(int fd, unsigned char *buffer)
+{
+ int i = 0;
+ int len = 3;
+ int count;
+
+ while ((count = read(fd, &buffer[i], len)) < len)
+ {
+ i += count;
+ len -= count;
+ }
+
+ i += count;
+ len = buffer[2];
+
+ while ((count = read(fd, &buffer[i], len)) < len)
+ {
+ i += count;
+ len -= count;
+ }
+
+#ifdef DEBUG
+ count += i;
+
+ DEBUG1( "received %d", count);
+ dump(buffer, count);
+#endif
+}
+
+UINT8 DownloadPatchram( char *patchram1, char *patchram2 )
+{
+ UINT32 len;
+ char prm[128] ={0,};
+ int fd2; /* file handle for patch config*/
+
+#if ( PRM_SELECT_PATCHRAM_INCLUDED == TRUE )
+ UINT8 status;
+ UINT8 *data = NULL;
+ tBTM_VERSION_INFO p_vi;
+#endif
+
+ DEBUG2( "\n%s\n%s\n", patchram1, patchram2);
+
+ /* HCI reset */
+ DEBUG0( "HCI reset\n");
+ SendCommand(HCI_RESET, 0, NULL);
+ alarm(1);
+ read_event(fd, buffer);
+ alarm(0);
+
+#if ( HIGH_SPEED_PATCHRAM_DOWNLOAD == TRUE )
+ ChangeBaudRate(921600);
+#endif
+
+#if ( PRM_SELECT_PATCHRAM_INCLUDED == TRUE )
+ /* read local version */
+ DEBUG0( "Read local version\n");
+ SendCommand(HCI_READ_LOCAL_VERSION_INFO, 0, NULL);
+ read_event(fd, buffer);
+
+ data = &buffer[6]; /* Filter Header */
+ STREAM_TO_UINT8 (status, data);
+ STREAM_TO_UINT8 (p_vi.hci_version, data);
+ STREAM_TO_UINT16 (p_vi.hci_revision, data);
+ STREAM_TO_UINT8 (p_vi.lmp_version, data);
+ STREAM_TO_UINT16 (p_vi.manufacturer, data);
+ STREAM_TO_UINT16 (p_vi.lmp_subversion, data);
+
+ DEBUG1( "status = 0x%02x\n", status);
+ DEBUG1( "hci_version = 0x%02x\n", p_vi.hci_version);
+ DEBUG1( "hci_revision = 0x%04x\n", p_vi.hci_revision);
+ DEBUG1( "lmp_version = 0x%02x\n", p_vi.lmp_version);
+ DEBUG1( "manufacturer = 0x%04x\n", p_vi.manufacturer);
+ DEBUG1( "lmp_subversion = 0x%04x\n", p_vi.lmp_subversion);
+
+ if( p_vi.lmp_subversion == BTA_PRM_SUBVER_BCM4325_D0 )
+ {
+ UINT8 param_buf[VSC_ARM_MEM_PEEK_CMD_LEN];
+ UINT32 peek_addr = PEEK_ADDR_4_BCM4325_SEL;
+ UINT8 peek_val = 0x0;
+
+ param_buf[0] = VSC_ARM_MEM_PEEK_CMD_TYPE;
+ memcpy(&param_buf[VSC_ARM_MEM_PEEK_CMD_ADDR_OFFSET], &peek_addr, 4);
+
+ SendCommand(VSC_ARM_MEM_PEEK_CMD, VSC_ARM_MEM_PEEK_CMD_LEN, param_buf);
+ read_event(fd, buffer);
+
+ data = &buffer[6]; /* Filter Header */
+ STREAM_TO_UINT8 (status, data);
+ STREAM_TO_UINT8 (peek_val, data);
+ DEBUG1( "status = 0x%02x\n", status);
+ DEBUG1( "peek_val = 0x%02x\n", peek_val);
+
+ if(peek_val == PEEK_VAL_4_BCM4325_D0)
+ {
+ DEBUG0("Detect BCM4325 D0\n");
+ p_vi.lmp_subversion = BTA_PRM_SUBVER_BCM4325_D0;
+ strcpy(prm,patchram1);
+ }
+ else if(peek_val == PEEK_VAL_4_BCM4325_D1)
+ {
+ DEBUG0("Detect BCM4325 D1\n");
+ p_vi.lmp_subversion = BTA_PRM_SUBVER_BCM4325_D1;
+ strcpy(prm,patchram2);
+ }
+ else
+ {
+ /* Unknown case, set BCM4325D1 */
+ DEBUG1( "[ERR] Unknown peek_val = 0x%02x\n", peek_val);
+ p_vi.lmp_subversion = BTA_PRM_SUBVER_BCM4325_D0;
+ strcpy(prm,patchram1);
+ }
+ }
+#else /* PRM_SELECT_PATCHRAM_INCLUDED */
+
+ strncpy(prm, patchram1, 127);
+
+#endif /* PRM_SELECT_PATCHRAM_INCLUDED */
+
+ fprintf(stderr, "Downloading %s\n", prm);
+
+ if ((fd2 = open(prm, O_RDONLY)) == -1)
+ {
+ fprintf(stderr, "file %s could not be opened, error %d\n", prm, errno);
+ exit_err(1);
+ }
+
+ SendCommand(HCI_BRCM_DOWNLOAD_MINI_DRV, 0, NULL);
+ read_event(fd, buffer);
+
+ read(fd, &buffer[0], 2);
+
+#ifdef DEBUG
+ DEBUG0( "read\n");
+ dump(buffer, 2);
+#endif
+
+ while (read(fd2, &buffer[1], 3))
+ {
+ buffer[0] = 0x01;
+
+ len = buffer[3];
+
+ read(fd2, &buffer[4], len);
+
+#ifdef DEBUG
+ DEBUG0( "writing\n");
+ dump(buffer, len + 4);
+#endif
+ write(fd, buffer, len + 4);
+
+ read_event(fd, buffer);
+
+ }
+ close(fd2);
+
+ usleep(100000); /*100ms delay */
+
+ tcflush(fd, TCIOFLUSH);
+ tcgetattr(fd, &termios);
+ cfmakeraw(&termios);
+ termios.c_cflag |= CRTSCTS;
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcflush(fd, TCIOFLUSH);
+ cfsetospeed(&termios, B115200);
+ cfsetispeed(&termios, B115200);
+ tcsetattr(fd, TCSANOW, &termios);
+
+ /* Send HCI_RESET Command and process event */
+ DEBUG0( "HCI reset\n");
+ SendCommand(HCI_RESET, 0, NULL);
+ alarm(1);
+ read_event(fd, buffer);
+ alarm(0);
+ fprintf(stderr,"Patchram download success\n");
+
+ return 0;
+}
+
+void SetScanEnable(void)
+{
+ UINT8 scan_data[1] ;
+
+ /* 0x00: No scan enabled */
+ /* 0x01: Inquiry scan enabled | Page scan disabled */
+ /* 0x02: Inquiry scan disabled | Page scan enabled */
+ /* 0x03: Inquiry scan enabled | Page scan enabled */
+
+ scan_data[0]= 0x03;
+ SendCommand(HCI_WRITE_SCAN_ENABLE, 1, &scan_data[0]);
+ read_event(fd, buffer);
+}
+
+void SetAudio(void)
+{
+ fprintf(stderr,"Write Audio parameter\n");
+
+ DEBUG5( "vsc_for_sco_pcm = {%d,%d,%d,%d,%d}\n", vsc_for_sco_pcm[0],
+ vsc_for_sco_pcm[1],vsc_for_sco_pcm[2],
+ vsc_for_sco_pcm[3],vsc_for_sco_pcm[4]);
+
+ SendCommand(HCI_BRCM_WRITE_SCO_PCM_INT_PARAM, 5, (UINT8 *)vsc_for_sco_pcm);
+ read_event(fd, buffer);
+
+ DEBUG5( "vsc_for_pcm_config = {%d,%d,%d,%d,%d}\n", vsc_for_pcm_config[0],
+ vsc_for_pcm_config[1], vsc_for_pcm_config[2],
+ vsc_for_pcm_config[3], vsc_for_pcm_config[4]);
+
+ SendCommand(VSC_WRITE_PCM_DATA_FORMAT_PARAM, 5, (UINT8 *)vsc_for_pcm_config);
+ read_event(fd, buffer);
+}
+
+void SetPcmConf( UINT8 p0, UINT8 p1, UINT8 p2, UINT8 p3, UINT8 p4 )
+{
+ vsc_for_pcm_config[0] = p0;
+ vsc_for_pcm_config[1] = p1;
+ vsc_for_pcm_config[2] = p2;
+ vsc_for_pcm_config[3] = p3;
+ vsc_for_pcm_config[4] = p4;
+}
+
+void SetScoConf( UINT8 p0, UINT8 p1, UINT8 p2, UINT8 p3, UINT8 p4 )
+{
+ vsc_for_sco_pcm[0] = p0;
+ vsc_for_sco_pcm[1] = p1;
+ vsc_for_sco_pcm[2] = p2;
+ vsc_for_sco_pcm[3] = p3;
+ vsc_for_sco_pcm[4] = p4;
+}
+
+void HCILP_Enable(BOOLEAN on)
+{
+ fprintf(stderr,"Set Low Power mode %d\n",on);
+ UINT8 data[HCI_BRCM_WRITE_SLEEP_MODE_LENGTH] = {
+ 0x01, /* Sleep Mode algorithm 1 */
+ HCILP_IDLE_THRESHOLD, /* Host Idle Treshold in 300ms */
+ HCILP_HC_IDLE_THRESHOLD, /* Host Controller Idle Treshold in 300ms */ /* this should be less than scan interval.*/
+ HCILP_BT_WAKE_POLARITY, /* BT_WAKE Polarity - 0=Active Low, 1= Active High*/
+ HCILP_HOST_WAKE_POLARITY, /* HOST_WAKE Polarity - 0=Active Low, 1= Active High */
+ 0x01, /* Allow host Sleep during SCO */
+ 0x01, /* Combine Sleep Mode and LPM - The device will not sleep in mode 0 if this flag is set to 1,*/
+ 0x00, /* UART_TXD Tri-State : 0x00 = Do not tri-state UART_TXD in sleep mode */
+ 0x00, /* NA to Mode 1 */
+ 0x00, /* NA to Mode 1 */
+ };
+
+ if(on)
+ {
+ data[0] = 0x01;
+ }
+ else
+ {
+ data[0] = 0x00;
+ }
+
+ SendCommand(HCI_BRCM_WRITE_SLEEP_MODE, HCI_BRCM_WRITE_SLEEP_MODE_LENGTH, (UINT8 *)data);
+ read_event(fd, buffer);
+}
+
+UINT32 uart_speed(UINT32 Speed)
+{
+ switch (Speed)
+ {
+ case 115200:
+ return B115200;
+ case 230400:
+ return B230400;
+ case 460800:
+ return B460800;
+ case 921600:
+ return B921600;
+ case 1000000:
+ return B1000000;
+ case 1500000:
+ return B1500000;
+ case 2000000:
+ return B2000000;
+ case 2500000:
+ return B2500000;
+ case 3000000:
+ return B3000000;
+ case 4000000:
+ return B4000000;
+ default:
+ return B115200;
+ }
+}
+
+void ChangeBaudRate(UINT32 baudrate)
+{
+ UINT8 hci_data[HCI_BRCM_UPDATE_BAUD_RATE_UNENCODED_LENGTH] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
+ UINT8 uart_clock_24 = 0x2; /* 0x1 - UART Clock 48MHz, 0x2 - UART Clock 24MHz */
+ UINT8 uart_clock_48 = 0x1; /* 0x1 - UART Clock 48MHz, 0x2 - UART Clock 24MHz */
+
+ switch(baudrate)
+ {
+ case 115200:
+ case 230400:
+ case 460800:
+ case 921600:
+ case 1000000:
+ case 1500000:
+ case 2000000:
+ case 2500000:
+ /* Write UART Clock setting of 24MHz */
+ DEBUG0( "Change UART_CLOCK 24Mhz");
+ SendCommand( VSC_WRITE_UART_CLOCK_SETTING, VSC_WRITE_UART_CLOCK_SETTING_LEN, (UINT8 *)&uart_clock_24);
+ read_event(fd, buffer);
+ break;
+
+ case 3000000:
+ case 4000000:
+ /* Write UART Clock setting of 48MHz */
+ DEBUG0( "Change UART_CLOCK 48Mhz");
+ SendCommand( VSC_WRITE_UART_CLOCK_SETTING, VSC_WRITE_UART_CLOCK_SETTING_LEN, (UINT8 *)&uart_clock_48);
+ read_event(fd, buffer);
+ break;
+
+ default:
+ fprintf(stderr,"Not Support baudrate = %d", baudrate);
+ exit_err(1);
+ break;
+ }
+
+ hci_data[2] = baudrate & 0xFF;
+ hci_data[3] = (baudrate >> 8) & 0xFF;
+ hci_data[4] = (baudrate >> 16) & 0xFF;
+ hci_data[5] = (baudrate >> 24) & 0xFF;
+
+ DEBUG1( "Change Baudrate %d\n",baudrate);
+
+ SendCommand( HCI_BRCM_UPDATE_BAUDRATE_CMD, HCI_BRCM_UPDATE_BAUD_RATE_UNENCODED_LENGTH, (UINT8 *)hci_data);
+ read_event(fd, buffer);
+
+
+ tcflush(fd, TCIOFLUSH);
+ tcgetattr(fd, &termios);
+ cfmakeraw(&termios);
+ termios.c_cflag |= CRTSCTS;
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcflush(fd, TCIOFLUSH);
+ cfsetospeed(&termios, uart_speed(baudrate));
+ cfsetispeed(&termios, uart_speed(baudrate));
+ tcsetattr(fd, TCSANOW, &termios);
+
+}
+
+void EnableTestMode(void)
+{
+ UINT8 filter_data[] = { 0x02, 0x00, 0x02 };
+
+ /* bt sleep disable */
+ HCILP_Enable(FALSE);
+
+ /* Enable both Inquiry & Page Scans */
+ SetScanEnable();
+
+ /* Set Event Filter: Enable Auto Connect */
+ SendCommand( HCI_SET_EVENT_FILTER, 0x03, (UINT8 *)filter_data);
+ read_event(fd, buffer);
+
+ /* Enable Device under test */
+ SendCommand( HCI_ENABLE_DEV_UNDER_TEST_MODE, 0x0, NULL);
+ read_event(fd, buffer);
+
+ fprintf(stderr,"Enable Device Under Test\n");
+}
+
+void print_usage( void )
+{
+ fprintf(stderr,"\n");
+ fprintf(stderr,"BRCM BT tool for Linux release 2009.12.10\n");
+ fprintf(stderr,"\n");
+ fprintf(stderr," Usage: bcmtool <tty Device> <command> [command parameter],....\n\n");
+#if ( PRM_SELECT_PATCHRAM_INCLUDED == TRUE )
+ fprintf(stderr," -FILE Patchram file name EX) -FILE=BCM4325D0.hcd, BCM4325D1.hcd\n");
+#else
+ fprintf(stderr," -FILE Patchram file name EX) -FILE=BCM4325D1.hcd\n");
+#endif
+ fprintf(stderr," -ADDR BD addr file name EX) -ADDR=.bdaddr\n");
+ fprintf(stderr," -SCO Enable SCO/PCM config EX) -SCO\n");
+ fprintf(stderr," -SETSCO SCO/PCM values verify EX) -SETSCO=0,1,0,1,1,0,0,3,3,0\n");
+ fprintf(stderr," -LP Enable Low power EX) -LP\n");
+ fprintf(stderr," -DUT Enable DUT mode(do not use with -LP) EX) -DUT\n");
+ fprintf(stderr," -DEBUG Debug message EX) -DEBUG\n");
+ fprintf(stderr,"\n");
+}
+
+int main(int argc, char *argv[])
+{
+ UINT8 i = 0;
+
+ fprintf(stderr,"BRCM BT tool for Linux release 2009.12.10\n");
+
+ if (argc < 2)
+ {
+ print_usage();
+ exit(1);
+ }
+
+ /* Open dev port */
+ if ((fd = open(argv[1], O_RDWR | O_NOCTTY)) == -1)
+ {
+ fprintf(stderr, "port %s could not be opened, error %d\n", argv[1], errno);
+ exit(2);
+ }
+
+ tcflush(fd, TCIOFLUSH);
+ tcgetattr(fd, &termios);
+ cfmakeraw(&termios);
+ termios.c_cflag |= CRTSCTS;
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcflush(fd, TCIOFLUSH);
+ cfsetospeed(&termios, B115200);
+ cfsetispeed(&termios, B115200);
+ tcsetattr(fd, TCSANOW, &termios);
+
+ signal(SIGALRM, expired);
+
+ for( i=2; i<argc; i++ )
+ {
+ char *ptr = argv[i];
+
+ if( strstr(ptr,"-DEBUG") )
+ {
+ debug_mode = TRUE;
+ DEBUG0("DEBUG On\n");
+ break;
+ }
+ }
+
+ for( i=2; i<argc; i++ )
+ {
+ char *ptr = argv[i];
+
+ fprintf(stderr,"[%d] %s\n", i-1, ptr);
+
+ if( strstr(ptr,"-FILE=") )
+ {
+#if ( PRM_SELECT_PATCHRAM_INCLUDED == TRUE )
+ int ret, j, k;
+#endif
+ char prm_name[2][128];
+
+ ptr += 6;
+#if ( PRM_SELECT_PATCHRAM_INCLUDED == TRUE )
+ memset(prm_name,0,sizeof(prm_name));
+
+ for( j=k=ret=0; j<strlen(ptr); j++ )
+ {
+ if( ret==0 || ret==1 )
+ {
+ if( ptr[j] != ',' )
+ prm_name[ret][k++] = ptr[j];
+ else
+ {
+ prm_name[ret][k] = '\0';
+ k = 0;
+ ret++;
+ }
+ }
+
+ else if( ret==2 )
+ {
+ ret++;
+ break;
+ }
+ }
+
+ if( ret < 1 )
+ {
+ DEBUG0("-FILE: Parameter error");
+ exit_err(1);
+ }
+#else
+ strcpy(prm_name[0],ptr);
+ strcpy(prm_name[1],ptr);
+#endif
+ DownloadPatchram( prm_name[0], prm_name[1]);
+
+ }
+ else if( strstr(ptr,"-BAUD=") )
+ {
+ UINT32 baudrate;
+
+ ptr += 6;
+ baudrate = atoi(ptr);
+
+ ChangeBaudRate(baudrate);
+ }
+ else if( strstr(ptr,"-ADDR=") )
+ {
+ char *bdaddr_filename;
+ FILE* pFile = NULL;
+
+ UINT8 bdaddr[10]; /* Displayed BD Address */
+
+ BD_ADDR local_addr; /* BD Address for write */
+
+#if 0
+ ptr += 6;
+ if( sscanf(ptr,"%02X:%02X:%02X:%02X:%02X:%02X",&bdaddr[0],&bdaddr[1],&bdaddr[2],&bdaddr[3],&bdaddr[4],&bdaddr[5]) != 6 )
+ {
+ fprintf(stderr,"-ADDR: Parameter error");
+ exit_err(1);
+ }
+ bte_write_bdaddr(bdaddr);
+#endif
+ ptr += 6;
+ bdaddr_filename = ptr;
+
+ if(bdaddr_filename)
+ {
+ pFile = fopen(bdaddr_filename, "r");
+ }
+
+ if(pFile)
+ {
+ char text[BTUI_MAX_STRING_LENGTH_PER_LINE];
+
+ fgets(text, BTUI_MAX_STRING_LENGTH_PER_LINE, pFile);
+ sscanf(text,"%02x%02x",&bdaddr[0],&bdaddr[1]);
+
+ fgets(text, BTUI_MAX_STRING_LENGTH_PER_LINE, pFile);
+ sscanf(text,"%02x",&bdaddr[2]);
+
+ fgets(text, BTUI_MAX_STRING_LENGTH_PER_LINE, pFile);
+ sscanf(text,"%02x%02x%02x",&bdaddr[3],&bdaddr[4],&bdaddr[5]);
+
+ fprintf(stderr,"Writing B/D Address = %02X:%02X:%02X:%02X:%02X:%02X\n",bdaddr[0],bdaddr[1],bdaddr[2],bdaddr[3],bdaddr[4],bdaddr[5]);
+
+ ROTATE_BD_ADDR(local_addr,bdaddr);
+
+ SendCommand(VSC_WRITE_BD_ADDR, BD_ADDR_LEN, (UINT8 *)local_addr);
+ read_event(fd, buffer);
+ }
+ else
+ {
+ fprintf(stderr, "-ADDR: file open fail\n");
+ exit_err(1);
+ }
+
+ }
+ else if( strstr(ptr,"-SCO") )
+ {
+ SetAudio();
+
+ }
+ else if( strstr(ptr,"-SETSCO=") )
+ {
+ ptr += 8;
+ UINT8 value[10];
+
+ if( sscanf(ptr,"%d,%d,%d,%d,%d,%d,%d,%d,%d,%d",&value[0],&value[1],&value[2],&value[3],&value[4],
+ &value[5],&value[6],&value[7],&value[8],&value[9]) != 10 )
+ {
+ DEBUG0("PCM / SCO configuration value err\n");
+ DEBUG0("SCO_Routing,PCM_Interface_Rate,Frame_Type,Sync_Mode,Clock_Mode,LSB_First,Fill_bits,Fill_Method,Fill_Num,Right_Justify\n");
+ exit_err(1);
+ }
+
+ SetScoConf( value[0],value[1],value[2],value[3],value[4] );
+ SetPcmConf( value[5],value[6],value[7],value[8],value[9] );
+ SetAudio();
+ }
+ else if( strstr(ptr,"-LP") )
+ {
+ HCILP_Enable(TRUE);
+ }
+ else if( strstr(ptr,"-DUT") )
+ {
+ EnableTestMode();
+ }
+ else if( strstr(ptr,"-DEBUG") )
+ {
+
+ }
+ else
+ {
+ fprintf(stderr,"Invalid parameter(s)!\n");
+ exit_err(1);
+ }
+ }
+
+ fprintf(stderr, "EXIT\n");
+ close(fd);
+ exit(0);
+
+ return 0;
+}
diff --git a/wearable/tools/bcmtool_4330b1.c b/wearable/tools/bcmtool_4330b1.c
new file mode 100644
index 0000000..65f7583
--- /dev/null
+++ b/wearable/tools/bcmtool_4330b1.c
@@ -0,0 +1,1024 @@
+/*****************************************************************************
+**
+** Name: bcmtool.c
+**
+** Description: Download a patchram files for the HCD format
+**
+** Copyright (c) 2000-2009, Broadcom Corp., All Rights Reserved.
+******************************************************************************/
+
+#include <stdio.h>
+#include <errno.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <stdlib.h>
+#include <time.h>
+#include <string.h>
+#include <signal.h>
+#include <unistd.h>
+#include <sys/termios.h>
+#include <sys/ioctl.h>
+#include <limits.h>
+
+#define N_HCI 15
+#define HCI_UART_H4 0
+#define HCI_UART_BCSP 1
+#define HCI_UART_3WIRE 2
+#define HCI_UART_H4DS 3
+#define HCI_UART_LL 4
+#define HCIUARTSETPROTO _IOW('U', 200, int)
+#define HCIUARTGETPROTO _IOR('U', 201, int)
+#define HCIUARTGETDEVICE _IOR('U', 202, int)
+
+/* Pre baudrate change for fast download */
+#define HIGH_SPEED_PATCHRAM_DOWNLOAD TRUE
+
+/* Host Stack Idle Threshold */
+#define HCILP_IDLE_THRESHOLD 0x01
+
+/* Host Controller Idle Threshold */
+#define HCILP_HC_IDLE_THRESHOLD 0x01
+
+/* BT_WAKE Polarity - 0=Active Low, 1= Active High */
+#define HCILP_BT_WAKE_POLARITY 1
+
+/* HOST_WAKE Polarity - 0=Active Low, 1= Active High */
+#define HCILP_HOST_WAKE_POLARITY 1
+
+/* Local Feature */
+#define BCM_DISABLE_RF_PWRCTRL FALSE
+
+#define RELEASE_DATE "2011.02.07"
+#define DEBUG 1
+
+/* Broadcom AXI patch for BCM4335 chipset only */
+/* #define DEPLOY_4335A_AXI_BRIDGE_PATCH TRUE */
+
+/* The fix for AXI bridge contention between BT and WLAN:
+ *
+ * Set this TRUE only when
+ * 1. the platform is using BCM4335A or BCM4335B0, and
+ * 2. Kernel source has implemented AXI BRIDGE lock logic.
+ */
+#ifndef DEPLOY_4335A_AXI_BRIDGE_PATCH
+#define DEPLOY_4335A_AXI_BRIDGE_PATCH FALSE
+#endif
+
+typedef unsigned char UINT8;
+typedef unsigned short UINT16;
+typedef unsigned long UINT32;
+typedef signed long INT32;
+typedef signed char INT8;
+typedef signed short INT16;
+typedef unsigned char BOOLEAN;
+
+#define FALSE 0
+#define TRUE (!FALSE)
+
+#define BD_ADDR_LEN 6 /* Device address length */
+typedef UINT8 BD_ADDR[BD_ADDR_LEN]; /* Device address */
+
+#define HCI_GRP_LINK_CONTROL_CMDS (0x01 << 10)
+#define HCI_GRP_LINK_POLICY_CMDS (0x02 << 10)
+#define HCI_GRP_HOST_CONT_BASEBAND_CMDS (0x03 << 10)
+#define HCI_GRP_INFORMATIONAL_PARAMS (0x04 << 10)
+#define HCI_GRP_STATUS_PARAMS (0x05 << 10)
+#define HCI_GRP_TESTING_CMDS (0x06 << 10)
+#define HCI_GRP_L2CAP_CMDS (0x07 << 10)
+#define HCI_GRP_L2CAP_HCI_EVTS (0x08 << 10)
+#define HCI_GRP_VENDOR_SPECIFIC (0x3F << 10)
+
+#define HCI_RESET (0x0003 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+#define HCI_SET_EVENT_FILTER (0x0005 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+#define HCI_READ_LOCAL_NAME (0x0014 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+#define HCI_READ_SCAN_ENABLE (0x0019 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+#define HCI_WRITE_SCAN_ENABLE (0x001A | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
+
+#define HCI_READ_LOCAL_VERSION_INFO (0x0001 | HCI_GRP_INFORMATIONAL_PARAMS)
+#define HCI_READ_LOCAL_FEATURES (0x0003 | HCI_GRP_INFORMATIONAL_PARAMS)
+
+#define HCI_ENABLE_DEV_UNDER_TEST_MODE (0x0003 | HCI_GRP_TESTING_CMDS)
+
+#define HCI_BRCM_SUPER_PEEK_POKE (0x000A | HCI_GRP_VENDOR_SPECIFIC)
+#define VSC_WRITE_BD_ADDR (0x0001 | HCI_GRP_VENDOR_SPECIFIC)
+#define VSC_HCI_CMD_SET_LOC_FEATURES_CMD (0x000B | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_UPDATE_BAUDRATE_CMD (0x0018 | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_WRITE_SCO_PCM_INT_PARAM (0x001C | HCI_GRP_VENDOR_SPECIFIC)
+#define VSC_WRITE_PCM_DATA_FORMAT_PARAM (0x001E | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_WRITE_SLEEP_MODE (0x0027 | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_BRCM_DOWNLOAD_MINI_DRV (0x002E | HCI_GRP_VENDOR_SPECIFIC)
+#define VSC_WRITE_UART_CLOCK_SETTING (0x0045 | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_VSC_WRITE_RAM (0x004C | HCI_GRP_VENDOR_SPECIFIC)
+#define HCI_VSC_LAUNCH_RAM (0x004E | HCI_GRP_VENDOR_SPECIFIC)
+
+#define VOICE_SETTING_MU_LAW_MD 0x0100
+#define VOICE_SETTING_LINEAR_MD 0x0060
+
+#define HCI_ARM_MEM_PEEK 0x04
+#define HCI_ARM_MEM_POKE 0x05
+
+#define BTUI_MAX_STRING_LENGTH_PER_LINE 255
+#define HCI_BRCM_WRITE_SLEEP_MODE_LENGTH 10
+
+#define HCI_BRCM_UPDATE_BAUD_RATE_ENCODED_LENGTH 0x02
+#define HCI_BRCM_UPDATE_BAUD_RATE_UNENCODED_LENGTH 0x06
+
+#define VSC_WRITE_UART_CLOCK_SETTING_LEN 1
+
+/* print string with time stamp */
+#define TDEBUG0(m) if(debug_mode) {print_time();fprintf(stderr,m);}
+#define TDEBUG1(m,n1) if(debug_mode) {print_time();fprintf(stderr,m,n1);}
+#define TDEBUG2(m,n1,n2) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2);}
+#define TDEBUG3(m,n1,n2,n3) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3);}
+#define TDEBUG4(m,n1,n2,n3,n4) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3,n4);}
+#define TDEBUG5(m,n1,n2,n3,n4,n5) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3,n4,n5);}
+#define TDEBUG6(m,n1,n2,n3,n4,n5,n6) if(debug_mode) {print_time();fprintf(stderr,m,n1,n2,n3,n4,n5,n6);}
+
+/* print just string */
+#define DEBUG0(m) if(debug_mode) {fprintf(stderr,m);}
+#define DEBUG1(m,n1) if(debug_mode) {fprintf(stderr,m,n1);}
+#define DEBUG2(m,n1,n2) if(debug_mode) {fprintf(stderr,m,n1,n2);}
+#define DEBUG3(m,n1,n2,n3) if(debug_mode) {fprintf(stderr,m,n1,n2,n3);}
+#define DEBUG4(m,n1,n2,n3,n4) if(debug_mode) {fprintf(stderr,m,n1,n2,n3,n4);}
+#define DEBUG5(m,n1,n2,n3,n4,n5) if(debug_mode) {fprintf(stderr,m,n1,n2,n3,n4,n5);}
+#define DEBUG6(m,n1,n2,n3,n4,n5,n6) if(debug_mode) {fprintf(stderr,m,n1,n2,n3,n4,n5,n6);}
+
+#define STREAM_TO_UINT8(u8, p) {u8 = (UINT8)(*(p)); (p) += 1;}
+#define STREAM_TO_UINT16(u16, p) {u16 = ((UINT16)(*(p)) + (((UINT16)(*((p) + 1))) << 8)); (p) += 2;}
+#define STREAM_TO_UINT32(u32, p) {u32 = (((UINT32)(*(p))) + ((((UINT32)(*((p) + 1)))) << 8) + ((((UINT32)(*((p) + 2)))) << 16) + ((((UINT32)(*((p) + 3)))) << 24)); (p) += 4;}
+
+#define ROTATE_BD_ADDR(p1, p2) \
+ do \
+ { \
+ p1[0] = p2[5]; \
+ p1[1] = p2[4]; \
+ p1[2] = p2[3]; \
+ p1[3] = p2[2]; \
+ p1[4] = p2[1]; \
+ p1[5] = p2[0]; \
+ } while (0)
+
+UINT8 vsc_for_pcm_config[5] = { 0x00, 0x00, 0x03, 0x03, 0x00 };
+
+/*
+ Byte1 -- 0 for MSb first
+ Byte2 -- 0 Fill value
+ Byte3 -- 1 Fill option (0:0's, 1:1's , 2:Signed, 3:Programmable)
+ Byte4 -- 1 Number of fill bits
+ Byte5 -- 1 Right justified (0 for left justified)
+*/
+
+UINT8 vsc_for_sco_pcm[5] = { 0x00, 0x01, 0x00, 0x01, 0x01 };
+
+/*
+ Neverland : PCM, 256, short, master ,master
+ Volance : PCM, 256, short, master ,master
+
+ Byte1 -- 0 for PCM 1 for UART or USB
+ Byte2 -- 0 : 128, 1: 256, 2:512, 3:1024, 4:2048 Khz
+ Byte3 -- 0 for short frame sync 1 for long frame sync
+ Byte4 -- 0 Clock direction 0 for same as sync 1 for opposite direction
+ Byte5 -- 0 for slave 1 for master
+*/
+
+int fd; /* HCI handle */
+
+BOOLEAN debug_mode = FALSE; /* Debug Mode Enable */
+
+BOOLEAN use_two_stop_bits = FALSE; /* Flag of two stop bits for tty */
+
+unsigned char buffer[1024];
+
+struct termios termios;
+
+void ChangeBaudRate(UINT32 baudrate);
+
+void exit_err(UINT8 err)
+{
+#if ( HIGH_SPEED_PATCHRAM_DOWNLOAD == TRUE )
+ ChangeBaudRate(115200);
+#endif
+ exit(err);
+}
+
+void print_time(void)
+{
+#if 0
+ struct timespec tp;
+ int rs;
+
+ rs = clock_gettime(CLOCK_REALTIME, &tp);
+ fprintf(stderr, "[%04d : %06d]\n", tp.tv_sec, tp.tv_nsec / 1000);
+ return;
+#endif
+}
+
+void dump(unsigned char *out, int len)
+{
+ int i;
+
+ for (i = 0; i < len; i++) {
+ if (!(i % 16)) {
+ DEBUG0("\n");
+ }
+ DEBUG1("%02x ", out[i]);
+ }
+ DEBUG0("\n\n");
+}
+
+UINT8 SendCommand(UINT16 opcode, UINT8 param_len, UINT8 * p_param_buf)
+{
+ UINT8 pbuf[255] = { 0, };
+ UINT8 i = 0;
+
+ pbuf[0] = 0x1;
+ pbuf[1] = (UINT8) (opcode);
+ pbuf[2] = (UINT8) (opcode >> 8);
+ pbuf[3] = param_len;
+
+ for (i = 0; i < param_len; i++) {
+ pbuf[i + 4] = *p_param_buf++;
+ }
+
+ DEBUG1("Send %d", param_len + 4);
+
+ dump(pbuf, param_len + 4);
+
+ write(fd, pbuf, param_len + 4);
+ return 0;
+}
+
+void expired(int sig)
+{
+ static UINT8 count = 0;
+ DEBUG0("expired try again\n");
+ SendCommand(HCI_RESET, 0, NULL);
+ alarm(1);
+ count++;
+
+ if (count > 3) {
+ fprintf(stderr, "[ERR] HCI reset time expired\n");
+ exit(1);
+ }
+}
+
+void read_event(int fd, unsigned char *buffer)
+{
+ int i = 0;
+ int len = 3;
+ int count;
+
+ while ((count = read(fd, &buffer[i], len)) < len) {
+ i += count;
+ len -= count;
+ }
+
+ i += count;
+ len = buffer[2];
+
+ while ((count = read(fd, &buffer[i], len)) < len) {
+ i += count;
+ len -= count;
+ }
+
+#ifdef DEBUG
+ count += i;
+
+ DEBUG1("\nreceived %d", count);
+ dump(buffer, count);
+#endif
+}
+
+INT32 filesize(char *name)
+{
+ INT32 size;
+ int flag;
+ struct stat buf;
+
+ flag = stat(name, &buf);
+ if (flag == -1)
+ return -1;
+
+ size = buf.st_size;
+ return (size);
+}
+
+void DisplayProgress(int total, int val)
+{
+#if 0
+#define PROGRESS_NUM 20
+
+ int p;
+ int i;
+ char text[PROGRESS_NUM + 2] = { 0, };
+
+ text[0] = '[';
+ text[PROGRESS_NUM + 1] = ']';
+ p = (val * PROGRESS_NUM) / total;
+
+ for (i = 1; i <= p; i++) {
+ text[i] = '=';
+ }
+
+ for (i = p + 1; i <= PROGRESS_NUM; i++) {
+ text[i] = ' ';
+ }
+
+ for (i = 0; i <= (PROGRESS_NUM + 1); i++) {
+ fprintf(stderr, "%c", text[i]);
+ }
+
+ if (p >= PROGRESS_NUM)
+ fprintf(stderr, " %6d/%6d\n", val, total);
+ else
+ fprintf(stderr, " %6d/%6d\r", val, total);
+#else
+ if (val == total)
+ fprintf(stderr, " %6d/%6d\n", val, total);
+ else
+ fprintf(stderr, " %6d/%6d\r", val, total);
+#endif
+}
+
+#if (DEPLOY_4335A_AXI_BRIDGE_PATCH == TRUE)
+/* 4335A/B0 AXI BRIDEG lock cookie */
+struct btlock {
+ int lock;
+ int cookie;
+};
+
+#define AXI_LOCK_COOKIE ('B' | 'T'<<8 | '3'<<16 | '5'<<24) /* BT35 */
+#define AXI_LOCK_FS_NODE "/dev/btlock"
+
+static const UINT8 bcm4335a_axi_patch_addr[4] =
+{
+ 0x00, 0x02, 0x0d, 0x00
+};
+
+static const UINT8 bcm4335a_axi_patch[] =
+{
+ 0x00, 0x02, 0x0d, 0x00, /* bcm4335a_axi_patch_addr */
+ 0x70, 0xb5, 0x0c, 0x49, 0x4c, 0xf6, 0x20, 0x30,
+ 0x8a, 0xf7, 0xbb, 0xf9, 0x01, 0x28, 0x0d, 0xd1,
+ 0x8a, 0xf7, 0x80, 0xf9, 0x08, 0xb1, 0x04, 0x25,
+ 0x00, 0xe0, 0x05, 0x25, 0x00, 0x24, 0x03, 0xe0,
+ 0x8a, 0xf7, 0x74, 0xf9, 0x64, 0x1c, 0xe4, 0xb2,
+ 0xac, 0x42, 0xf9, 0xd3, 0xbd, 0xe8, 0x70, 0x40,
+ 0x8a, 0xf7, 0x7f, 0xb9, 0xb0, 0x9b, 0x04, 0x00
+};
+
+/*******************************************************************************
+**
+** Function hw_4335_dl_axi_patch
+**
+** Description Download 4335Ax/4335B0 AXI BRIDGE patch
+**
+** Returns TRUE, if fw patch is sent
+** FALSE, otherwise
+**
+*******************************************************************************/
+static UINT8 hw_4335_dl_axi_patch(void)
+{
+ SendCommand(HCI_VSC_WRITE_RAM, sizeof(bcm4335a_axi_patch),
+ (UINT8 *) bcm4335a_axi_patch);
+ read_event(fd, buffer);
+
+ DEBUG0("hw_4335_dl_axi_patch downloading done");
+
+ SendCommand(HCI_VSC_LAUNCH_RAM, sizeof(bcm4335a_axi_patch_addr),
+ (UINT8 *) bcm4335a_axi_patch_addr);
+ read_event(fd, buffer);
+
+ DEBUG0("hw_4335_dl_axi_patch launching done");
+
+ return TRUE;
+}
+
+/*******************************************************************************
+**
+** Function hw_4335_release_axi_bridge_lock
+**
+** Description Notify kernel to release the AXI BRIDGE lock which was
+** acquired earlier in rfkill driver when powering on BT
+** Controller
+**
+** Returns None
+**
+*******************************************************************************/
+void hw_4335_axi_bridge_lock(void)
+{
+ int fd, ret;
+ struct btlock lock;
+
+ lock.cookie = AXI_LOCK_COOKIE;
+ lock.lock = 1;
+
+ fd = open(AXI_LOCK_FS_NODE, O_RDWR);
+ if (fd >= 0)
+ {
+ ret = write(fd, &lock, sizeof(lock));
+ DEBUG0("4335 AXI BRIDGE lock");
+ close(fd);
+ }
+ else
+ {
+ DEBUG1("Failed to unlock AXI LOCK -- can't open %s", AXI_LOCK_FS_NODE);
+ }
+}
+
+/*******************************************************************************
+**
+** Function hw_4335_release_axi_bridge_lock
+**
+** Description Notify kernel to release the AXI BRIDGE lock which was
+** acquired earlier in rfkill driver when powering on BT
+** Controller
+**
+** Returns None
+**
+*******************************************************************************/
+void hw_4335_release_axi_bridge_lock(void)
+{
+ int fd, ret;
+ struct btlock lock;
+
+ lock.cookie = AXI_LOCK_COOKIE;
+ lock.lock = 0;
+
+ fd = open(AXI_LOCK_FS_NODE, O_RDWR);
+ if (fd >= 0)
+ {
+ ret = write(fd, &lock, sizeof(lock));
+ DEBUG0("Releasing 4335 AXI BRIDGE lock");
+ close(fd);
+ }
+ else
+ {
+ DEBUG1("Failed to unlock AXI LOCK -- can't open %s", AXI_LOCK_FS_NODE);
+ }
+}
+#endif /* (DEPLOY_4335A_AXI_BRIDGE_PATCH == TRUE) */
+
+UINT8 DownloadPatchram(char *patchram1)
+{
+ UINT32 len;
+ char prm[128] = { 0, };
+ FILE *pFile = NULL;
+
+ INT32 FileSize = 0;
+ INT32 SentSize = 0;
+
+ DEBUG1("\n%s\n", patchram1);
+
+ /* HCI reset */
+ DEBUG0("HCI reset\n");
+ SendCommand(HCI_RESET, 0, NULL);
+ alarm(1);
+ read_event(fd, buffer);
+ alarm(0);
+
+#if (DEPLOY_4335A_AXI_BRIDGE_PATCH == TRUE)
+ char *p_tmp;
+
+ SendCommand(HCI_READ_LOCAL_NAME, 0, NULL);
+ read_event(fd, buffer);
+
+ p_tmp = strstr((char *)(buffer + 7), "BCM4335");
+ DEBUG1( "chip_name [%s]\n", p_tmp);
+
+ if ((p_tmp != NULL) &&
+ ((p_tmp[7] == 'A') /* 4335A */||
+ ((p_tmp[7] == 'B') && (p_tmp[8] == '0')) /* 4335B0 */)) {
+ hw_4335_dl_axi_patch();
+ }
+#endif
+
+#if ( HIGH_SPEED_PATCHRAM_DOWNLOAD == TRUE )
+ ChangeBaudRate(3000000);
+#endif
+
+ strcpy(prm, patchram1);
+
+ fprintf(stderr, "Download Start\n");
+
+ if ((pFile = fopen(prm, "r")) == NULL) {
+ fprintf(stderr, "file %s could not be opened, error %d\n", prm,
+ errno);
+ exit_err(1);
+ }
+ FileSize = filesize(prm);
+
+ SendCommand(HCI_BRCM_DOWNLOAD_MINI_DRV, 0, NULL);
+ read_event(fd, buffer);
+
+ usleep(50000);
+
+ while (fread(&buffer[1], sizeof(UINT8), 3, pFile)) {
+ buffer[0] = 0x01;
+
+ len = buffer[3];
+
+ fread(&buffer[4], sizeof(UINT8), len, pFile);
+
+ write(fd, buffer, len + 4);
+
+ /* dispaly progress */
+ SentSize += (len + 3);
+#if 0
+ DisplayProgress(FileSize, SentSize);
+#endif
+ /* dispaly progress */
+
+ read_event(fd, buffer);
+
+ }
+ fclose(pFile);
+
+#if (DEPLOY_4335A_AXI_BRIDGE_PATCH == TRUE)
+ hw_4335_release_axi_bridge_lock();
+#endif
+ usleep(100000); /*100ms delay */
+
+ tcflush(fd, TCIOFLUSH);
+ tcgetattr(fd, &termios);
+ cfmakeraw(&termios);
+ termios.c_cflag |= CRTSCTS;
+
+ if (use_two_stop_bits)
+ termios.c_cflag |= CSTOPB;
+
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcflush(fd, TCIOFLUSH);
+ cfsetospeed(&termios, B115200);
+ cfsetispeed(&termios, B115200);
+ tcsetattr(fd, TCSANOW, &termios);
+
+ /* Send HCI_RESET Command and process event */
+ DEBUG0("HCI reset\n");
+ SendCommand(HCI_RESET, 0, NULL);
+ alarm(1);
+ read_event(fd, buffer);
+ alarm(0);
+ fprintf(stderr, "Download Complete\n");
+
+ return 0;
+}
+
+void SetScanEnable(void)
+{
+ UINT8 scan_data[1];
+
+ /* 0x00: No scan enabled */
+ /* 0x01: Inquiry scan enabled | Page scan disabled */
+ /* 0x02: Inquiry scan disabled | Page scan enabled */
+ /* 0x03: Inquiry scan enabled | Page scan enabled */
+
+ scan_data[0] = 0x03;
+ SendCommand(HCI_WRITE_SCAN_ENABLE, 1, &scan_data[0]);
+ read_event(fd, buffer);
+}
+
+void SetAudio(void)
+{
+ fprintf(stderr, "Write Audio parameter\n");
+
+ DEBUG5("vsc_for_sco_pcm = {%d,%d,%d,%d,%d}\n", vsc_for_sco_pcm[0],
+ vsc_for_sco_pcm[1], vsc_for_sco_pcm[2],
+ vsc_for_sco_pcm[3], vsc_for_sco_pcm[4]);
+
+ SendCommand(HCI_BRCM_WRITE_SCO_PCM_INT_PARAM, 5,
+ (UINT8 *) vsc_for_sco_pcm);
+ read_event(fd, buffer);
+
+ DEBUG5("vsc_for_pcm_config = {%d,%d,%d,%d,%d}\n", vsc_for_pcm_config[0],
+ vsc_for_pcm_config[1], vsc_for_pcm_config[2],
+ vsc_for_pcm_config[3], vsc_for_pcm_config[4]);
+
+ SendCommand(VSC_WRITE_PCM_DATA_FORMAT_PARAM, 5,
+ (UINT8 *) vsc_for_pcm_config);
+ read_event(fd, buffer);
+}
+
+void SetPcmConf(UINT8 p0, UINT8 p1, UINT8 p2, UINT8 p3, UINT8 p4)
+{
+ vsc_for_pcm_config[0] = p0;
+ vsc_for_pcm_config[1] = p1;
+ vsc_for_pcm_config[2] = p2;
+ vsc_for_pcm_config[3] = p3;
+ vsc_for_pcm_config[4] = p4;
+}
+
+void SetScoConf(UINT8 p0, UINT8 p1, UINT8 p2, UINT8 p3, UINT8 p4)
+{
+ vsc_for_sco_pcm[0] = p0;
+ vsc_for_sco_pcm[1] = p1;
+ vsc_for_sco_pcm[2] = p2;
+ vsc_for_sco_pcm[3] = p3;
+ vsc_for_sco_pcm[4] = p4;
+}
+
+void HCILP_Enable(BOOLEAN on)
+{
+ fprintf(stderr, "Set Low Power mode %d\n", on);
+ UINT8 data[HCI_BRCM_WRITE_SLEEP_MODE_LENGTH] = {
+ 0x01, /* Sleep Mode algorithm 1 */
+ HCILP_IDLE_THRESHOLD, /* Host Idle Treshold in 300ms */
+ HCILP_HC_IDLE_THRESHOLD, /* Host Controller Idle Treshold in 300ms *//* this should be less than scan interval. */
+ HCILP_BT_WAKE_POLARITY, /* BT_WAKE Polarity - 0=Active Low, 1= Active High */
+ HCILP_HOST_WAKE_POLARITY, /* HOST_WAKE Polarity - 0=Active Low, 1= Active High */
+ 0x01, /* Allow host Sleep during SCO */
+ 0x01, /* Combine Sleep Mode and LPM - The device will not sleep in mode 0 if this flag is set to 1, */
+ 0x00, /* UART_TXD Tri-State : 0x00 = Do not tri-state UART_TXD in sleep mode */
+ 0x00, /* NA to Mode 1 */
+ 0x00, /* NA to Mode 1 */
+ };
+
+ if (on) {
+ data[0] = 0x01;
+ } else {
+ data[0] = 0x00;
+ }
+
+ SendCommand(HCI_BRCM_WRITE_SLEEP_MODE, HCI_BRCM_WRITE_SLEEP_MODE_LENGTH,
+ (UINT8 *) data);
+ read_event(fd, buffer);
+}
+
+UINT32 uart_speed(UINT32 Speed)
+{
+ switch (Speed) {
+ case 115200:
+ return B115200;
+ case 230400:
+ return B230400;
+ case 460800:
+ return B460800;
+ case 921600:
+ return B921600;
+ case 1000000:
+ return B1000000;
+ case 1500000:
+ return B1500000;
+ case 2000000:
+ return B2000000;
+ case 2500000:
+ return B2500000;
+ case 3000000:
+ return B3000000;
+ case 4000000:
+ return B4000000;
+ default:
+ return B115200;
+ }
+}
+
+void ChangeBaudRate(UINT32 baudrate)
+{
+ UINT8 hci_data[HCI_BRCM_UPDATE_BAUD_RATE_UNENCODED_LENGTH] =
+ { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
+ UINT8 uart_clock_24 = 0x2; /* 0x1 - UART Clock 48MHz, 0x2 - UART Clock 24MHz */
+ UINT8 uart_clock_48 = 0x1; /* 0x1 - UART Clock 48MHz, 0x2 - UART Clock 24MHz */
+
+ switch (baudrate) {
+ case 115200:
+ case 230400:
+ case 460800:
+ case 921600:
+ case 1000000:
+ case 1500000:
+ case 2000000:
+ case 2500000:
+ /* Write UART Clock setting of 24MHz */
+ DEBUG0("Change UART_CLOCK 24Mhz\n");
+ SendCommand(VSC_WRITE_UART_CLOCK_SETTING,
+ VSC_WRITE_UART_CLOCK_SETTING_LEN,
+ (UINT8 *) & uart_clock_24);
+ read_event(fd, buffer);
+ break;
+
+ case 3000000:
+ case 4000000:
+ /* Write UART Clock setting of 48MHz */
+ DEBUG0("Change UART_CLOCK 48Mh\nz");
+ SendCommand(VSC_WRITE_UART_CLOCK_SETTING,
+ VSC_WRITE_UART_CLOCK_SETTING_LEN,
+ (UINT8 *) & uart_clock_48);
+ read_event(fd, buffer);
+ break;
+
+ default:
+ fprintf(stderr, "Not Support baudrate = %ld\n", baudrate);
+ exit_err(1);
+ break;
+ }
+
+ hci_data[2] = baudrate & 0xFF;
+ hci_data[3] = (baudrate >> 8) & 0xFF;
+ hci_data[4] = (baudrate >> 16) & 0xFF;
+ hci_data[5] = (baudrate >> 24) & 0xFF;
+
+ DEBUG1("Change Baudrate %ld\n", baudrate);
+
+ SendCommand(HCI_BRCM_UPDATE_BAUDRATE_CMD,
+ HCI_BRCM_UPDATE_BAUD_RATE_UNENCODED_LENGTH,
+ (UINT8 *) hci_data);
+ read_event(fd, buffer);
+
+ tcflush(fd, TCIOFLUSH);
+ tcgetattr(fd, &termios);
+ cfmakeraw(&termios);
+ termios.c_cflag |= CRTSCTS;
+
+ if (use_two_stop_bits)
+ termios.c_cflag |= CSTOPB;
+
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcflush(fd, TCIOFLUSH);
+ cfsetospeed(&termios, uart_speed(baudrate));
+ cfsetispeed(&termios, uart_speed(baudrate));
+ tcsetattr(fd, TCSANOW, &termios);
+
+}
+
+void EnableTestMode(void)
+{
+ UINT8 filter_data[] = { 0x02, 0x00, 0x02 };
+
+ /* bt sleep disable */
+ HCILP_Enable(FALSE);
+
+ /* Enable both Inquiry & Page Scans */
+ SetScanEnable();
+
+ /* Set Event Filter: Enable Auto Connect */
+ SendCommand(HCI_SET_EVENT_FILTER, 0x03, (UINT8 *) filter_data);
+ read_event(fd, buffer);
+
+ /* Enable Device under test */
+ SendCommand(HCI_ENABLE_DEV_UNDER_TEST_MODE, 0x0, NULL);
+ read_event(fd, buffer);
+
+ fprintf(stderr, "Enable Device Under Test\n");
+}
+
+void SetLocalFeatures(void)
+{
+ UINT8 *data = NULL;
+
+ DEBUG0("Read Local Feature\n");
+ SendCommand(HCI_READ_LOCAL_FEATURES, 0, NULL);
+ read_event(fd, buffer);
+
+ data = &buffer[7];
+
+#if (BCM_DISABLE_RF_PWRCTRL == TRUE)
+ fprintf(stderr, "Remove Power Control\n");
+ data[2] &= 0xFB; /* Power contrel */
+#endif
+ DEBUG0("Write Local Feature\n");
+ SendCommand(VSC_HCI_CMD_SET_LOC_FEATURES_CMD, 0x08, (UINT8 *) data);
+ read_event(fd, buffer);
+}
+
+void EnbleHCI(void)
+{
+ int i = N_HCI;
+ int proto = HCI_UART_H4;
+
+ if (ioctl(fd, TIOCSETD, &i) < 0) {
+ fprintf(stderr, "Can't set line discipline\n");
+ return;
+ }
+
+ if (ioctl(fd, HCIUARTSETPROTO, proto) < 0) {
+ fprintf(stderr, "Can't set hci protocol\n");
+ return;
+ }
+ fprintf(stderr, "Done setting line discpline\n");
+ return;
+
+}
+
+void print_usage(void)
+{
+ fprintf(stderr, "\n");
+ fprintf(stderr, "BRCM BT tool for Linux release %s\n", RELEASE_DATE);
+ fprintf(stderr, "\n");
+ fprintf(stderr,
+ " Usage: bcmtool <tty Device> <command> [command parameter],....\n\n");
+ fprintf(stderr,
+ " -FILE Patchram file name EX) -FILE=BCM43xx_xxx.hcd\n");
+ fprintf(stderr,
+ " -BAUD Set Baudrate EX) -BAUD=3000000\n");
+ fprintf(stderr,
+ " -ADDR BD addr file name EX) -ADDR=.bdaddr\n");
+ fprintf(stderr, " -SCO Enable SCO/PCM config EX) -SCO\n");
+ fprintf(stderr,
+ " -SETSCO SCO/PCM values verify EX) -SETSCO=0,1,0,1,1,0,0,3,3,0\n");
+ fprintf(stderr, " -LP Enable Low power EX) -LP\n");
+ fprintf(stderr, " -FEATURE Set local Feature EX) -FEATURE\n");
+ fprintf(stderr,
+ " -DUT Enable DUT mode(do not use with -LP) EX) -DUT\n");
+ fprintf(stderr,
+ " -ATTACH Attach BT controller to BlueZ stack EX) -ATTACH\n");
+ fprintf(stderr, " -DEBUG Debug message EX) -DEBUG\n");
+ fprintf(stderr, " -CSTOPB Set two stop bits for tty EX) -CSTOPB\n");
+ fprintf(stderr, "\n");
+}
+
+int main(int argc, char *argv[])
+{
+ UINT8 i = 0;
+
+ if (argc < 2) {
+ print_usage();
+ exit(1);
+ } else {
+ fprintf(stderr, "BRCM BT tool for Linux release %s\n",
+ RELEASE_DATE);
+ }
+
+#if (DEPLOY_4335A_AXI_BRIDGE_PATCH == TRUE)
+ hw_4335_axi_bridge_lock();
+ usleep(50000);
+#endif
+
+ /* Open dev port */
+ if ((fd = open(argv[1], O_RDWR | O_NOCTTY)) == -1) {
+ fprintf(stderr, "port %s could not be opened, error %d\n",
+ argv[1], errno);
+ exit(2);
+ }
+
+ tcflush(fd, TCIOFLUSH);
+ tcgetattr(fd, &termios);
+ cfmakeraw(&termios);
+ termios.c_cflag |= CRTSCTS;
+
+ if (use_two_stop_bits)
+ termios.c_cflag |= CSTOPB;
+
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcsetattr(fd, TCSANOW, &termios);
+ tcflush(fd, TCIOFLUSH);
+ tcflush(fd, TCIOFLUSH);
+ cfsetospeed(&termios, B115200);
+ cfsetispeed(&termios, B115200);
+ tcsetattr(fd, TCSANOW, &termios);
+
+ signal(SIGALRM, expired);
+
+ for (i = 2; i < argc; i++) {
+ char *ptr = argv[i];
+
+ if (strstr(ptr, "-DEBUG")) {
+ debug_mode = TRUE;
+ DEBUG0("DEBUG On\n");
+ break;
+ }
+
+ if (strstr(ptr, "-CSTOPB")) {
+ use_two_stop_bits = TRUE;
+ DEBUG0("Use two stop bits for tty\n");
+ break;
+ }
+ }
+
+ for (i = 2; i < argc; i++) {
+ char *ptr = argv[i];
+
+ if (ptr == NULL)
+ continue;
+
+ fprintf(stderr, "[%d] %s\n", i - 1, ptr);
+
+ if (strstr(ptr, "-FILE=")) {
+ char prm_name[128];
+
+ ptr += 6;
+
+ strncpy(prm_name, ptr, 127);
+ DownloadPatchram(prm_name);
+
+ } else if (strstr(ptr, "-BAUD=")) {
+ UINT32 baudrate;
+
+ ptr += 6;
+ baudrate = atoi(ptr);
+
+ ChangeBaudRate(baudrate);
+ } else if (strstr(ptr, "-ADDR=")) {
+ char *bdaddr_filename;
+ FILE *pFile = NULL;
+
+ int bdaddr[10]; /* Displayed BD Address */
+
+ BD_ADDR local_addr; /* BD Address for write */
+
+#if 0
+ ptr += 6;
+ if (sscanf
+ (ptr, "%02X:%02X:%02X:%02X:%02X:%02X", &bdaddr[0],
+ &bdaddr[1], &bdaddr[2], &bdaddr[3], &bdaddr[4],
+ &bdaddr[5]) != 6) {
+ fprintf(stderr, "-ADDR: Parameter error");
+ exit_err(1);
+ }
+ bte_write_bdaddr(bdaddr);
+#endif
+ ptr += 6;
+ bdaddr_filename = ptr;
+
+ if (bdaddr_filename) {
+ pFile = fopen(bdaddr_filename, "r");
+ }
+
+ if (pFile) {
+ char text[BTUI_MAX_STRING_LENGTH_PER_LINE];
+
+ fgets(text, BTUI_MAX_STRING_LENGTH_PER_LINE,
+ pFile);
+ sscanf(text, "%02x%02x", &bdaddr[0],
+ &bdaddr[1]);
+
+ fgets(text, BTUI_MAX_STRING_LENGTH_PER_LINE,
+ pFile);
+ sscanf(text, "%02x", &bdaddr[2]);
+
+ fgets(text, BTUI_MAX_STRING_LENGTH_PER_LINE,
+ pFile);
+ sscanf(text, "%02x%02x%02x", &bdaddr[3],
+ &bdaddr[4], &bdaddr[5]);
+
+ fprintf(stderr,
+ "Writing B/D Address = %02X:%02X:%02X:%02X:%02X:%02X\n",
+ bdaddr[0], bdaddr[1], bdaddr[2],
+ bdaddr[3], bdaddr[4], bdaddr[5]);
+
+ ROTATE_BD_ADDR(local_addr, bdaddr);
+
+ SendCommand(VSC_WRITE_BD_ADDR, BD_ADDR_LEN,
+ (UINT8 *) local_addr);
+ read_event(fd, buffer);
+ } else {
+ fprintf(stderr, "-ADDR: file open fail\n");
+ exit_err(1);
+ }
+
+ } else if (strstr(ptr, "-SCO")) {
+ SetAudio();
+
+ } else if (strstr(ptr, "-SETSCO=")) {
+ ptr += 8;
+ int value[10];
+
+ if (sscanf
+ (ptr, "%d,%d,%d,%d,%d,%d,%d,%d,%d,%d", &value[0],
+ &value[1], &value[2], &value[3], &value[4],
+ &value[5], &value[6], &value[7], &value[8],
+ &value[9]) != 10) {
+ DEBUG0("PCM / SCO configuration value err\n");
+ DEBUG0
+ ("SCO_Routing,PCM_Interface_Rate,Frame_Type,Sync_Mode,Clock_Mode,LSB_First,Fill_bits,Fill_Method,Fill_Num,Right_Justify\n");
+ exit_err(1);
+ }
+
+ SetScoConf(value[0], value[1], value[2], value[3],
+ value[4]);
+ SetPcmConf(value[5], value[6], value[7], value[8],
+ value[9]);
+ SetAudio();
+ } else if (strstr(ptr, "-LP")) {
+ HCILP_Enable(TRUE);
+ } else if (strstr(ptr, "-DUT")) {
+ EnableTestMode();
+ } else if (strstr(ptr, "-FEATURE")) {
+ SetLocalFeatures();
+ } else if (strstr(ptr, "-ATTACH")) {
+ EnbleHCI();
+ while (1) {
+ sleep(UINT_MAX);
+ }
+ } else if (strstr(ptr, "-DEBUG")) {
+ } else if (strstr(ptr, "-CSTOPB")) {
+
+ } else {
+ fprintf(stderr, "Invalid parameter(s)!\n");
+ exit_err(1);
+ }
+ }
+
+ fprintf(stderr, "EXIT\n");
+ close(fd);
+ exit(0);
+
+ return 0;
+}