public inbox for ltp@lists.linux.it
 help / color / mirror / Atom feed
From: Oliver Hartkopp <socketcan@hartkopp.net>
To: Subrata Modak <subrata@linux.vnet.ibm.com>
Cc: SocketCAN Core Mailing List <socketcan-core@lists.berlios.de>,
	ltp-list <ltp-list@lists.sf.net>
Subject: [LTP] New LTP test for CAN packet flow
Date: Mon, 23 Aug 2010 20:23:16 +0200	[thread overview]
Message-ID: <4C72BC94.1090608@hartkopp.net> (raw)

Dear Subrata,

long time - no update ;-)

But now i created a test that's able to detect a corrupt CAN frame flow inside
the Kernel. So far the correct IFF_ECHO functionality has been accidentally
removed by netdev patches two times.

The latest fix was here:

http://git.kernel.org/?p=linux/kernel/git/davem/net-2.6.git;a=commitdiff;h=cff0d6e6edac7672b3f915bb4fb59f279243b7f9

To perform the local echo of CAN frames, the reference to the originating sock
struct has to be passed to the netdevice without orphan of the socketbuffer.

The new test tool 'tst-rcv-own-msgs' can check the correct packet flow by
creating two can-raw sockets.

To extend your test-script in

    network/can/filter-tests/run_ltp-can_tests.sh

the modprobe of the vcan driver needs an additional parameter 'echo=1', which
configures the driver to perform the CAN frame echo on driver level.

This 'echo=1' setting does not have any impact to the filtertest performed in
your script.

The new tool 'tst-rcv-own-msgs' can be found in the same directory in the
SocketCAN SVN where the current 'tst-filter-server' and 'tst-filter-master'
tools are located too.

I'll send the latest fix (see above) to the stable tree, as 2.6.35.3 currently
still *has* this problem.

On 2.6.35.3 you can see 'tst-rcv-own-msgs' ...

   - work correctly when echo=0
   - will fail when echo=1

On 2.6.36-rc1 'tst-rcv-own-msgs' runs successfully regardless of the 'echo'
setting of the vcan driver.

Please give me feedback, if there are still open questions.

Many thanks for your work & best regards,
Oliver


---

Load vcan module with commandline parameter echo=1 :

root@host:~# modprobe vcan echo=1
root@host:~# ip link add dev vcan0 type vcan
root@host:~# ip link set vcan0 up

---

When the test is successful, it looks like this:

user@host:~$ socketcan/trunk/test/tst-rcv-own-msgs vcan0
Starting PF_CAN frame flow test.
checking socket default settings ... ok.
check loopback 0 recv_own_msgs 0 ... ok.
check loopback 0 recv_own_msgs 1 ... ok.
check loopback 1 recv_own_msgs 0 ... ok.
check loopback 1 recv_own_msgs 1 ... ok.
PF_CAN frame flow test was successful.
user@host:~$ echo $?
0
user@host:~$

---

When the test fails, it looks like this:

user@host:~$ socketcan/trunk/test/tst-rcv-own-msgs vcan0
Starting PF_CAN frame flow test.
checking socket default settings ... failure!
user@host:~$ echo $?
1
user@host:~$

---


------------------------------------------------------------------------------
Sell apps to millions through the Intel(R) Atom(Tm) Developer Program
Be part of this innovative community and reach millions of netbook users 
worldwide. Take advantage of special opportunities to increase revenue and 
speed time-to-market. Join now, and jumpstart your future.
http://p.sf.net/sfu/intel-atom-d2d
_______________________________________________
Ltp-list mailing list
Ltp-list@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/ltp-list

             reply	other threads:[~2010-08-23 18:48 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-08-23 18:23 Oliver Hartkopp [this message]
2010-08-24  7:14 ` [LTP] New LTP test for CAN packet flow Subrata Modak
2010-09-06 16:17   ` Subrata Modak

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=4C72BC94.1090608@hartkopp.net \
    --to=socketcan@hartkopp.net \
    --cc=ltp-list@lists.sf.net \
    --cc=socketcan-core@lists.berlios.de \
    --cc=subrata@linux.vnet.ibm.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