From owner-freebsd-bluetooth@FreeBSD.ORG Thu May 14 16:26:19 2009 Return-Path: Delivered-To: freebsd-bluetooth@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id C71D01065673 for ; Thu, 14 May 2009 16:26:19 +0000 (UTC) (envelope-from maksim.yevmenkin@gmail.com) Received: from yw-out-2324.google.com (yw-out-2324.google.com [74.125.46.29]) by mx1.freebsd.org (Postfix) with ESMTP id 7A3E98FC2A for ; Thu, 14 May 2009 16:26:19 +0000 (UTC) (envelope-from maksim.yevmenkin@gmail.com) Received: by yw-out-2324.google.com with SMTP id 9so773943ywe.13 for ; Thu, 14 May 2009 09:26:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:mime-version:received:in-reply-to:references :date:message-id:subject:from:to:cc:content-type :content-transfer-encoding; bh=ca8WAlGo6Stj1n6frB3JmPJvKBapj6vhNKhikIm1azk=; b=ah3cuZVRPpe1vOfrb3zp9cQznQiewN3hYykUkmBE5/kWQg5xdHFAKFY1+3boiHDxUR 1wQ2RqU3uJlIZMF2bl5PwJ9wqxWBcu5iweGY0lUn6Z8JdeLOmKP8u8RyCVS/Qqew9yZf b0WFkrPfUeWjlAXYw0e4n+1hS9hEcM+dGyvlE= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type:content-transfer-encoding; b=flPAVPEKLZdGF0MfZOIpFLYJJuJXkSRQK5U7757uIok6LE/NvStW84Q8zn6H2CWIxp bnEYpctMcZ5eKhDrB9ui5aomSv6jjOhTlaQ93+NzzUDNsBLCpTqwrTRXinLClOjRuahT PaF3DUIi+/kFmNxOO+sRn3aU4XPpyv49QQ/gQ= MIME-Version: 1.0 Received: by 10.90.83.2 with SMTP id g2mr1911345agb.105.1242318378846; Thu, 14 May 2009 09:26:18 -0700 (PDT) In-Reply-To: <1242294653.314348.1748.nullmailer@galant.ukfsn.org> References: <1240311202.361300.1366.nullmailer@galant.ukfsn.org> <1240352254.082638.416.nullmailer@galant.ukfsn.org> <1240386569.369073.696.nullmailer@galant.ukfsn.org> <1242294653.314348.1748.nullmailer@galant.ukfsn.org> Date: Thu, 14 May 2009 09:26:18 -0700 Message-ID: From: Maksim Yevmenkin To: Iain Hibbert Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Cc: freebsd-bluetooth@freebsd.org Subject: Re: libhci update X-BeenThere: freebsd-bluetooth@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Using Bluetooth in FreeBSD environments List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 14 May 2009 16:26:20 -0000 Iain, >> thanks for the review. i committed it to -head. > > Hi Max, I'm in progress of translating for NetBSD and in bt_devinquiry() I > see > > if (ii == NULL) { > errno = EINVAL; > return (-1); > } > > but I think this test might be bogus? manpage implies that the caller > provides a buffer but we allocate one.. no, the test is correct. yes, we allocate buffer internally, but we need to return pointer to the buffer back to the caller. so, ii is basically ii is struct bt_devinquiry **. perhaps language in the man page is not clear enough? > /* Calculate inquire length in 1.28 second units */ > to = (time_t) ((double) length / 1.28); > > if (to <= 0) > cp->inquiry_length = 4; /* 5.12 seconds */ > else if (to > 254) > cp->inquiry_length = 255; /* 326.40 seconds */ > else > cp->inquiry_length = to + 1; > > 2.1 spec says 1.28 -> 61.44 seconds range is acceptable (0x01->0x30) > > Then, to avoid the floating point arithmetic, can use (to * 100 / 128) but > would need to be range checked first. I'm inclined to use something like > > if (to == 0) > to = 4; > else if (to == 1) > to = 2; > else if (to > 61) > to = 61; > > cp->inquiry_length = (uint8_t)(to * 100 / 128); i have no problem with it. > also, I'm not sure that the timeout is handled right; the bt_devrecv() > uses the complete timeout each time but the time endpoint might need to be > calculated so that time-to-end can be used? well, yes. bt_devrecv() was envisioned as "one-shot" call. the only case, imo, where it can restart internally with the same timeout is when select is interrupted by a signal. > Also I'm wondering what to do in the case bt_devrecv() does actually time > out - what can it mean and should we [attempt to] cancel the inquiry? ahh, but in case of bt_devinquiry() it probably does not matter that much because inquiry itself is limited by the "length" parameter. so we have to receive something back from the device. i was thinking to pass -1 as timeout to bt_devrecv() in this particular case, but decided not to do it (try harder to exit the bt_devinquiry()). > (actually the whole timeout thing is probably irrelevant for a properly > functioning device :) exactly :) thanks, max p.s. thanks for the sdp update. i will try and take a look when i get free minute.