AUTOSAR адаптивная сервисная коммуникация предоставляет возможность конфигурировать приложения, чтобы использовать одноразовое или динамическое открытие, чтобы подписаться на сервисы. Режим открытия по умолчанию, OneTime, позволяет приложению AUTOSAR находить и подписываться на сервисы при инициализации. Этот режим открытия может потребовать, чтобы сервисы были запущены перед приложением. Можно изменить сервисный режим открытия в DynamicDiscovery чтобы позволить приложению AUTOSAR найти и подписаться на сервисы как, они становятся доступными.
Можно сконфигурировать, в модели или программно, сервисный режим открытия каждого необходимого порта услуг как OneTime или DynamicDiscovery:
Из вашей модели можно использовать Словарь AUTOSAR, чтобы открыть атрибуты Service discovery требуемых портов и выбрать их сервисные режимы открытия.
В этом примере показано, как установить требуемый порт на DynamicDiscovery.

Программно, можно использовать set функция от getAUTOSARProperties API, чтобы сконфигурировать сервисный режим открытия.
В этом примере показано, как установить требуемый порт на DynamicDiscovery.
hModel = 'autosar_LaneGuidance'; addpath(fullfile(matlabroot,'/examples/autosarblockset/main')); open_system(hModel); apiObj = autosar.api.getAUTOSARProperties(hModel); set(apiObj,"/LaneGuidance_pkg/LaneGuidance_swc/LaneGuidance/RequiredPort/", ... "ServiceDiscoveryMode", "DynamicDiscovery")
Сервисное значение режима открытия влияет на сгенерированный Код С++ (в файле исходного кода модели) в следующих двух местах:
Сайт вызова StartFindService API и регистрация коллбэка (для обоих InstanceIdentifier и InstanceSpecifier варианты).
// Model initialize function
void autosar_LaneGuidanceModelClass::initialize()
{
ProvidedPort = std::make_shared< company::chassis::provided::skeleton::
ProvidedInterfaceSkeleton >(ara::com::InstanceIdentifier("2"), ara::com::
MethodCallProcessingMode::kPoll);
ProvidedPort->OfferService();
company::chassis::required::proxy::RequiredInterfaceProxy::StartFindService
(std::move(std::bind(&autosar_LaneGuidanceModelClass::RequiredPortSvcHandler,
this, std::placeholders::_1, std::placeholders::_2)), ara::com::
InstanceIdentifier("1"));
}Определение функции обратного вызова.
void autosar_LaneGuidanceModelClass::RequiredPortSvcHandler(ara::com::
ServiceHandleContainer< company::chassis::required::proxy::
RequiredInterfaceProxy::HandleType > svcHandles, const ara::com::
FindServiceHandle fsHandle)
{
if ((!RequiredPort) && (svcHandles.size() > 0U)) {
RequiredPort = std::make_shared< company::chassis::required::proxy::
RequiredInterfaceProxy >(*svcHandles.begin());
RequiredPort->leftCarInBlindSpot.Subscribe(1U);
RequiredPort->leftLaneDistance.Subscribe(1U);
RequiredPort->leftTurnIndicator.Subscribe(1U);
RequiredPort->rightCarInBlindSpot.Subscribe(1U);
RequiredPort->rightLaneDistance.Subscribe(1U);
RequiredPort->rightTurnIndicator.Subscribe(1U);
company::chassis::required::proxy::RequiredInterfaceProxy::StopFindService
(fsHandle);
}
}