BTstack for Nucleo F401RE/FRDM-KL46Z example program

Dependencies:   F401RE-USBHost mbed

The usage is the same as KL46Z-BTstack_example.
使い方はKL46Z-BTstack_exampleと同じです。
/media/uploads/va009039/f401re-btstack.jpg

Committer:
va009039
Date:
Mon Jun 09 09:03:25 2014 +0000
Revision:
0:a05a07cd6fdf
first commit

Who changed what in which revision?

UserRevisionLine numberNew contents of line
va009039 0:a05a07cd6fdf 1 /*
va009039 0:a05a07cd6fdf 2 * Copyright (C) 2009-2012 by Matthias Ringwald
va009039 0:a05a07cd6fdf 3 *
va009039 0:a05a07cd6fdf 4 * Redistribution and use in source and binary forms, with or without
va009039 0:a05a07cd6fdf 5 * modification, are permitted provided that the following conditions
va009039 0:a05a07cd6fdf 6 * are met:
va009039 0:a05a07cd6fdf 7 *
va009039 0:a05a07cd6fdf 8 * 1. Redistributions of source code must retain the above copyright
va009039 0:a05a07cd6fdf 9 * notice, this list of conditions and the following disclaimer.
va009039 0:a05a07cd6fdf 10 * 2. Redistributions in binary form must reproduce the above copyright
va009039 0:a05a07cd6fdf 11 * notice, this list of conditions and the following disclaimer in the
va009039 0:a05a07cd6fdf 12 * documentation and/or other materials provided with the distribution.
va009039 0:a05a07cd6fdf 13 * 3. Neither the name of the copyright holders nor the names of
va009039 0:a05a07cd6fdf 14 * contributors may be used to endorse or promote products derived
va009039 0:a05a07cd6fdf 15 * from this software without specific prior written permission.
va009039 0:a05a07cd6fdf 16 * 4. Any redistribution, use, or modification is done solely for
va009039 0:a05a07cd6fdf 17 * personal benefit and not for any commercial purpose or for
va009039 0:a05a07cd6fdf 18 * monetary gain.
va009039 0:a05a07cd6fdf 19 *
va009039 0:a05a07cd6fdf 20 * THIS SOFTWARE IS PROVIDED BY MATTHIAS RINGWALD AND CONTRIBUTORS
va009039 0:a05a07cd6fdf 21 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
va009039 0:a05a07cd6fdf 22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
va009039 0:a05a07cd6fdf 23 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
va009039 0:a05a07cd6fdf 24 * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
va009039 0:a05a07cd6fdf 25 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
va009039 0:a05a07cd6fdf 26 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
va009039 0:a05a07cd6fdf 27 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
va009039 0:a05a07cd6fdf 28 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
va009039 0:a05a07cd6fdf 29 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
va009039 0:a05a07cd6fdf 30 * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
va009039 0:a05a07cd6fdf 31 * SUCH DAMAGE.
va009039 0:a05a07cd6fdf 32 *
va009039 0:a05a07cd6fdf 33 * Please inquire about commercial licensing options at btstack@ringwald.ch
va009039 0:a05a07cd6fdf 34 *
va009039 0:a05a07cd6fdf 35 */
va009039 0:a05a07cd6fdf 36
va009039 0:a05a07cd6fdf 37 /*
va009039 0:a05a07cd6fdf 38 * bt_control.h
va009039 0:a05a07cd6fdf 39 *
va009039 0:a05a07cd6fdf 40 * BT Control API -- allows BT Daemon to initialize and control differnt hardware
va009039 0:a05a07cd6fdf 41 *
va009039 0:a05a07cd6fdf 42 * Created by Matthias Ringwald on 5/19/09.
va009039 0:a05a07cd6fdf 43 *
va009039 0:a05a07cd6fdf 44 */
va009039 0:a05a07cd6fdf 45
va009039 0:a05a07cd6fdf 46 #pragma once
va009039 0:a05a07cd6fdf 47
va009039 0:a05a07cd6fdf 48 #include <stdint.h>
va009039 0:a05a07cd6fdf 49
va009039 0:a05a07cd6fdf 50 typedef enum {
va009039 0:a05a07cd6fdf 51 POWER_WILL_SLEEP = 1,
va009039 0:a05a07cd6fdf 52 POWER_WILL_WAKE_UP
va009039 0:a05a07cd6fdf 53 } POWER_NOTIFICATION_t;
va009039 0:a05a07cd6fdf 54
va009039 0:a05a07cd6fdf 55 typedef struct {
va009039 0:a05a07cd6fdf 56 int (*on) (void *config); // <-- turn BT module on and configure
va009039 0:a05a07cd6fdf 57 int (*off) (void *config); // <-- turn BT module off
va009039 0:a05a07cd6fdf 58 int (*sleep)(void *config); // <-- put BT module to sleep - only to be called after ON
va009039 0:a05a07cd6fdf 59 int (*wake) (void *config); // <-- wake BT module from sleep - only to be called after SLEEP
va009039 0:a05a07cd6fdf 60 int (*valid)(void *config); // <-- test if hardware can be supported
va009039 0:a05a07cd6fdf 61 const char * (*name) (void *config); // <-- return hardware name
va009039 0:a05a07cd6fdf 62
va009039 0:a05a07cd6fdf 63 /** support for UART baud rate changes - cmd has to be stored in hci_cmd_buffer
va009039 0:a05a07cd6fdf 64 * @return have command
va009039 0:a05a07cd6fdf 65 */
va009039 0:a05a07cd6fdf 66 int (*baudrate_cmd)(void * config, uint32_t baudrate, uint8_t *hci_cmd_buffer);
va009039 0:a05a07cd6fdf 67
va009039 0:a05a07cd6fdf 68 /** support custom init sequences after RESET command - cmd has to be stored in hci_cmd_buffer
va009039 0:a05a07cd6fdf 69 * @return have command
va009039 0:a05a07cd6fdf 70 */
va009039 0:a05a07cd6fdf 71 int (*next_cmd)(void *config, uint8_t * hci_cmd_buffer);
va009039 0:a05a07cd6fdf 72
va009039 0:a05a07cd6fdf 73 void (*register_for_power_notifications)(void (*cb)(POWER_NOTIFICATION_t event));
va009039 0:a05a07cd6fdf 74
va009039 0:a05a07cd6fdf 75 void (*hw_error)(void);
va009039 0:a05a07cd6fdf 76 } bt_control_t;