|
@@ -24,8 +24,10 @@ static void cfservl_ctrlcmd(struct cflayer *layr, enum caif_ctrlcmd ctrl,
|
|
|
int phyid)
|
|
|
{
|
|
|
struct cfsrvl *service = container_obj(layr);
|
|
|
+
|
|
|
caif_assert(layr->up != NULL);
|
|
|
caif_assert(layr->up->ctrlcmd != NULL);
|
|
|
+
|
|
|
switch (ctrl) {
|
|
|
case CAIF_CTRLCMD_INIT_RSP:
|
|
|
service->open = true;
|
|
@@ -89,9 +91,14 @@ static void cfservl_ctrlcmd(struct cflayer *layr, enum caif_ctrlcmd ctrl,
|
|
|
static int cfservl_modemcmd(struct cflayer *layr, enum caif_modemcmd ctrl)
|
|
|
{
|
|
|
struct cfsrvl *service = container_obj(layr);
|
|
|
+
|
|
|
caif_assert(layr != NULL);
|
|
|
caif_assert(layr->dn != NULL);
|
|
|
caif_assert(layr->dn->transmit != NULL);
|
|
|
+
|
|
|
+ if (!service->supports_flowctrl)
|
|
|
+ return 0;
|
|
|
+
|
|
|
switch (ctrl) {
|
|
|
case CAIF_MODEMCMD_FLOW_ON_REQ:
|
|
|
{
|
|
@@ -153,8 +160,10 @@ void cfservl_destroy(struct cflayer *layer)
|
|
|
}
|
|
|
|
|
|
void cfsrvl_init(struct cfsrvl *service,
|
|
|
- u8 channel_id,
|
|
|
- struct dev_info *dev_info)
|
|
|
+ u8 channel_id,
|
|
|
+ struct dev_info *dev_info,
|
|
|
+ bool supports_flowctrl
|
|
|
+ )
|
|
|
{
|
|
|
caif_assert(offsetof(struct cfsrvl, layer) == 0);
|
|
|
service->open = false;
|
|
@@ -164,6 +173,7 @@ void cfsrvl_init(struct cfsrvl *service,
|
|
|
service->layer.ctrlcmd = cfservl_ctrlcmd;
|
|
|
service->layer.modemcmd = cfservl_modemcmd;
|
|
|
service->dev_info = *dev_info;
|
|
|
+ service->supports_flowctrl = supports_flowctrl;
|
|
|
kref_init(&service->ref);
|
|
|
}
|
|
|
|