Hi Alfonso, On Mon, Oct 06, 2014, Alfonso Acosta wrote: > @@ -4322,7 +4323,7 @@ static void check_pending_le_conn(struct hci_dev *hdev, bdaddr_t *addr, > * count consistent once the connection is established. > */ > params->conn = hci_conn_get(conn); > - return; > + return conn; > } > > switch (PTR_ERR(conn)) { > @@ -4335,7 +4336,10 @@ static void check_pending_le_conn(struct hci_dev *hdev, bdaddr_t *addr, > break; > default: > BT_DBG("Failed to connect: err %ld", PTR_ERR(conn)); > + return NULL; > } > + > + return conn; > } I just realized that in this last part of check_pending_le_conn() IS_ERR(conn) will true (since the first part that I quoted handles the !IS_ERR(conn) condition) so you should really be explicitly returning NULL here instead of the conn pointer. This is particularly important since you're only checking for non-NULL in the calling code instead of doing IS_ERR() there. > - if (conn->dev_class && memcmp(conn->dev_class, "\0\0\0", 3) != 0) > - eir_len = eir_append_data(ev->eir, eir_len, > - EIR_CLASS_OF_DEV, conn->dev_class, 3); > + if (conn->dev_class && > + memcmp(conn->dev_class, "\0\0\0", 3) != 0) > + eir_len = eir_append_data(ev->eir, eir_len, > + EIR_CLASS_OF_DEV, > + conn->dev_class, 3); > + } I know this is not your fault but a redundancy in the existing code, but the check for if (conn->dev_class) is pointless since the variable is defined as an array, i.e. it will always be non-NULL. To make this fix clear it's probably better to have it as a separate patch either before or after your current two patches. To make it easier to get the right versions of these applied could you please send the entire set again instead of just this one patch. Thanks. Johan -- 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