From: Wolfgang Grandegger <wg@grandegger.com>
To: Alexander Stein <alexander.stein@systec-electronic.com>
Cc: linux-can@vger.kernel.org, bhupesh.sharma@st.com, tomoya.rohm@gmail.com
Subject: Re: [RFC v2 0/7] pch_can/c_can: fix races and add PCH support to c_can
Date: Wed, 05 Dec 2012 13:50:46 +0100 [thread overview]
Message-ID: <50BF4326.4040507@grandegger.com> (raw)
In-Reply-To: <2955657.EIGT0HjrVV@ws-stein>
Hi Alexander,
thanks for testing!. Maybe we deal with more than one problem.
On 12/05/2012 01:09 PM, Alexander Stein wrote:
> Hello Wolfgang and others,
>
> On Thursday 29 November 2012 15:39:40, Wolfgang Grandegger wrote:
>> here is v2 of my patches for the C_CAN drivers.
>>
>> For Michael I have prepared out-of-tree driver sources allowing to
>> easily build the drivers also for older 3.x kernel versions. More
>> tester are welcome.
>>
>> Changes since v1:
>>
>> - use init callback after renaming it from initram
>> - use different sets of interface registers for rx and tx (like PCH_CAN)
>> - use spin_[un]lock_bh to protect the tx objects
>>
>> Wolfgang Grandegger (7):
>> pch_can: add spinlocks to protect tx objects
>> c_can: rename callback "initram" to "init" to more general usage
>> c_can: use different sets of interface registers for rx and tx
>> c_can_pci: introduce board specific PCI bar
>> c_can_pci: enable PCI bus master only for MSI
>> c_can_pci: add support for PCH CAN on Intel EG20T PCH
>> c_can: add spinlock to protect tx and objects
>>
>> drivers/net/can/c_can/c_can.c | 66
> +++++++++++++++++++++-----------
>> drivers/net/can/c_can/c_can.h | 3 +-
>> drivers/net/can/c_can/c_can_pci.c | 56 +++++++++++++++++++++++++--
>> drivers/net/can/c_can/c_can_platform.c | 2 +-
>> drivers/net/can/pch_can.c | 9 +++++
>> 5 files changed, 108 insertions(+), 28 deletions(-)
>
> I backported the c_can patches incl. your patchset to v3.0.31 and tested this
> driver on our own custom atom board using the eg20t pch. CAN in general works,
The out-of-tree archive may have worked for you as well.
A few general questions to understand your hardware and setup:
- Is this a multi-processor system (SMP)? If not, you may not run into
tx-not-working-any-more problem. Have you ever realized it?
- Did you see the problems below with the old PCH_CAN driver as well.
- Do the problems show up with the still existing PCH_CAN driver
(including the "pch_can: add spinlocks to protect tx objects" patch)?
> but if I run my heavy CAN load testcase I get errors sometimes.
> This test works as follows: I send a CAN message to 2 other CAN nodes
> configuring some timings (like burst length or time between each can frame)
> and they send 250000 messages each containing a counter. This way I can detect
> any missing or switched message with a high bus load.
> If I use the described software state alone it works, but if I run 'watch
> sensors' in a different ssh session, CAN start to misbehave like missing CAN
> frames or switched order. It seems that I2C usage on the PCH influences the
> CAN part also:
- When your app sends/writes messages, does it check for errno==ENOBUFS?
- The messages look still ok (not currupted, I mean)?
> Even worse, if I use the following patch to check if PCI writes were
> successfully, I notices that some writes (or the consecutive read) don't
> succeed. And I also get lots of I2C timeouts waiting for a xfer complete.
Be careful, there might be some registers changing their values after
writing. Can you show the value read after writing and the register
offset? The influence on the I2C bus looks more like an overload or
hardware problem. What is your CAN interrupt rate?
Do you see this problem with the old PCH_CAN driver as well?
> Does anybody have an idea what's going wrong here? Is somebody able to see the
> same problems on their hardware?
At least you are the first one reporting this problem.
> Wolfgang: Compared to your v8 c_can drivers for Michael, I'm just missing the
> const bitrate table and don't use pci_register_driver, as I have cherry-picked
> the module_pci_driver patches.
What do you mean with "missing the const bitrate table"?
Wolfgang.
next prev parent reply other threads:[~2012-12-05 12:50 UTC|newest]
Thread overview: 38+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-11-29 14:39 [RFC v2 0/7] pch_can/c_can: fix races and add PCH support to c_can Wolfgang Grandegger
2012-11-29 14:39 ` [RFC v2 1/7] pch_can: add spinlocks to protect tx objects Wolfgang Grandegger
2012-11-29 14:39 ` [RFC v2 2/7] c_can: rename callback "initram" to "init" to more general usage Wolfgang Grandegger
2012-12-03 14:20 ` Alexander Stein
2012-12-03 14:32 ` Wolfgang Grandegger
2012-11-29 14:39 ` [RFC v2 3/7] c_can: use different sets of interface registers for rx and tx Wolfgang Grandegger
2012-11-30 8:39 ` Marc Kleine-Budde
2012-11-30 9:15 ` Wolfgang Grandegger
2012-11-29 14:39 ` [RFC v2 4/7] c_can_pci: introduce board specific PCI bar Wolfgang Grandegger
2012-11-30 8:45 ` Marc Kleine-Budde
2012-11-30 9:11 ` Wolfgang Grandegger
2012-11-30 9:19 ` Marc Kleine-Budde
2012-11-29 14:39 ` [RFC v2 5/7] c_can_pci: enable PCI bus master only for MSI Wolfgang Grandegger
2012-11-30 8:54 ` Marc Kleine-Budde
2012-11-29 14:39 ` [RFC v2 6/7] c_can_pci: add support for PCH CAN on Intel EG20T PCH Wolfgang Grandegger
2012-11-29 14:39 ` [RFC v2 7/7] c_can: add spinlock to protect tx and rx objects Wolfgang Grandegger
2012-12-05 12:09 ` [RFC v2 0/7] pch_can/c_can: fix races and add PCH support to c_can Alexander Stein
2012-12-05 12:50 ` Wolfgang Grandegger [this message]
2012-12-05 14:46 ` Alexander Stein
2012-12-05 17:35 ` Wolfgang Grandegger
2012-12-05 21:52 ` Marc Kleine-Budde
2012-12-06 7:09 ` Wolfgang Grandegger
2012-12-06 8:35 ` Marc Kleine-Budde
2012-12-06 8:17 ` Wolfgang Grandegger
2012-12-06 13:38 ` Alexander Stein
2012-12-06 14:02 ` Marc Kleine-Budde
2012-12-06 14:31 ` Wolfgang Grandegger
2012-12-06 14:37 ` Marc Kleine-Budde
2012-12-06 14:56 ` Alexander Stein
2012-12-06 15:15 ` Wolfgang Grandegger
2012-12-06 15:27 ` Wolfgang Grandegger
2012-12-06 15:55 ` Alexander Stein
2012-12-06 17:14 ` Alexander Stein
2012-12-06 23:34 ` Marc Kleine-Budde
2012-12-07 9:26 ` Wolfgang Grandegger
2012-12-07 9:55 ` Marc Kleine-Budde
2012-12-07 10:00 ` Bhupesh SHARMA
2012-12-07 10:09 ` Marc Kleine-Budde
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=50BF4326.4040507@grandegger.com \
--to=wg@grandegger.com \
--cc=alexander.stein@systec-electronic.com \
--cc=bhupesh.sharma@st.com \
--cc=linux-can@vger.kernel.org \
--cc=tomoya.rohm@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).