OSDN Git Service
Johan Hedberg [Sun, 19 Dec 2010 14:50:27 +0000 (16:50 +0200)]
Get rid of unneeded btd_adapter_get_conn_handle function
Johan Hedberg [Sun, 19 Dec 2010 14:34:44 +0000 (16:34 +0200)]
Fix handle endianess issues with btd_adapter_read_clock
Johan Hedberg [Sun, 19 Dec 2010 14:17:15 +0000 (16:17 +0200)]
Clean up btd_request_authorization code
Johan Hedberg [Sun, 19 Dec 2010 13:30:29 +0000 (15:30 +0200)]
Remove unnecessary btd_adapter_get_remote_version function
Johan Hedberg [Sun, 19 Dec 2010 13:16:29 +0000 (15:16 +0200)]
Rename btd_event_inquiry_result to btd_event_device_found
Johan Hedberg [Sun, 19 Dec 2010 13:04:32 +0000 (15:04 +0200)]
Move PIN code storage access to core daemon
Johan Hedberg [Sun, 19 Dec 2010 12:40:54 +0000 (14:40 +0200)]
Move storage dependencies from hciops to core daemon
Anderson Lizardo [Fri, 17 Dec 2010 14:57:24 +0000 (10:57 -0400)]
Move local name parsing to parse_eir_data()
Anderson Lizardo [Fri, 17 Dec 2010 14:57:23 +0000 (10:57 -0400)]
Move AD flags parsing to parse_eir_data()
Anderson Lizardo [Fri, 17 Dec 2010 14:57:22 +0000 (10:57 -0400)]
Modify get_eir_uuids() to parse other EIR data
Currently, EIR parsing (name, UUIDs, flags etc.) is done in various
places. This leads to duplicated checks and does not support parsing
multiple AD/EIR structures on a single transfer.
These changes modify get_eir_uuids() to parse other EIR data types and
avoid passing raw EIR data to higher layers.
To accomplish this, get_eir_uuids() was renamed to parse_eir_data(), and
a new (internal) "struct eir_data" was introduced to store the parsed
data.
This first commit only handles the services UUIDs, following patches
will move other EIR parsing to it until everything is done inside
parse_eir_data().
Anderson Lizardo [Sun, 19 Dec 2010 12:23:26 +0000 (14:23 +0200)]
Move get_eir_uuids() from src/adapter.c to src/event.c
Moving get_eir_uuids() to src/event.c removes the need to pass the raw
EIR data to higher layers. Now it is not necessary to pass the original
GSList of service UUIDs, because the list is concatenated (with
verification of duplicate entries) on adapter_update_device_from_info()
(for LE) and adapter_update_found_devices() (for BR/EDR).
Brian Gix [Fri, 17 Dec 2010 19:08:53 +0000 (11:08 -0800)]
Add enc_read_blob_req() as defined in BT Core Spec v4.0
Johan Hedberg [Sun, 19 Dec 2010 11:51:28 +0000 (13:51 +0200)]
Remove unused btd_adapter_get_remote_name function
Johan Hedberg [Sun, 19 Dec 2010 11:46:16 +0000 (13:46 +0200)]
Remove unnecessary empty line
Johan Hedberg [Sun, 19 Dec 2010 11:43:49 +0000 (13:43 +0200)]
Remove non-existent adapter_is_ready prototype
Johan Hedberg [Sun, 19 Dec 2010 11:42:47 +0000 (13:42 +0200)]
Remove non-existent btd_adapter_get_init_mode prototype
Johan Hedberg [Sun, 19 Dec 2010 11:40:27 +0000 (13:40 +0200)]
Remove non-existent adapter_set_service_classes prototype
Johan Hedberg [Sun, 19 Dec 2010 11:39:10 +0000 (13:39 +0200)]
Get rid of unused btd_manager_set_offline function
Johan Hedberg [Sun, 19 Dec 2010 11:35:58 +0000 (13:35 +0200)]
Get rid of non-existend manager_update_svc prototype
Johan Hedberg [Sun, 19 Dec 2010 11:35:13 +0000 (13:35 +0200)]
Get rid of unnecessary manager_get_default_adapter function
Johan Hedberg [Sun, 19 Dec 2010 11:33:18 +0000 (13:33 +0200)]
Get rid of unnecessary manager_find_adapter_by_path function
Johan Hedberg [Sun, 19 Dec 2010 11:32:04 +0000 (13:32 +0200)]
Get rid of unnecessary manager_find_adapter_by_address function
Johan Hedberg [Sun, 19 Dec 2010 11:25:51 +0000 (13:25 +0200)]
Add manager_foreach_adapter()
Ultimately manager_get_adapters shouldn't be needed at all. By
introducing manager_foreach_adapter most instances can be removed.
Johan Hedberg [Sun, 19 Dec 2010 08:40:43 +0000 (10:40 +0200)]
Fix memory leak in adapter_service_ins_rem()
Since the adapters list is artificially created for specific adapters
(bdaddr != BDADDR_ANY) the list needs freeing at the end of the
function. However, there's no need to artificially create the list at
all if the address comparison is done within the for-loop. Since
manager_find_adapter needs to iterate through the adapters anyway while
comparing the address there really isn't a significant penalty in doing
this in the loop in adapter_service_ins_rem.
Based on the original report and initial patch from
Anderson Lizardo <anderson.lizardo@openbossa.org>.
Johan Hedberg [Sun, 19 Dec 2010 00:01:55 +0000 (02:01 +0200)]
Fix clearing authentication request for renewed keys
In the case of upgrading an unauthenticated key to an authenticated one
there will be a second authentication request which needs to be cleared
upon the link key notification event.
Johan Hedberg [Sat, 18 Dec 2010 11:52:02 +0000 (13:52 +0200)]
Fix setting paired state when device->authr is false
Some buggy controllers might generate a link key notification even after
a disconnect has been requested. To make sure that device->paired is in
sync with the real paired state set the value independent of
device->authr when a link key notification happens. Below is a snippet
of such buggy (or at least strange) behavior from a controller:
< HCI Command: Disconnect (0x01|0x0006) plen 3
handle 6 reason 0x13
Reason: Remote User Terminated Connection
> HCI Event: Link Key Notification (0x18) plen 23
bdaddr 00:26:CC:77:xx:xx key
33E6F2B75FC870AA794BB6249EBD6AC6 type 0
Type: Combination Key
> HCI Event: Auth Complete (0x06) plen 3
status 0x00 handle 6
> HCI Event: Command Status (0x0f) plen 4
Disconnect (0x01|0x0006) status 0x00 ncmd 1
< HCI Command: Disconnect (0x01|0x0006) plen 3
handle 6 reason 0x13
Reason: Remote User Terminated Connection
> HCI Event: Command Status (0x0f) plen 4
Disconnect (0x01|0x0006) status 0x00 ncmd 1
> HCI Event: Disconn Complete (0x05) plen 4
status 0x00 handle 6 reason 0x16
Reason: Connection Terminated by Local Host
Johan Hedberg [Sat, 18 Dec 2010 11:51:48 +0000 (13:51 +0200)]
Remove unnecessary empty line
Johan Hedberg [Sat, 18 Dec 2010 11:50:10 +0000 (13:50 +0200)]
Implement storing of link keys in runtime memory
The management interface will enable storing link keys in runtime memory
in the kernel. This patch makes the adapter interface match this model
and adds storing of link keys into hciops.
Johan Hedberg [Sat, 18 Dec 2010 02:38:16 +0000 (04:38 +0200)]
Add missing mgmtops callbacks
Johan Hedberg [Sat, 18 Dec 2010 02:31:55 +0000 (04:31 +0200)]
Switch to using power_on & power_off adapter_ops callbacks
These map better to the new management interface.
Johan Hedberg [Sat, 18 Dec 2010 01:49:14 +0000 (03:49 +0200)]
Remove hciops device info struct member defines
The struct is growing quite large and having a define for every member
is not really clean.
Johan Hedberg [Sat, 18 Dec 2010 00:32:45 +0000 (02:32 +0200)]
Remove unnecessary read_local_ext_features callback
Johan Hedberg [Fri, 17 Dec 2010 12:07:19 +0000 (14:07 +0200)]
Refactor adapter initialization and power control
This (rather big) patch refactors the way that adapters are initialized
and powered on/off. The purpose is to align the adapter_ops <-> core
daemon interface with how the management interface will behave.
Marcel Holtmann [Sat, 18 Dec 2010 19:34:45 +0000 (20:34 +0100)]
Release 4.82
Luiz Augusto von Dentz [Fri, 17 Dec 2010 13:31:26 +0000 (15:31 +0200)]
Fix crash when mmaping files which size is multiple of page size
In this case the buffer returned by mmap is not NULL terminated so
functions like strpbrk that expect a string goes out of bounds.
To fix this strpbrk_len was introduced which takes the size of the buffer
making sure it never goes out of bounds.
Dmitriy Paliy [Wed, 15 Dec 2010 09:48:53 +0000 (11:48 +0200)]
Add AVDTP SRC stream send buffer size verification
Functions get_send_buffer_size and set_send_buffer_size are added to
avdpt.c.
get_send_buffer_size returns size of send buffer for a given socket
on success or error code on failure. set_send_buffer_size sets size
of send buffer for a given socket, and returns 0 on success or error
code on failure.
Size of send buffer for L2CAP socket for SRC AVDTP stream is verified
during establishment of a new transport channel. If the size is less
than twice of outgoing L2CAP MTU, then it is considered as being
insufficient to handle streaming data reliably.
In this case buffer size is increased to be twice of MTU size. Such
fixes some IOP problems with car-kits that use large MTU for music
playback.
Gustavo F. Padovan [Thu, 16 Dec 2010 17:58:09 +0000 (15:58 -0200)]
Convert more D-Bus errors to btd_error_*
Gustavo F. Padovan [Thu, 16 Dec 2010 17:58:08 +0000 (15:58 -0200)]
Add btd_error_not_ready()
Gustavo F. Padovan [Thu, 16 Dec 2010 17:58:07 +0000 (15:58 -0200)]
Add btd_error_agent_not_available()
Johan Hedberg [Thu, 16 Dec 2010 17:48:48 +0000 (19:48 +0200)]
Fix overriding global link_policy due to a single adapter
The global link policy should remain unchanged even if an adapter
doesn't happen to support some features. These features should only be
disabled for that specific adapter.
Luiz Augusto von Dentz [Thu, 16 Dec 2010 14:13:21 +0000 (16:13 +0200)]
Fix sending duplicate speaker/microphone gains to the headset
Current code only prevent duplicate D-Bus signals, so in case headset
changes the volume a client may set the same volume level again which
would be send as new volume level.
To fix this headset_set_gain now return -EALREADY if nothing has changed
so code using it can just ignore the change instead of sending to remote
device.
Luiz Augusto von Dentz [Thu, 16 Dec 2010 14:13:20 +0000 (16:13 +0200)]
Fix not calling SetConfiguration on hfp/hsp endpoints before connected
This cause some clients like PulseAudio to fail to find a proper
transport since connected state is send before transport configuration
is set.
To fix this now SetConfiguration is called early on when headset is still
in connecting phase, this matches sink/source where SetConfiguration is
also called before connected.
Gustavo F. Padovan [Wed, 15 Dec 2010 22:07:01 +0000 (20:07 -0200)]
Remove error_common_reply()
Remove old dbus error report function. This patch doesn't make things
really really better, but is a start.
Claudio Takahasi [Wed, 15 Dec 2010 20:00:09 +0000 (17:00 -0300)]
Fix memory leak of gattrib commands queue
Claudio Takahasi [Wed, 15 Dec 2010 19:54:08 +0000 (16:54 -0300)]
Implement cancel primary discovery session
Extend bt_cancel_discovery function to cancel an ongoing Discover
All Primary Services procedure.
Johan Hedberg [Wed, 15 Dec 2010 22:41:41 +0000 (00:41 +0200)]
Implement support for management powered event
Johan Hedberg [Wed, 15 Dec 2010 22:41:10 +0000 (00:41 +0200)]
Rename set_powered callbacks accordingly
Johan Hedberg [Wed, 15 Dec 2010 17:51:11 +0000 (19:51 +0200)]
Fix invalid g_io_channel_unref call in hf_io_cb
Johan Hedberg [Tue, 14 Dec 2010 13:43:41 +0000 (15:43 +0200)]
Fix signess of err variable passed to strerror
Johan Hedberg [Tue, 14 Dec 2010 08:52:18 +0000 (10:52 +0200)]
Fix add_record_to_server to return a proper error value
Johan Hedberg [Tue, 14 Dec 2010 08:52:04 +0000 (10:52 +0200)]
Fix start_discovery error return value
Johan Hedberg [Tue, 14 Dec 2010 08:51:41 +0000 (10:51 +0200)]
Use correct signess for err variable
Johan Hedberg [Tue, 14 Dec 2010 08:51:03 +0000 (10:51 +0200)]
Fix input disconnect function error return value
Johan Hedberg [Tue, 14 Dec 2010 08:50:34 +0000 (10:50 +0200)]
Fix avctp_send_passthrough to return a proper error value
Gustavo F. Padovan [Mon, 13 Dec 2010 21:33:07 +0000 (19:33 -0200)]
src: use btd_error_failed()
Gustavo F. Padovan [Mon, 13 Dec 2010 21:33:06 +0000 (19:33 -0200)]
serial: use btd_error_failed()
Gustavo F. Padovan [Mon, 13 Dec 2010 21:33:05 +0000 (19:33 -0200)]
audio: use btd_error_failed()
Gustavo F. Padovan [Mon, 13 Dec 2010 21:33:04 +0000 (19:33 -0200)]
input: use btd_error_failed()
Gustavo F. Padovan [Mon, 13 Dec 2010 21:33:03 +0000 (19:33 -0200)]
network: use btd_error_failed()
Gustavo F. Padovan [Mon, 13 Dec 2010 21:33:02 +0000 (19:33 -0200)]
attrib: use btd_error_failed()
Gustavo F. Padovan [Mon, 13 Dec 2010 21:33:01 +0000 (19:33 -0200)]
plugins: use btd_error_failed()
Gustavo F. Padovan [Mon, 13 Dec 2010 21:33:00 +0000 (19:33 -0200)]
Add btd_error_failed()
This is a special error type. It has a more general meaning and allows you
to add a string to the error.
Gustavo F. Padovan [Mon, 13 Dec 2010 21:32:59 +0000 (19:32 -0200)]
src: use btd_error_invalid_args()
Gustavo F. Padovan [Mon, 13 Dec 2010 21:32:58 +0000 (19:32 -0200)]
Add btd_error_no_such_adapter()
Johan Hedberg [Mon, 13 Dec 2010 19:35:24 +0000 (21:35 +0200)]
Update mgmt-api.txt to match current implementation of read_info
Pawel Wieczorkiewicz [Mon, 13 Dec 2010 14:19:14 +0000 (15:19 +0100)]
Setting default Link Policy according to the chip supported features
By default all features are enabled (RSWITCH, HOLD, PARK, SNIFF).
When "read local supported features" complete event occurs, not supported
features are disabled and then "Write default link policy" command with
supported features is sent.
On behalf of ST-Ericsson SA
Johan Hedberg [Mon, 13 Dec 2010 12:08:02 +0000 (14:08 +0200)]
Fix potential memory leak of ag.number
Johan Hedberg [Mon, 13 Dec 2010 10:30:25 +0000 (12:30 +0200)]
Rename hciops_set_class to write_class
Since hciops_set_class isn't (anymore) part of the exported adapter_ops
callbacks it's better to change it's name to avoid confusion.
Johan Hedberg [Mon, 13 Dec 2010 09:12:03 +0000 (11:12 +0200)]
Refactor class of device (and related values) handling to adapter_ops
The management interface will move class of device and extended inquiry
response handling to the kernel side so the same functionality needs to
be moved into hciops. These features are quite tightly coupled in
bluetoothd so splitting this into multiple patches would have been hard
(if not impossible). Thus this quite large single commit.
Johan Hedberg [Sun, 12 Dec 2010 21:03:59 +0000 (23:03 +0200)]
Fix cleaning up HFP state after calling telephony_exit
HFP state variables in telephony.h need to be reset when telephony_exit
is called. This is even more important now that telephony_init/exit get
called simply by toggling the adapter powered state.
Johan Hedberg [Sun, 12 Dec 2010 21:02:32 +0000 (23:02 +0200)]
Don't strdup the chld string for HFP
The chld string is of type const char * and is referring to a fixed
string in the telephony driver. I.e. there's no need to strdup it.
Johan Hedberg [Sat, 11 Dec 2010 22:00:19 +0000 (00:00 +0200)]
Remove unused adapter_ops->read_link_policy function
There is no code to react to the command complete of this HCI command so
there's really no value in issuing it to begin with.
Johan Hedberg [Sat, 11 Dec 2010 21:57:55 +0000 (23:57 +0200)]
Merge read_mode management command into read_info
The read_mode and read_info commands are issued only once in the
beginning for each adapter so it doesn't make sense to have the
information fetching split across two different commands. Instead all
necessary info can be fetched through the read_info command.
Johan Hedberg [Fri, 10 Dec 2010 12:04:41 +0000 (14:04 +0200)]
Fix device removal when connecting/browsing fails
Johan Hedberg [Fri, 10 Dec 2010 11:52:31 +0000 (13:52 +0200)]
Fix device creation error response when powered off
When the adapter is powered off the Create*Device methods should fail
early instead of attempting to create a connection in vain.
Johan Hedberg [Fri, 10 Dec 2010 09:25:00 +0000 (11:25 +0200)]
Fix adapter->services leak in adapter_free()
Claudio Takahasi [Thu, 9 Dec 2010 19:42:14 +0000 (16:42 -0300)]
Convert CreateDevice on test-device script to an asynchronous call
Change required to test the scenario when the sender of a CreateDevice
request disconnects from the system bus. Current implementation is
blocking and it doesn't allow the user to cancel a request.
Johan Hedberg [Thu, 9 Dec 2010 19:52:54 +0000 (21:52 +0200)]
gdbus: fix accessing freed callback data
cb->disc_func or cb->conn_func could remove the callback so this needs
to be checked for before continuing processing.
Bruna Moreira [Thu, 9 Dec 2010 13:09:13 +0000 (09:09 -0400)]
Check the security level on a per request base
Check security level on attribute server on each request, and update the
"encrypted" flag.
Johan Hedberg [Thu, 9 Dec 2010 13:09:39 +0000 (15:09 +0200)]
Fix HFP response and hold (AT+BTRH) command response
Since no telephony driver supports this command at the moment the
correct behavior is to always return an error. Therefore, a new
"not supported" value is needed for the respective state variable.
Gustavo F. Padovan [Wed, 8 Dec 2010 20:26:01 +0000 (18:26 -0200)]
Add btd_error_already_connected()
Gustavo F. Padovan [Wed, 8 Dec 2010 20:26:00 +0000 (18:26 -0200)]
convert error to btd_error_not_supported()
Gustavo F. Padovan [Wed, 8 Dec 2010 20:25:59 +0000 (18:25 -0200)]
convert error to btd_error_not_connected()
Gustavo F. Padovan [Wed, 8 Dec 2010 20:25:58 +0000 (18:25 -0200)]
convert error to btd_error_busy()
Gustavo F. Padovan [Wed, 8 Dec 2010 20:25:57 +0000 (18:25 -0200)]
convert errors to btd_error_does_not_exist()
Gustavo F. Padovan [Wed, 8 Dec 2010 20:25:56 +0000 (18:25 -0200)]
convert errors to btd_error_not_authorized()
Gustavo F. Padovan [Wed, 8 Dec 2010 20:25:55 +0000 (18:25 -0200)]
Fix coding styling issues in src/error.c
Lucas De Marchi [Sat, 27 Nov 2010 19:39:01 +0000 (17:39 -0200)]
gdbus: explicitly compare pointers to NULL
This patch was generated by the following semantic patch
(http://coccinelle.lip6.fr/)
// <smpl>
@fix disable is_null,isnt_null1@
expression *E;
@@
- !E
+ E == NULL
// </smpl>
Johan Hedberg [Wed, 8 Dec 2010 08:28:55 +0000 (10:28 +0200)]
Fix bt_extract_eir_name to use GLib memory allocation
The string returned by bt_extract_eir_name is freed using g_free so
GLib's own allocators should be used instead of libc ones.
Gustavo F. Padovan [Wed, 8 Dec 2010 01:02:06 +0000 (23:02 -0200)]
Revert use of new error function for Blocked
The error message says a lot about what the user need to do, I'm reverting
this change and will fix in the next patch series about the DBus error
handling.
Claudio Takahasi [Tue, 7 Dec 2010 22:20:37 +0000 (19:20 -0300)]
Remove fixed item from TODO
Read by UUID is already supported by attribute server and gatttool.
Johan Hedberg [Tue, 7 Dec 2010 22:03:34 +0000 (00:03 +0200)]
Make device type evaluation more readable
Claudio Takahasi [Fri, 3 Dec 2010 14:28:52 +0000 (11:28 -0300)]
Make bt_name2class static on glib-helper
Claudio Takahasi [Fri, 3 Dec 2010 14:28:51 +0000 (11:28 -0300)]
glib-helper: fix coding style issues
Claudio Takahasi [Tue, 7 Dec 2010 21:33:15 +0000 (18:33 -0300)]
Make EIR type an optional argument for bt_extract_eir_name
Claudio Takahasi [Tue, 7 Dec 2010 21:31:53 +0000 (18:31 -0300)]
Check if the remote LE is connectable when creating a device
Before issue Discover All Primary Service the advertising event type
needs to be evaluated to avoid connection attempts to non-connectable
devices. For non-connectable devices, CreateDevice creates the device
instance however no Services/UUIDs will be exposed.
Claudio Takahasi [Tue, 7 Dec 2010 21:30:40 +0000 (18:30 -0300)]
Add device type to identify LE, BR/EDR or dual mode devices
If EIR Flags field is sent in the advertising data, it can be used
to detect the operation mode. If the remote device is dual mode,
GAP operation mode defines that it shall follow the connectable
mode for BR/EDR and non-connectable mode for LE. This patch forces
service discovery protocol prior to Discover All Primary Services.
Claudio Takahasi [Tue, 7 Dec 2010 21:41:38 +0000 (18:41 -0300)]
Remove automatic battery state change on attribute example
Legacy code implemented to test Indication and Notification
Gustavo F. Padovan [Mon, 6 Dec 2010 19:10:48 +0000 (17:10 -0200)]
Add btd_error_not_authorized()
Gustavo F. Padovan [Mon, 6 Dec 2010 19:10:47 +0000 (17:10 -0200)]
Add btd_error_does_not_exist()