diff options
Diffstat (limited to 'net/nfc/core.c')
| -rw-r--r-- | net/nfc/core.c | 43 | 
1 files changed, 23 insertions, 20 deletions
diff --git a/net/nfc/core.c b/net/nfc/core.c index e92923cf3e0..819b87702b7 100644 --- a/net/nfc/core.c +++ b/net/nfc/core.c @@ -16,9 +16,7 @@   * GNU General Public License for more details.   *   * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the - * Free Software Foundation, Inc., - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * along with this program; if not, see <http://www.gnu.org/licenses/>.   */  #define pr_fmt(fmt) KBUILD_MODNAME ": %s: " fmt, __func__ @@ -135,11 +133,8 @@ int nfc_dev_up(struct nfc_dev *dev)  		dev->dev_up = true;  	/* We have to enable the device before discovering SEs */ -	if (dev->ops->discover_se) { -		rc = dev->ops->discover_se(dev); -		if (rc) -			pr_warn("SE discovery failed\n"); -	} +	if (dev->ops->discover_se && dev->ops->discover_se(dev)) +		pr_err("SE discovery failed\n");  error:  	device_unlock(&dev->dev); @@ -285,9 +280,6 @@ static struct nfc_target *nfc_find_target(struct nfc_dev *dev, u32 target_idx)  {  	int i; -	if (dev->n_targets == 0) -		return NULL; -  	for (i = 0; i < dev->n_targets; i++) {  		if (dev->targets[i].idx == target_idx)  			return &dev->targets[i]; @@ -384,6 +376,19 @@ int nfc_dep_link_is_up(struct nfc_dev *dev, u32 target_idx,  {  	dev->dep_link_up = true; +	if (!dev->active_target && rf_mode == NFC_RF_INITIATOR) { +		struct nfc_target *target; + +		target = nfc_find_target(dev, target_idx); +		if (target == NULL) +			return -ENOTCONN; + +		dev->active_target = target; +	} + +	dev->polling = false; +	dev->rf_mode = rf_mode; +  	nfc_llcp_mac_is_up(dev, target_idx, comm_mode, rf_mode);  	return nfc_genl_dep_link_up_event(dev, target_idx, comm_mode, rf_mode); @@ -536,16 +541,17 @@ error:  	return rc;  } -static struct nfc_se *find_se(struct nfc_dev *dev, u32 se_idx) +struct nfc_se *nfc_find_se(struct nfc_dev *dev, u32 se_idx)  { -	struct nfc_se *se, *n; +	struct nfc_se *se; -	list_for_each_entry_safe(se, n, &dev->secure_elements, list) +	list_for_each_entry(se, &dev->secure_elements, list)  		if (se->idx == se_idx)  			return se;  	return NULL;  } +EXPORT_SYMBOL(nfc_find_se);  int nfc_enable_se(struct nfc_dev *dev, u32 se_idx)  { @@ -577,7 +583,7 @@ int nfc_enable_se(struct nfc_dev *dev, u32 se_idx)  		goto error;  	} -	se = find_se(dev, se_idx); +	se = nfc_find_se(dev, se_idx);  	if (!se) {  		rc = -EINVAL;  		goto error; @@ -622,7 +628,7 @@ int nfc_disable_se(struct nfc_dev *dev, u32 se_idx)  		goto error;  	} -	se = find_se(dev, se_idx); +	se = nfc_find_se(dev, se_idx);  	if (!se) {  		rc = -EINVAL;  		goto error; @@ -646,9 +652,6 @@ int nfc_set_remote_general_bytes(struct nfc_dev *dev, u8 *gb, u8 gb_len)  {  	pr_debug("dev_name=%s gb_len=%d\n", dev_name(&dev->dev), gb_len); -	if (gb_len > NFC_MAX_GT_LEN) -		return -EINVAL; -  	return nfc_llcp_set_remote_gb(dev, gb, gb_len);  }  EXPORT_SYMBOL(nfc_set_remote_general_bytes); @@ -881,7 +884,7 @@ int nfc_add_se(struct nfc_dev *dev, u32 se_idx, u16 type)  	pr_debug("%s se index %d\n", dev_name(&dev->dev), se_idx); -	se = find_se(dev, se_idx); +	se = nfc_find_se(dev, se_idx);  	if (se)  		return -EALREADY;  | 
