Re: [PATCH v3 05/10] profiles/network: Remove unneded bnep_uuid function from bnep code

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Szymon,

On 12 March 2015 at 11:02, Szymon Janc <szymon.janc@xxxxxxxxx> wrote:
> Hi Grzegorz,
>
> On Monday 09 of March 2015 17:24:50 Grzegorz Kolodziejczyk wrote:
>> This function is no longer needed since connection and server can handle
>> this funcionality by itself.
>> ---
>>  profiles/network/bnep.c       | 10 ----------
>>  profiles/network/bnep.h       |  1 -
>>  profiles/network/connection.c | 19 ++++++++++++-------
>>  profiles/network/server.c     | 24 +++++++++++++++++++++---
>>  4 files changed, 33 insertions(+), 21 deletions(-)
>>
>> diff --git a/profiles/network/bnep.c b/profiles/network/bnep.c
>> index 3fe63f0..a81a260 100644
>> --- a/profiles/network/bnep.c
>> +++ b/profiles/network/bnep.c
>> @@ -85,16 +85,6 @@ struct bnep {
>>       void    *disconn_data;
>>  };
>>
>> -const char *bnep_uuid(uint16_t id)
>> -{
>> -     int i;
>> -
>> -     for (i = 0; __svc[i].uuid128; i++)
>> -             if (__svc[i].id == id)
>> -                     return __svc[i].uuid128;
>> -     return NULL;
>> -}
>> -
>>  const char *bnep_name(uint16_t id)
>>  {
>>       int i;
>> diff --git a/profiles/network/bnep.h b/profiles/network/bnep.h
>> index 31579f9..811ea14 100644
>> --- a/profiles/network/bnep.h
>> +++ b/profiles/network/bnep.h
>> @@ -26,7 +26,6 @@ struct bnep;
>>  int bnep_init(void);
>>  int bnep_cleanup(void);
>>
>> -const char *bnep_uuid(uint16_t id);
>>  const char *bnep_name(uint16_t id);
>>
>>  struct bnep *bnep_new(int sk, uint16_t local_role, uint16_t remote_role,
>> diff --git a/profiles/network/connection.c b/profiles/network/connection.c
>> index 4311cc9..da8b86e 100644
>> --- a/profiles/network/connection.c
>> +++ b/profiles/network/connection.c
>> @@ -284,21 +284,23 @@ static DBusMessage *local_connect(DBusConnection *conn,
>>       struct btd_service *service;
>>       struct network_conn *nc;
>>       const char *svc;
>> -     const char *uuid;
>>       uint16_t id;
>>       int err;
>> +     char uuid_str[MAX_LEN_UUID_STR];
>> +     bt_uuid_t uuid;
>>
>>       if (dbus_message_get_args(msg, NULL, DBUS_TYPE_STRING, &svc,
>>                                               DBUS_TYPE_INVALID) == FALSE)
>>               return btd_error_invalid_args(msg);
>>
>>       id = get_pan_srv_id(svc);
>> -     uuid = bnep_uuid(id);
>> +     bt_uuid16_create(&uuid, id);
>> +     bt_uuid_to_uuid128(&uuid, &uuid);
>>
>> -     if (uuid == NULL)
>> +     if (bt_uuid_to_string(&uuid, uuid_str, MAX_LEN_UUID_STR) < 0)
>>               return btd_error_invalid_args(msg);
>>
>> -     service = btd_device_get_service(peer->device, uuid);
>> +     service = btd_device_get_service(peer->device, uuid_str);
>>       if (service == NULL)
>>               return btd_error_not_supported(msg);
>>
>> @@ -439,15 +441,18 @@ static gboolean network_property_get_uuid(const GDBusPropertyTable *property,
>>  {
>>       struct network_peer *peer = data;
>>       struct network_conn *nc;
>> -     const char *uuid;
>> +     char uuid_str[MAX_LEN_UUID_STR];
>> +     bt_uuid_t uuid;
>>
>>       nc = find_connection_by_state(peer->connections, CONNECTED);
>>       if (nc == NULL)
>>               return FALSE;
>>
>> -     uuid = bnep_uuid(nc->id);
>> +     bt_uuid16_create(&uuid, nc->id);
>> +     bt_uuid_to_uuid128(&uuid, &uuid);
>> +     bt_uuid_to_string(&uuid, uuid_str, MAX_LEN_UUID_STR);
>>
>> -     dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING, &uuid);
>> +     dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING, &uuid_str);
>>
>>       return TRUE;
>>  }
>> diff --git a/profiles/network/server.c b/profiles/network/server.c
>> index 9caabb0..e05bc1a 100644
>> --- a/profiles/network/server.c
>> +++ b/profiles/network/server.c
>> @@ -114,14 +114,32 @@ static struct network_server *find_server(GSList *list, uint16_t id)
>>  static struct network_server *find_server_by_uuid(GSList *list,
>>                                                       const char *uuid)
>>  {
>> +     bt_uuid_t srv_uuid, bnep_uuid;
>> +
>>       for (; list; list = list->next) {
>>               struct network_server *ns = list->data;
>> +             bt_uuid16_create(&bnep_uuid, ns->id);
>>
>> -             if (strcasecmp(uuid, bnep_uuid(ns->id)) == 0)
>> +             /* UUID value compare */
>> +             if (!bt_string_to_uuid(&srv_uuid, uuid) &&
>> +                                     !bt_uuid_cmp(&srv_uuid, &bnep_uuid))
>>                       return ns;
>
> Please call bt_string_to_uuid() before loop and based on its result
> check if uuid or name compare is needed.
>
> This should make code a bit faster and easier to read.
>
Ok, I agree. I'll reorganize this.
>>
>> -             if (strcasecmp(uuid, bnep_name(ns->id)) == 0)
>> -                     return ns;
>> +             /* String value compare */
>> +             switch (ns->id) {
>> +             case BNEP_SVC_PANU:
>> +                     if (!strcasecmp(uuid, "panu"))
>> +                             return ns;
>> +                     break;
>> +             case BNEP_SVC_NAP:
>> +                     if (!strcasecmp(uuid, "nap"))
>> +                             return ns;
>> +                     break;
>> +             case BNEP_SVC_GN:
>> +                     if (!strcasecmp(uuid, "gn"))
>> +                             return ns;
>> +                     break;
>> +             }
>>       }
>>
>>       return NULL;
>>
>
> --
> Best regards,
> Szymon Janc
Best regards,
Grzegorz Kolodziejczyk
--
To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux