[WFD][IOT]通过小米盒子连接电视,概率性卡在接受视频数据界面
[DESCRIPTION]
手机通过小米盒子连接电视,电视一直停留在正在接受视频数据界面,手机端一直显示正在连接,过1分钟左右断开。
若有看到rtsp session中有下面红色交互过程,请参考下面resolution。
同时还可以查看下ap log有下面关键log打印出来:
sys.log
01-02 04:37:35.430 860 894 I WIFIDisplayController: Lost RTSP connection with Wifi display due to error
1: wcn的小米盒子
01-02 04:37:35.430 860 894 I WifiDisplayController: Wifi display connection failed!
01-02 04:37:35.430 860 894 I WifiDisplayController: disconnect, mRemoteDisplayInterface = 127.0.0.1:7236
01-02 04:37:35.431 860 894 I WifiDisplayController: updateScanState(), mSinkEnabled:false
01-02 04:37:35.432 860 894 I WifiDisplayController: Stopped listening for RTSP connection on
127.0.0.1:7236 from Wifi display : wcn的小米盒子
01-02 04:37:35.432 860 894 I WifiDisplayController: before dispose() --->
main.log
01-02 04:37:35.433 860 894 D RemoteDisplay: ~NativeRemoteDisplay
//PlaybackSession的建立在主动stop之后
01-02 04:37:35.434 406 406 I WifiDisplaySource: WifiDisplaySource::stop kWhatStop=2
01-02 04:37:35.485 406 7771 I WifiDisplaySource: new playbackSession w/o HDCP
[SOLUTION]
该题是由于Dongle在Capability Negotiation(M3-M4)阶段发送了setparameter过来,而此时source
并未建立Playbacksession,回复454,并且上报出错主动断开此连接。
由于是sink逻辑不符合规范,且代码逻辑是google 默认,弊司暂不会修改这段逻辑,请了解。
贵司可以自行决定是否要添加下面修改。
//L版本后,修改frameworks\av\media\libstagefright\wifidisplay\
source\WifiDisplaySource.cpp
//L之前版本,若MTK_USE_ANDROID_MM_DEFAULT_CODE = no,修改
mediatek\frameworks-ext\av\media\libstagefright\wifi-displaymediatek\
WifiDisplaySource.cpp
status_t WifiDisplaySource:nSetParameterRequest(
int32_t sessionID,
int32_t cseq,
const sp &data) {
int32_t playbackSessionID;
sp playbackSession =
findPlaybackSession(data, &playbackSessionID);
if (playbackSession == NULL) {
sendErrorResponse(sessionID, "454 Session Not Found", cseq);
// return ERROR_MALFORMED;
return OK;
}
if (strstr(data->getContent(), "wfd_idr_request\r\n")) {
playbackSession->requestIDRFrame();
}
...
}
手机通过小米盒子连接电视,电视一直停留在正在接受视频数据界面,手机端一直显示正在连接,过1分钟左右断开。
若有看到rtsp session中有下面红色交互过程,请参考下面resolution。
同时还可以查看下ap log有下面关键log打印出来:
sys.log
01-02 04:37:35.430 860 894 I WIFIDisplayController: Lost RTSP connection with Wifi display due to error
1: wcn的小米盒子
01-02 04:37:35.430 860 894 I WifiDisplayController: Wifi display connection failed!
01-02 04:37:35.430 860 894 I WifiDisplayController: disconnect, mRemoteDisplayInterface = 127.0.0.1:7236
01-02 04:37:35.431 860 894 I WifiDisplayController: updateScanState(), mSinkEnabled:false
01-02 04:37:35.432 860 894 I WifiDisplayController: Stopped listening for RTSP connection on
127.0.0.1:7236 from Wifi display : wcn的小米盒子
01-02 04:37:35.432 860 894 I WifiDisplayController: before dispose() --->
main.log
01-02 04:37:35.433 860 894 D RemoteDisplay: ~NativeRemoteDisplay
//PlaybackSession的建立在主动stop之后
01-02 04:37:35.434 406 406 I WifiDisplaySource: WifiDisplaySource::stop kWhatStop=2
01-02 04:37:35.485 406 7771 I WifiDisplaySource: new playbackSession w/o HDCP
[SOLUTION]
该题是由于Dongle在Capability Negotiation(M3-M4)阶段发送了setparameter过来,而此时source
并未建立Playbacksession,回复454,并且上报出错主动断开此连接。
由于是sink逻辑不符合规范,且代码逻辑是google 默认,弊司暂不会修改这段逻辑,请了解。
贵司可以自行决定是否要添加下面修改。
//L版本后,修改frameworks\av\media\libstagefright\wifidisplay\
source\WifiDisplaySource.cpp
//L之前版本,若MTK_USE_ANDROID_MM_DEFAULT_CODE = no,修改
mediatek\frameworks-ext\av\media\libstagefright\wifi-displaymediatek\
WifiDisplaySource.cpp
status_t WifiDisplaySource:nSetParameterRequest(
int32_t sessionID,
int32_t cseq,
const sp &data) {
int32_t playbackSessionID;
sp playbackSession =
findPlaybackSession(data, &playbackSessionID);
if (playbackSession == NULL) {
sendErrorResponse(sessionID, "454 Session Not Found", cseq);
// return ERROR_MALFORMED;
return OK;
}
if (strstr(data->getContent(), "wfd_idr_request\r\n")) {
playbackSession->requestIDRFrame();
}
...
}