|
@@ -426,6 +426,69 @@ free_msg:
|
|
|
return rc;
|
|
|
}
|
|
|
|
|
|
+int nfc_genl_se_added(struct nfc_dev *dev, u32 se_idx, u16 type)
|
|
|
+{
|
|
|
+ struct sk_buff *msg;
|
|
|
+ void *hdr;
|
|
|
+
|
|
|
+ msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
|
|
|
+ if (!msg)
|
|
|
+ return -ENOMEM;
|
|
|
+
|
|
|
+ hdr = genlmsg_put(msg, 0, 0, &nfc_genl_family, 0,
|
|
|
+ NFC_EVENT_SE_ADDED);
|
|
|
+ if (!hdr)
|
|
|
+ goto free_msg;
|
|
|
+
|
|
|
+ if (nla_put_u32(msg, NFC_ATTR_DEVICE_INDEX, dev->idx) ||
|
|
|
+ nla_put_u32(msg, NFC_ATTR_SE_INDEX, se_idx) ||
|
|
|
+ nla_put_u8(msg, NFC_ATTR_SE_TYPE, type))
|
|
|
+ goto nla_put_failure;
|
|
|
+
|
|
|
+ genlmsg_end(msg, hdr);
|
|
|
+
|
|
|
+ genlmsg_multicast(msg, 0, nfc_genl_event_mcgrp.id, GFP_KERNEL);
|
|
|
+
|
|
|
+ return 0;
|
|
|
+
|
|
|
+nla_put_failure:
|
|
|
+ genlmsg_cancel(msg, hdr);
|
|
|
+free_msg:
|
|
|
+ nlmsg_free(msg);
|
|
|
+ return -EMSGSIZE;
|
|
|
+}
|
|
|
+
|
|
|
+int nfc_genl_se_removed(struct nfc_dev *dev, u32 se_idx)
|
|
|
+{
|
|
|
+ struct sk_buff *msg;
|
|
|
+ void *hdr;
|
|
|
+
|
|
|
+ msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
|
|
|
+ if (!msg)
|
|
|
+ return -ENOMEM;
|
|
|
+
|
|
|
+ hdr = genlmsg_put(msg, 0, 0, &nfc_genl_family, 0,
|
|
|
+ NFC_EVENT_SE_REMOVED);
|
|
|
+ if (!hdr)
|
|
|
+ goto free_msg;
|
|
|
+
|
|
|
+ if (nla_put_u32(msg, NFC_ATTR_DEVICE_INDEX, dev->idx) ||
|
|
|
+ nla_put_u32(msg, NFC_ATTR_SE_INDEX, se_idx))
|
|
|
+ goto nla_put_failure;
|
|
|
+
|
|
|
+ genlmsg_end(msg, hdr);
|
|
|
+
|
|
|
+ genlmsg_multicast(msg, 0, nfc_genl_event_mcgrp.id, GFP_KERNEL);
|
|
|
+
|
|
|
+ return 0;
|
|
|
+
|
|
|
+nla_put_failure:
|
|
|
+ genlmsg_cancel(msg, hdr);
|
|
|
+free_msg:
|
|
|
+ nlmsg_free(msg);
|
|
|
+ return -EMSGSIZE;
|
|
|
+}
|
|
|
+
|
|
|
static int nfc_genl_send_device(struct sk_buff *msg, struct nfc_dev *dev,
|
|
|
u32 portid, u32 seq,
|
|
|
struct netlink_callback *cb,
|