提交 5d8eac3a 编写于 作者: J John W. Linville

Merge tag 'nfc-next-3.9-3' of git://git.kernel.org/pub/scm/linux/kernel/git/sameo/nfc-next

Samuel Ortiz <sameo@linux.intel.com> says:

"This 3rd NFC pull request for 3.9 contains a fix for the microread MEI
physical layer support, as the MEI bus API changed.

From the MEI code, we now pass the MEI id back to the driver probe routine,
and we also pass a name and a MEI id table through the mei_bus_driver
structure. A few renames as well like e.g. mei_bus_driver to mei_driver or
mei_bus_client to mei_device in order to be closer to the driver model
practices."
Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
...@@ -48,7 +48,7 @@ struct mei_nfc_hdr { ...@@ -48,7 +48,7 @@ struct mei_nfc_hdr {
#define MEI_NFC_MAX_READ (MEI_NFC_HEADER_SIZE + MEI_NFC_MAX_HCI_PAYLOAD) #define MEI_NFC_MAX_READ (MEI_NFC_HEADER_SIZE + MEI_NFC_MAX_HCI_PAYLOAD)
struct microread_mei_phy { struct microread_mei_phy {
struct mei_bus_client *client; struct mei_device *mei_device;
struct nfc_hci_dev *hdev; struct nfc_hci_dev *hdev;
int powered; int powered;
...@@ -105,14 +105,14 @@ static int microread_mei_write(void *phy_id, struct sk_buff *skb) ...@@ -105,14 +105,14 @@ static int microread_mei_write(void *phy_id, struct sk_buff *skb)
MEI_DUMP_SKB_OUT("mei frame sent", skb); MEI_DUMP_SKB_OUT("mei frame sent", skb);
r = mei_bus_send(phy->client, skb->data, skb->len); r = mei_send(phy->device, skb->data, skb->len);
if (r > 0) if (r > 0)
r = 0; r = 0;
return r; return r;
} }
static void microread_event_cb(struct mei_bus_client *client, u32 events, static void microread_event_cb(struct mei_device *device, u32 events,
void *context) void *context)
{ {
struct microread_mei_phy *phy = context; struct microread_mei_phy *phy = context;
...@@ -120,7 +120,7 @@ static void microread_event_cb(struct mei_bus_client *client, u32 events, ...@@ -120,7 +120,7 @@ static void microread_event_cb(struct mei_bus_client *client, u32 events,
if (phy->hard_fault != 0) if (phy->hard_fault != 0)
return; return;
if (events & BIT(MEI_BUS_EVENT_RX)) { if (events & BIT(MEI_EVENT_RX)) {
struct sk_buff *skb; struct sk_buff *skb;
int reply_size; int reply_size;
...@@ -128,7 +128,7 @@ static void microread_event_cb(struct mei_bus_client *client, u32 events, ...@@ -128,7 +128,7 @@ static void microread_event_cb(struct mei_bus_client *client, u32 events,
if (!skb) if (!skb)
return; return;
reply_size = mei_bus_recv(client, skb->data, MEI_NFC_MAX_READ); reply_size = mei_recv(device, skb->data, MEI_NFC_MAX_READ);
if (reply_size < MEI_NFC_HEADER_SIZE) { if (reply_size < MEI_NFC_HEADER_SIZE) {
kfree(skb); kfree(skb);
return; return;
...@@ -149,7 +149,8 @@ static struct nfc_phy_ops mei_phy_ops = { ...@@ -149,7 +149,8 @@ static struct nfc_phy_ops mei_phy_ops = {
.disable = microread_mei_disable, .disable = microread_mei_disable,
}; };
static int microread_mei_probe(struct mei_bus_client *client) static int microread_mei_probe(struct mei_device *device,
const struct mei_id *id)
{ {
struct microread_mei_phy *phy; struct microread_mei_phy *phy;
int r; int r;
...@@ -162,10 +163,10 @@ static int microread_mei_probe(struct mei_bus_client *client) ...@@ -162,10 +163,10 @@ static int microread_mei_probe(struct mei_bus_client *client)
return -ENOMEM; return -ENOMEM;
} }
phy->client = client; phy->device = device;
mei_bus_set_clientdata(client, phy); mei_set_clientdata(device, phy);
r = mei_bus_register_event_cb(client, microread_event_cb, phy); r = mei_register_event_cb(device, microread_event_cb, phy);
if (r) { if (r) {
pr_err(MICROREAD_DRIVER_NAME ": event cb registration failed\n"); pr_err(MICROREAD_DRIVER_NAME ": event cb registration failed\n");
goto err_out; goto err_out;
...@@ -185,9 +186,9 @@ static int microread_mei_probe(struct mei_bus_client *client) ...@@ -185,9 +186,9 @@ static int microread_mei_probe(struct mei_bus_client *client)
return r; return r;
} }
static int microread_mei_remove(struct mei_bus_client *client) static int microread_mei_remove(struct mei_device *device)
{ {
struct microread_mei_phy *phy = mei_bus_get_clientdata(client); struct microread_mei_phy *phy = mei_get_clientdata(device);
pr_info("Removing microread\n"); pr_info("Removing microread\n");
...@@ -201,14 +202,18 @@ static int microread_mei_remove(struct mei_bus_client *client) ...@@ -201,14 +202,18 @@ static int microread_mei_remove(struct mei_bus_client *client)
return 0; return 0;
} }
static struct mei_bus_driver microread_driver = { static struct mei_id microread_mei_tbl[] = {
.driver = { { MICROREAD_DRIVER_NAME, MICROREAD_UUID },
.name = MICROREAD_DRIVER_NAME,
}, /* required last entry */
.id = { { }
.name = MICROREAD_DRIVER_NAME, };
.uuid = MICROREAD_UUID,
}, MODULE_DEVICE_TABLE(mei, microread_mei_tbl);
static struct mei_driver microread_driver = {
.id_table = microread_mei_tbl,
.name = MICROREAD_DRIVER_NAME,
.probe = microread_mei_probe, .probe = microread_mei_probe,
.remove = microread_mei_remove, .remove = microread_mei_remove,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册