From: riccardo.lucchese@gmail.com (Riccardo Lucchese)
To: cocci@systeme.lip6.fr
Subject: [Cocci] Exception "try to delete an expanded token: {" and C macros
Date: Tue, 22 Jul 2014 19:03:45 +0200 [thread overview]
Message-ID: <20140722170345.GB4986@rlp> (raw)
In-Reply-To: <alpine.DEB.2.10.1407221813400.2366@hadrien>
On Tue, Jul 22, 2014 at 06:17:10PM +0200, Julia Lawall wrote:
>
>
> On Tue, 22 Jul 2014, Riccardo Lucchese wrote:
>
> > Hello,
> >
> > Running the command (semantic patch is attached)
> >
> > $ spatch --sp-file macro-err.cocci --dir drivers/staging/octeon-usb/octeon-hcd.c
> >
> > from the root dir of linux-next-20140721, yields the following error:
> >
> > init_defs_builtins: /usr/local/share/coccinelle/standard.h
> > HANDLING: drivers/staging/octeon-usb/octeon-hcd.c
> > Fatal error: exception Failure("drivers/staging/octeon-usb/octeon-hcd.c: 429: try to delete an expanded token: {")
> >
> >
> > The code around where the exception happens (--->) reads:
> >
> > /* This macro spins on a field waiting for it to reach a value */
> > #define CVMX_WAIT_FOR_FIELD32(address, type, field, op, value, timeout_usec)\
> > ---> ({int result; \
> > do { \
> > uint64_t done = cvmx_get_cycle() + (uint64_t)timeout_usec * \
> > octeon_get_clock_rate() / 1000000; \
> > type c; \
> > while (1) { \
> > c.u32 = __cvmx_usb_read_csr32(usb, address); \
> > if (c.s.field op (value)) { \
> > result = 0; \
> > break; \
> > } else if (cvmx_get_cycle() > done) { \
> > result = -1; \
> > break; \
> > } else \
> > cvmx_wait(100); \
> > } \
> > } while (0); \
> > result; })
> >
> >
> > Should I change something in my invocation to deal with this macro ?
>
> One solution is to add the following command-line argument:
> --disable-multi-pass
>
> Then it will not try to take macros into account on a parse failure. But
> there may be other macros whose definitions do need to be taken into
> account to get parsing to succeed.
>
> Another option is to extend standard.h with
>
> #define CVMX_WAIT_FOR_FIELD32(a,b,c,d,e,f)
>
> and then give the resulting file with the argument --macro-file-builtins.
> That will make it use your standard.h definition before it tries the real
> definition.
>
> julia
I see. Thanks !
riccardo
prev parent reply other threads:[~2014-07-22 17:03 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-07-21 23:25 [Cocci] Exception "try to delete an expanded token: {" and C macros Riccardo Lucchese
2014-07-22 16:17 ` Julia Lawall
2014-07-22 17:03 ` Riccardo Lucchese [this message]
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=20140722170345.GB4986@rlp \
--to=riccardo.lucchese@gmail.com \
--cc=cocci@systeme.lip6.fr \
/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 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.