* [PATCH v2] I2C: busses: i2c-eg20t Do not print error message in syslog if no ACK received
@ 2013-11-17 8:58 ` Andreas Werner
0 siblings, 0 replies; 12+ messages in thread
From: Andreas Werner @ 2013-11-17 8:58 UTC (permalink / raw)
To: wsa-z923LK4zBo2bacvFa/9K2g
Cc: khali-PUYAD+kWke1g9hUCZPvPmw, jacmet-OfajU3CKLf1/SzgSGea1oA,
hskinnemoen-Re5JQEeQqe8AvxtiuMwx3w,
dianders-F7+t8E8rja9g9hUCZPvPmw, linux-i2c-u79uwXL29TY76Z2rM5mHXA,
linux-kernel-u79uwXL29TY76Z2rM5mHXA, wernerandy-Mmb7MZpHnFY
Revision 2:
- delete the pch_err completly instead of changing to pch_dbg
because there is already a pch_dbg at the function who calls
pch_i2c_getack.
- Fixed message line issue
Using the i2c-eg20t driver and call i2cdetect or probe on the bus,
the driver will print a lot of error messages if there was no ACK
received.
i2cdetect normally print a table with all the available devices. If there
is no device on the address, the table will be empty.
Currently with the i2c-eg20t driver, the table is not visible because
the error messages destroy the table.
Error message: pch_i2c_getack return -71
This patch prevent the driver to print the messages to syslog.
The pch_i2c_wait_for_check_xfer function is the only one who is
calling pch_i2c_getack, and there is already a dbg print if it fails,
so we can delete the pch_err in pch_i2c_getack completly.
Fixed print message to be a one liner so we can grep for the
error message.
Tested on Intel Atom E6xx and Eg20t Chipset.
Signed-off-by: Andreas Werner <wernerandy-Mmb7MZpHnFY@public.gmane.org>
---
drivers/i2c/busses/i2c-eg20t.c | 7 ++-----
1 file changed, 2 insertions(+), 5 deletions(-)
diff --git a/drivers/i2c/busses/i2c-eg20t.c b/drivers/i2c/busses/i2c-eg20t.c
index 0f37529..5c39f90 100644
--- a/drivers/i2c/busses/i2c-eg20t.c
+++ b/drivers/i2c/busses/i2c-eg20t.c
@@ -321,10 +321,8 @@ static s32 pch_i2c_getack(struct i2c_algo_pch_data *adap)
void __iomem *p = adap->pch_base_address;
reg_val = ioread32(p + PCH_I2CSR) & PCH_GETACK;
- if (reg_val != 0) {
- pch_err(adap, "return%d\n", -EPROTO);
+ if (reg_val != 0)
return -EPROTO;
- }
return 0;
}
@@ -367,8 +365,7 @@ static int pch_i2c_wait_for_check_xfer(struct i2c_algo_pch_data *adap)
adap->pch_event_flag = 0;
if (pch_i2c_getack(adap)) {
- pch_dbg(adap, "Receive NACK for slave address"
- "setting\n");
+ pch_dbg(adap, "Receive NACK for slave address setting\n");
return -EIO;
}
--
1.8.4
^ permalink raw reply related [flat|nested] 12+ messages in thread* [PATCH v2] I2C: busses: i2c-eg20t Do not print error message in syslog if no ACK received
@ 2013-11-17 8:58 ` Andreas Werner
0 siblings, 0 replies; 12+ messages in thread
From: Andreas Werner @ 2013-11-17 8:58 UTC (permalink / raw)
To: wsa
Cc: khali, jacmet, hskinnemoen, dianders, linux-i2c, linux-kernel,
wernerandy
Revision 2:
- delete the pch_err completly instead of changing to pch_dbg
because there is already a pch_dbg at the function who calls
pch_i2c_getack.
- Fixed message line issue
Using the i2c-eg20t driver and call i2cdetect or probe on the bus,
the driver will print a lot of error messages if there was no ACK
received.
i2cdetect normally print a table with all the available devices. If there
is no device on the address, the table will be empty.
Currently with the i2c-eg20t driver, the table is not visible because
the error messages destroy the table.
Error message: pch_i2c_getack return -71
This patch prevent the driver to print the messages to syslog.
The pch_i2c_wait_for_check_xfer function is the only one who is
calling pch_i2c_getack, and there is already a dbg print if it fails,
so we can delete the pch_err in pch_i2c_getack completly.
Fixed print message to be a one liner so we can grep for the
error message.
Tested on Intel Atom E6xx and Eg20t Chipset.
Signed-off-by: Andreas Werner <wernerandy@gmx.de>
---
drivers/i2c/busses/i2c-eg20t.c | 7 ++-----
1 file changed, 2 insertions(+), 5 deletions(-)
diff --git a/drivers/i2c/busses/i2c-eg20t.c b/drivers/i2c/busses/i2c-eg20t.c
index 0f37529..5c39f90 100644
--- a/drivers/i2c/busses/i2c-eg20t.c
+++ b/drivers/i2c/busses/i2c-eg20t.c
@@ -321,10 +321,8 @@ static s32 pch_i2c_getack(struct i2c_algo_pch_data *adap)
void __iomem *p = adap->pch_base_address;
reg_val = ioread32(p + PCH_I2CSR) & PCH_GETACK;
- if (reg_val != 0) {
- pch_err(adap, "return%d\n", -EPROTO);
+ if (reg_val != 0)
return -EPROTO;
- }
return 0;
}
@@ -367,8 +365,7 @@ static int pch_i2c_wait_for_check_xfer(struct i2c_algo_pch_data *adap)
adap->pch_event_flag = 0;
if (pch_i2c_getack(adap)) {
- pch_dbg(adap, "Receive NACK for slave address"
- "setting\n");
+ pch_dbg(adap, "Receive NACK for slave address setting\n");
return -EIO;
}
--
1.8.4
^ permalink raw reply related [flat|nested] 12+ messages in thread[parent not found: <1384678731-10399-1-git-send-email-wernerandy-Mmb7MZpHnFY@public.gmane.org>]
* Re: [PATCH v2] I2C: busses: i2c-eg20t Do not print error message in syslog if no ACK received
2013-11-17 8:58 ` Andreas Werner
@ 2013-11-17 11:08 ` Wolfram Sang
-1 siblings, 0 replies; 12+ messages in thread
From: Wolfram Sang @ 2013-11-17 11:08 UTC (permalink / raw)
To: Andreas Werner
Cc: khali-PUYAD+kWke1g9hUCZPvPmw, jacmet-OfajU3CKLf1/SzgSGea1oA,
hskinnemoen-Re5JQEeQqe8AvxtiuMwx3w,
dianders-F7+t8E8rja9g9hUCZPvPmw, linux-i2c-u79uwXL29TY76Z2rM5mHXA,
linux-kernel-u79uwXL29TY76Z2rM5mHXA
[-- Attachment #1: Type: text/plain, Size: 1304 bytes --]
On Sun, Nov 17, 2013 at 09:58:51AM +0100, Andreas Werner wrote:
> Revision 2:
> - delete the pch_err completly instead of changing to pch_dbg
> because there is already a pch_dbg at the function who calls
> pch_i2c_getack.
> - Fixed message line issue
I prefer this below "---" after Signed-off.
>
> diff --git a/drivers/i2c/busses/i2c-eg20t.c b/drivers/i2c/busses/i2c-eg20t.c
> index 0f37529..5c39f90 100644
> --- a/drivers/i2c/busses/i2c-eg20t.c
> +++ b/drivers/i2c/busses/i2c-eg20t.c
> @@ -321,10 +321,8 @@ static s32 pch_i2c_getack(struct i2c_algo_pch_data *adap)
> void __iomem *p = adap->pch_base_address;
> reg_val = ioread32(p + PCH_I2CSR) & PCH_GETACK;
>
> - if (reg_val != 0) {
> - pch_err(adap, "return%d\n", -EPROTO);
> + if (reg_val != 0)
> return -EPROTO;
That could be fixed to -ENXIO according to
Documentation/i2c/fault-codes.
> @@ -367,8 +365,7 @@ static int pch_i2c_wait_for_check_xfer(struct i2c_algo_pch_data *adap)
> adap->pch_event_flag = 0;
>
> if (pch_i2c_getack(adap)) {
> - pch_dbg(adap, "Receive NACK for slave address"
> - "setting\n");
> + pch_dbg(adap, "Receive NACK for slave address setting\n");
> return -EIO;
What about returning the value we got from pch_i2c_getack?
Regards,
Wolfram
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 836 bytes --]
^ permalink raw reply [flat|nested] 12+ messages in thread* Re: [PATCH v2] I2C: busses: i2c-eg20t Do not print error message in syslog if no ACK received
@ 2013-11-17 11:08 ` Wolfram Sang
0 siblings, 0 replies; 12+ messages in thread
From: Wolfram Sang @ 2013-11-17 11:08 UTC (permalink / raw)
To: Andreas Werner
Cc: khali, jacmet, hskinnemoen, dianders, linux-i2c, linux-kernel
[-- Attachment #1: Type: text/plain, Size: 1304 bytes --]
On Sun, Nov 17, 2013 at 09:58:51AM +0100, Andreas Werner wrote:
> Revision 2:
> - delete the pch_err completly instead of changing to pch_dbg
> because there is already a pch_dbg at the function who calls
> pch_i2c_getack.
> - Fixed message line issue
I prefer this below "---" after Signed-off.
>
> diff --git a/drivers/i2c/busses/i2c-eg20t.c b/drivers/i2c/busses/i2c-eg20t.c
> index 0f37529..5c39f90 100644
> --- a/drivers/i2c/busses/i2c-eg20t.c
> +++ b/drivers/i2c/busses/i2c-eg20t.c
> @@ -321,10 +321,8 @@ static s32 pch_i2c_getack(struct i2c_algo_pch_data *adap)
> void __iomem *p = adap->pch_base_address;
> reg_val = ioread32(p + PCH_I2CSR) & PCH_GETACK;
>
> - if (reg_val != 0) {
> - pch_err(adap, "return%d\n", -EPROTO);
> + if (reg_val != 0)
> return -EPROTO;
That could be fixed to -ENXIO according to
Documentation/i2c/fault-codes.
> @@ -367,8 +365,7 @@ static int pch_i2c_wait_for_check_xfer(struct i2c_algo_pch_data *adap)
> adap->pch_event_flag = 0;
>
> if (pch_i2c_getack(adap)) {
> - pch_dbg(adap, "Receive NACK for slave address"
> - "setting\n");
> + pch_dbg(adap, "Receive NACK for slave address setting\n");
> return -EIO;
What about returning the value we got from pch_i2c_getack?
Regards,
Wolfram
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 836 bytes --]
^ permalink raw reply [flat|nested] 12+ messages in thread* Re: [PATCH v2] I2C: busses: i2c-eg20t Do not print error message in syslog if no ACK received
2013-11-17 11:08 ` Wolfram Sang
@ 2013-11-17 12:39 ` Andreas Werner
-1 siblings, 0 replies; 12+ messages in thread
From: Andreas Werner @ 2013-11-17 12:39 UTC (permalink / raw)
To: Wolfram Sang
Cc: khali-PUYAD+kWke1g9hUCZPvPmw, jacmet-OfajU3CKLf1/SzgSGea1oA,
hskinnemoen-Re5JQEeQqe8AvxtiuMwx3w,
dianders-F7+t8E8rja9g9hUCZPvPmw, linux-i2c-u79uwXL29TY76Z2rM5mHXA,
linux-kernel-u79uwXL29TY76Z2rM5mHXA
On Sun, Nov 17, 2013 at 12:08:46PM +0100, Wolfram Sang wrote:
> On Sun, Nov 17, 2013 at 09:58:51AM +0100, Andreas Werner wrote:
> > Revision 2:
> > - delete the pch_err completly instead of changing to pch_dbg
> > because there is already a pch_dbg at the function who calls
> > pch_i2c_getack.
> > - Fixed message line issue
>
> I prefer this below "---" after Signed-off.
Ok i will change it next time.
>
> >
> > diff --git a/drivers/i2c/busses/i2c-eg20t.c b/drivers/i2c/busses/i2c-eg20t.c
> > index 0f37529..5c39f90 100644
> > --- a/drivers/i2c/busses/i2c-eg20t.c
> > +++ b/drivers/i2c/busses/i2c-eg20t.c
> > @@ -321,10 +321,8 @@ static s32 pch_i2c_getack(struct i2c_algo_pch_data *adap)
> > void __iomem *p = adap->pch_base_address;
> > reg_val = ioread32(p + PCH_I2CSR) & PCH_GETACK;
> >
> > - if (reg_val != 0) {
> > - pch_err(adap, "return%d\n", -EPROTO);
> > + if (reg_val != 0)
> > return -EPROTO;
>
> That could be fixed to -ENXIO according to
> Documentation/i2c/fault-codes.
Yes you are right -ENXIO should returned if no ACK was received.
Is there another reason why pch_i2c_getack returned EPROTO?
May be ENXIO was introduced later?
>
> > @@ -367,8 +365,7 @@ static int pch_i2c_wait_for_check_xfer(struct i2c_algo_pch_data *adap)
> > adap->pch_event_flag = 0;
> >
> > if (pch_i2c_getack(adap)) {
> > - pch_dbg(adap, "Receive NACK for slave address"
> > - "setting\n");
> > + pch_dbg(adap, "Receive NACK for slave address setting\n");
> > return -EIO;
>
> What about returning the value we got from pch_i2c_getack?
>
EIO is almost ok, because EIO means something went wrong when performing
an I/O operation, but yes we can return the value from pch_i2c_getack (ENXIO)
to get more detailed informations whats going wrong exactly (no ACK reveiced).
I think we can just replace the -EIO with -ENXIO or do you want to pick up the return
vale of pch_i2c_getack and return that ?
Regards
Andy
> Regards,
>
> Wolfram
>
^ permalink raw reply [flat|nested] 12+ messages in thread* Re: [PATCH v2] I2C: busses: i2c-eg20t Do not print error message in syslog if no ACK received
@ 2013-11-17 12:39 ` Andreas Werner
0 siblings, 0 replies; 12+ messages in thread
From: Andreas Werner @ 2013-11-17 12:39 UTC (permalink / raw)
To: Wolfram Sang
Cc: khali, jacmet, hskinnemoen, dianders, linux-i2c, linux-kernel
On Sun, Nov 17, 2013 at 12:08:46PM +0100, Wolfram Sang wrote:
> On Sun, Nov 17, 2013 at 09:58:51AM +0100, Andreas Werner wrote:
> > Revision 2:
> > - delete the pch_err completly instead of changing to pch_dbg
> > because there is already a pch_dbg at the function who calls
> > pch_i2c_getack.
> > - Fixed message line issue
>
> I prefer this below "---" after Signed-off.
Ok i will change it next time.
>
> >
> > diff --git a/drivers/i2c/busses/i2c-eg20t.c b/drivers/i2c/busses/i2c-eg20t.c
> > index 0f37529..5c39f90 100644
> > --- a/drivers/i2c/busses/i2c-eg20t.c
> > +++ b/drivers/i2c/busses/i2c-eg20t.c
> > @@ -321,10 +321,8 @@ static s32 pch_i2c_getack(struct i2c_algo_pch_data *adap)
> > void __iomem *p = adap->pch_base_address;
> > reg_val = ioread32(p + PCH_I2CSR) & PCH_GETACK;
> >
> > - if (reg_val != 0) {
> > - pch_err(adap, "return%d\n", -EPROTO);
> > + if (reg_val != 0)
> > return -EPROTO;
>
> That could be fixed to -ENXIO according to
> Documentation/i2c/fault-codes.
Yes you are right -ENXIO should returned if no ACK was received.
Is there another reason why pch_i2c_getack returned EPROTO?
May be ENXIO was introduced later?
>
> > @@ -367,8 +365,7 @@ static int pch_i2c_wait_for_check_xfer(struct i2c_algo_pch_data *adap)
> > adap->pch_event_flag = 0;
> >
> > if (pch_i2c_getack(adap)) {
> > - pch_dbg(adap, "Receive NACK for slave address"
> > - "setting\n");
> > + pch_dbg(adap, "Receive NACK for slave address setting\n");
> > return -EIO;
>
> What about returning the value we got from pch_i2c_getack?
>
EIO is almost ok, because EIO means something went wrong when performing
an I/O operation, but yes we can return the value from pch_i2c_getack (ENXIO)
to get more detailed informations whats going wrong exactly (no ACK reveiced).
I think we can just replace the -EIO with -ENXIO or do you want to pick up the return
vale of pch_i2c_getack and return that ?
Regards
Andy
> Regards,
>
> Wolfram
>
^ permalink raw reply [flat|nested] 12+ messages in thread* Re: [PATCH v2] I2C: busses: i2c-eg20t Do not print error message in syslog if no ACK received
2013-11-17 12:39 ` Andreas Werner
(?)
@ 2013-11-17 12:18 ` Wolfram Sang
2013-11-17 16:53 ` Andreas Werner
-1 siblings, 1 reply; 12+ messages in thread
From: Wolfram Sang @ 2013-11-17 12:18 UTC (permalink / raw)
To: Andreas Werner
Cc: khali, jacmet, hskinnemoen, dianders, linux-i2c, linux-kernel
[-- Attachment #1: Type: text/plain, Size: 411 bytes --]
> Is there another reason why pch_i2c_getack returned EPROTO?
> May be ENXIO was introduced later?
Imperfect review :)
> I think we can just replace the -EIO with -ENXIO or do you want to pick up the return
> vale of pch_i2c_getack and return that ?
The latter. As a rule of thumb, it is usually more sustainable to pass
through error codes. Overloading them should only be done when really
necessary IMO.
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 836 bytes --]
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v2] I2C: busses: i2c-eg20t Do not print error message in syslog if no ACK received
2013-11-17 12:18 ` Wolfram Sang
@ 2013-11-17 16:53 ` Andreas Werner
[not found] ` <20131117165329.GA1562-Zv899e0YUSYXU02nzanrWNbf9cGiqdzd@public.gmane.org>
0 siblings, 1 reply; 12+ messages in thread
From: Andreas Werner @ 2013-11-17 16:53 UTC (permalink / raw)
To: Wolfram Sang
Cc: khali, jacmet, hskinnemoen, dianders, linux-i2c, linux-kernel
On Sun, Nov 17, 2013 at 01:18:09PM +0100, Wolfram Sang wrote:
>
> > Is there another reason why pch_i2c_getack returned EPROTO?
> > May be ENXIO was introduced later?
>
> Imperfect review :)
>
> > I think we can just replace the -EIO with -ENXIO or do you want to pick up the return
> > vale of pch_i2c_getack and return that ?
>
> The latter. As a rule of thumb, it is usually more sustainable to pass
> through error codes. Overloading them should only be done when really
> necessary IMO.
>
Ok, if that will be ok in pch_i2c_wait_for_check_xfer i will resend
the patch.
ret = pch_i2c_getack(adap);
if (ret)
pch_dbg(adap, "Receive NACK for slave address setting\n");
return (int)ret;
Regards
Andy
^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2013-11-17 17:31 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-11-17 8:58 [PATCH v2] I2C: busses: i2c-eg20t Do not print error message in syslog if no ACK received Andreas Werner
2013-11-17 8:58 ` Andreas Werner
[not found] ` <1384678731-10399-1-git-send-email-wernerandy-Mmb7MZpHnFY@public.gmane.org>
2013-11-17 11:08 ` Wolfram Sang
2013-11-17 11:08 ` Wolfram Sang
2013-11-17 12:39 ` Andreas Werner
2013-11-17 12:39 ` Andreas Werner
2013-11-17 12:18 ` Wolfram Sang
2013-11-17 16:53 ` Andreas Werner
[not found] ` <20131117165329.GA1562-Zv899e0YUSYXU02nzanrWNbf9cGiqdzd@public.gmane.org>
2013-11-17 17:08 ` Wolfram Sang
2013-11-17 17:08 ` Wolfram Sang
2013-11-17 17:16 ` Andreas Werner
2013-11-17 17:31 ` Wolfram Sang
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.