From owner-freebsd-bluetooth@FreeBSD.ORG Thu May 14 18:40:58 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 C0902106568A for ; Thu, 14 May 2009 18:40:58 +0000 (UTC) (envelope-from maksim.yevmenkin@gmail.com) Received: from yx-out-2324.google.com (yx-out-2324.google.com [74.125.44.29]) by mx1.freebsd.org (Postfix) with ESMTP id 73E5B8FC1B for ; Thu, 14 May 2009 18:40:58 +0000 (UTC) (envelope-from maksim.yevmenkin@gmail.com) Received: by yx-out-2324.google.com with SMTP id 8so819263yxb.13 for ; Thu, 14 May 2009 11:40:58 -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=p6vith9++b4OTl2ajCFOC8qoXsIPlSDHa8bOo+kw5vI=; b=kEVao2FXo6/1aGbWv5LLe5umn477p3CxPmjX/TZ70wfDDPikgdwSi8TnnSY0K9AhkD dChluuJLIjRgur8eafCvWMvpUxA2o+80ZiCEiW4wS88k4aavAKwM19LoPk69zii4vOwM F+SyfFI1hQ2VqAPgaj/imp/G0VmWmzPgA64DE= 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=hNkW9oIDZNiX+p6XFccQQ7S4b1NAK46F8+uJ9hm1mgxJ9pbDmXf0I20HP5w0IdTQXK Dt1pW37DbWMxljkczMYVzxESy4+UVX4Nzsv8oa2Jg+zeaozeAa3RRrNjee5I2P4v+TR1 yycCeVCQ+RGGCo2L6aRpHkHrFmqLqDV5sgnaY= MIME-Version: 1.0 Received: by 10.100.46.18 with SMTP id t18mr3476133ant.54.1242326457879; Thu, 14 May 2009 11:40:57 -0700 (PDT) In-Reply-To: <1242322384.832849.4269.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> <1242322384.832849.4269.nullmailer@galant.ukfsn.org> Date: Thu, 14 May 2009 11:40:57 -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 18:40:59 -0000 On Thu, May 14, 2009 at 10:33 AM, Iain Hibbert wrote: [...] >> > 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? > > Ah yes, my bad. I haven't properly looked at the manpage yet (I saw a > spelling mistake earlier but I didn't note it :), will examine it in > detail later. I'm trying to think of another function that does similar to > copy the language from, perhaps asprintf()? yeah, may be. please feel free to correct my english :) > btw do you know what devinfo->role_switch_info might contain? I have > link_policy_info which presumably contains the following flags that is for 'forceful' role switch when we are accepting connection. basically always try to become master on any connection (or not). [...] >> > 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. > > I think the timeout should probably act the same way as in bt_devreq(), > but I thought there could be close calls at the end because of the integer > arithmetic. sorry, are we talking about bt_devrecv() in isolation, or about bt_devinquiry() usage of bt_devrecv(). in other words, are you saying we should fix bt_devinquiry() and make sure that is decreases timeout with every call to bt_devrecv()? >> > 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()). > > mm, -1 is tempting but I think its better to error timeout even if the > device is left in a weird state. At least the user won't be left waiting.. my thoughts exactly :) > I'll continue to work on it because a successful exit must wait until the > device has exited inquiry mode. (I noticed that you can't do things like > get-remote-name when still in inquiry mode, at least on some devices) yes, inquiry is weird (from baseband point of view) procedure. device basically has to blast on the range of frequencies and wait for someone to respond. technically, nothing prevents device from doing other rf activity, but some devices choose not to do it. thanks, max