Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp5848752ybp; Tue, 15 Oct 2019 06:04:22 -0700 (PDT) X-Google-Smtp-Source: APXvYqw2TDiopWPKLwY20xQDPO7Q+FGKQfKKCfopEM9JY6XEnnR2Bdptx+CeESFQagw1Y+ws+3NB X-Received: by 2002:a17:906:2295:: with SMTP id p21mr34169744eja.8.1571144661843; Tue, 15 Oct 2019 06:04:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571144661; cv=none; d=google.com; s=arc-20160816; b=u/LAttfwGObJkVZRfSsq42q2pflpqoWymhwuAKkleDhpSxjG1SbmEMXaSggRomTgcq w23yOvVrBxawJtC2oslYAoYQuduepP18/gPYrgiov8LoUy5qlzlndlXJ+3u0F5aEeBQq HJMXI8nvKYvv3U9Wcia5bHhl405RWR88nH4qcfwPt2g1povI79Ob7aBUVC76ux0b4B+m 98KjLcXmQnFiLhq5iieZ/m4idzafXUW0W2Ze7WMWfAph+We38D136MYqYM0xTSR0bJN7 TCbIM4PTijwj6GV4+Of5V/kaFme1IaiwEYw5bX+nahtGWBiWcO49rzsN+o7ae6pdZTwu GvRg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from:dkim-signature; bh=VHS+BxJ9bqoSYa+xH/IlFL4fMa0/Sv3mZVO6EbWq22c=; b=Q6TrdzDN88fXiR3gJ6LeE8wLK+pmUDDDi3EMTdH0c7PGtez3jywjd2EDyJZMwZzirU IhYI6M2XzkdgabETdfioPBJvZD+eYufmBlJSDBo/+gwmm6hosnzbrQ2S4oQJ8fOsQuDb cJ3nUA3SfnGK30oluhQq92BjZ50hGb7AhW+XwD+4WpzSbhwZ2SfTS7XnHP6HzhVvo+wn FOos40jSMNkdZc6flh2verBDohmG/VKy9K9hWso9sOyHsi+iHHebOYB0n70pgGkh/Jnb 18iPDjCflh/QWqpaBvQf39+xvLSHJ+tl7Yd385anQlCSJmVXTp7TAuUjXuFLrZ03gxLB f3Kg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@st.com header.s=STMicroelectronics header.b=0Lj58A9x; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w26si14446881edd.305.2019.10.15.06.03.57; Tue, 15 Oct 2019 06:04:21 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@st.com header.s=STMicroelectronics header.b=0Lj58A9x; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729595AbfJONDe (ORCPT + 99 others); Tue, 15 Oct 2019 09:03:34 -0400 Received: from mx07-00178001.pphosted.com ([62.209.51.94]:10150 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726236AbfJONDd (ORCPT ); Tue, 15 Oct 2019 09:03:33 -0400 Received: from pps.filterd (m0046668.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id x9FD19iU028733; Tue, 15 Oct 2019 15:03:10 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=st.com; h=from : to : cc : subject : date : message-id : mime-version : content-type; s=STMicroelectronics; bh=VHS+BxJ9bqoSYa+xH/IlFL4fMa0/Sv3mZVO6EbWq22c=; b=0Lj58A9xHYrxKdris99TmusVli4cURzyHTxxKuLM7DKc4aq6Qe/2a5y2kZbCOr/QZwTY OPdz2wDm6ziwgXKcppkiWLBH33LxmcGX6nbjkUtd6yS7Hvoywy9xZX12wnd0yxlyyGcR dfAzfeLIzRZcvxat5fWjIUqgE3ahLoqEc8WsbWEbWmYJ/MxaAf22DYvrDpSre0WdZ7Fb PzHVq1hX780fNsak25CV4sMZnKuiYLzS11o7nSi5rxCiyXn4+eveluM2VK5cEkU5IGta xajiHrem7QQCYzcu0eAZ75UyryHND4Opg/FlSSFIYHwDbPsFBbJ0bAr3FJR3E3HXZpga 8A== Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com with ESMTP id 2vk4a18aw0-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 15 Oct 2019 15:03:10 +0200 Received: from euls16034.sgp.st.com (euls16034.sgp.st.com [10.75.44.20]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id BCB6F10002A; Tue, 15 Oct 2019 15:03:09 +0200 (CEST) Received: from Webmail-eu.st.com (sfhdag3node2.st.com [10.75.127.8]) by euls16034.sgp.st.com (STMicroelectronics) with ESMTP id 8EA7D206463; Tue, 15 Oct 2019 15:03:09 +0200 (CEST) Received: from localhost (10.75.127.49) by SFHDAG3NODE2.st.com (10.75.127.8) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Tue, 15 Oct 2019 15:03:09 +0200 From: Alain Volmat To: , CC: , , , , , , , , , Subject: [PATCH] i2c: i2c-stm32f7: rework slave_id allocation Date: Tue, 15 Oct 2019 15:03:09 +0200 Message-ID: <1571144589-3066-1-git-send-email-alain.volmat@st.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.75.127.49] X-ClientProxiedBy: SFHDAG5NODE2.st.com (10.75.127.14) To SFHDAG3NODE2.st.com (10.75.127.8) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.95,1.0.8 definitions=2019-10-15_05:2019-10-15,2019-10-15 signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The IP can handle two slave addresses. One address can either be 7 bits or 10 bits while the other can only be 7 bits. In order to ensure that a 10 bits address can always be allocated (assuming there is only one 7 bits address already allocated), pick up the 7-bits only address slot in priority when performing a 7-bits address allocation. Fixes: 60d609f3 ("i2c: i2c-stm32f7: Add slave support") Signed-off-by: Alain Volmat --- drivers/i2c/busses/i2c-stm32f7.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/i2c/busses/i2c-stm32f7.c b/drivers/i2c/busses/i2c-stm32f7.c index d36cf08461f7..cfae01b15243 100644 --- a/drivers/i2c/busses/i2c-stm32f7.c +++ b/drivers/i2c/busses/i2c-stm32f7.c @@ -1265,7 +1265,7 @@ static int stm32f7_i2c_get_free_slave_id(struct stm32f7_i2c_dev *i2c_dev, * slave[0] supports 7-bit and 10-bit slave address * slave[1] supports 7-bit slave address only */ - for (i = 0; i < STM32F7_I2C_MAX_SLAVE; i++) { + for (i = STM32F7_I2C_MAX_SLAVE - 1; i >= 0; i--) { if (i == 1 && (slave->flags & I2C_CLIENT_PEC)) continue; if (!i2c_dev->slave[i]) { -- 2.7.4