All of lore.kernel.org
 help / color / mirror / Atom feed
From: Timo =?unknown-8bit?q?M=C3=BCller?= <mail@timomueller.eu>
To: ofono@ofono.org
Subject: Re: [PATCHv2 2/2] hfpmodem: Request AT+CLCC again after callheld=<2 or 3>
Date: Mon, 04 Feb 2013 17:20:13 +0100	[thread overview]
Message-ID: <510FDFBD.8020900@timomueller.eu> (raw)
In-Reply-To: <5109EE68.5050109@gmail.com>

[-- Attachment #1: Type: text/plain, Size: 3756 bytes --]

Hi Denis,

Denis Kenzior wrote, On 31.01.2013 05:09:
> Hi Timo,
>
> On 01/28/2013 04:13 AM, Timo Mueller wrote:
>> From: Timo Mueller<timo.mueller@bmw-carit.de>
>>
>> With a call being active, placing a second call on the AG device will
>> lead to the active call being put on hold. During the transition some
>> phones do not update the list of current calls. This leads to an +CLCC
>> response that does not contain the new outgoing call, even though an
>> outgoing callsetup was reported.
>>
>> The list will be updated once the active call was put on hold and
>> callheld=2 is reported. In this case the list has to be requested
>> again (AT+CLCC).
>>
>> AT sequence that exhibited the failure (AG device was a Nokia N9
>> having an active outgoing call and placing a second outgoing call)
>>
>
> Ugh.
>
> <snip>
>
>> @@ -1072,6 +1074,14 @@ static void ciev_callheld_notify(struct
>> ofono_voicecall *vc,
>>                   call->status = CALL_STATUS_HELD;
>>                   ofono_voicecall_notify(vc, call);
>>               }
>> +
>> +            if (callsetup == 2 || callsetup == 3) {
>> +                dialing = find_dialing(vd->calls);
>> +
>> +                if (dialing == NULL)
>> +                    g_at_chat_send(vd->chat, "AT+CLCC", clcc_prefix,
>> +                        clcc_poll_cb, vc, NULL);
>> +            }
>>           } else if (callheld == 1) {
>>               if (vd->clcc_source)
>>                   g_source_remove(vd->clcc_source);
>
> I'm seeing reports of too many devices doing too many weird things, and
> if we change the core logic for each and every one then the code becomes
> a huge mess quickly.  It would be hard to validate or regression test it
> without massive investment in automated interoperability testing.
>
> Marcel and I spoke briefly about this and our belief is that we need to
> introduce manufacturer specific quirks to HFP drivers instead of trying
> to solve this generically.
>
> BlueZ should be able to provide us enough information about the remote
> device for us to make a fairly good guess as to the manufacturer /
> version.  Additional details can be queried by manufacturer specific
> commands (e.g. in the case of iOS).  That should be enough for us to
> simply set the vendor / quirk ID and take appropriate action in the driver.
>
> We can always fall back to strict spec compliant behavior by default if
> the manufacturer quirks cannot be determined.  What do you think?

I agree, that the core logic shouldn't be polluted with phone specific 
workarounds. This is especially true when the quirks somehow interfere 
or modify the standard path. Having said this, I'd consider this fix 
general enough to justify it's integration in the standard driver, since 
the policy makes sense for any phone (mis)behaving this way, keeping the 
phone specific quirks to an absolute minimum.

I know that the N9 is the only phone that has seen this problem so far, 
but the problem will occur with every phone that doesn't "atomically" 
change the CLCC list the moment it reports an indicator change (+CIEV).

As described in the commit message the phone already told the HF that it 
has set up an outgoing call (or that it's already alerting). The  only 
thing missing is the detailed information about the call, which is 
retrieved using the AT+CLCC request.

So in this case I think it's valid to generally try to fill in the 
missing information by issuing another AT+CLCC request. Otherwise the 
call will be alerting and although the phone has reported all indicator 
changes to oFono, we won't be able to reasonably control it from HF side.

>
> Regards,
> -Denis

Best regards,
Timo


  reply	other threads:[~2013-02-04 16:20 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <cover.1359360111.git.timo.mueller@bmw-carit.de>
2013-01-28 10:13 ` [PATCHv2 1/2] hfpmodem: Retry AT+CLCC request after outgoing callsetup Timo Mueller
2013-01-28 10:13   ` [PATCHv2 2/2] hfpmodem: Request AT+CLCC again after callheld=<2 or 3> Timo Mueller
2013-01-31  4:09     ` Denis Kenzior
2013-02-04 16:20       ` Timo =?unknown-8bit?q?M=C3=BCller?= [this message]
2013-02-03  3:23         ` Denis Kenzior
2013-01-31  3:50   ` [PATCHv2 1/2] hfpmodem: Retry AT+CLCC request after outgoing callsetup Denis Kenzior

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=510FDFBD.8020900@timomueller.eu \
    --to=mail@timomueller.eu \
    --cc=ofono@ofono.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.