Yes, the braces is necessary and I can adjust it's place by other tool such
as "indent".
For now , your code is good enough.
Thank you.
----------------------------------------------
From: Julia Lawall
Sent: Monday, June 18, 2012 9:21 PM
To: yafo lee
Cc: [email protected]
Subject: Re: [Cocci] How to replace a macro?
@@
identifier ha;
identifier netdev;
iterator name TAILQ_FOREACH;
iterator name netdev_for_each_mc_addr;
statement S;
@@
+ TAILQ_FOREACH(ha, &netdev->if_multiaddrs, ifma_link) {
- netdev_for_each_mc_addr(ha, netdev)
S
+ }
The closing brace does not come out so well placed. Do you actually want
to add braces?
julia
On Mon, 18 Jun 2012, yafo lee wrote:
Hi Julia,
It can eliminate the error message, but still can not get a match:
init_defs_builtins: /usr/local/share/coccinelle/standard.h
HANDLING: test.c
the complete code I want to convert:
static void alx_set_multicase_list(struct net_device *netdev)
{
struct alx_adapter *adpt = netdev_priv(netdev);
struct alx_hw *hw = &adpt->hw;
struct netdev_hw_addr *ha;
/* Check for Promiscuous and All Multicast modes */
if (netdev->flags & IFF_PROMISC) {
SET_HW_FLAG(PROMISC_EN);
} else if (netdev->flags & IFF_ALLMULTI) {
SET_HW_FLAG(MULTIALL_EN);
CLI_HW_FLAG(PROMISC_EN);
} else {
CLI_HW_FLAG(MULTIALL_EN);
CLI_HW_FLAG(PROMISC_EN);
}
hw->cbs.config_mac_ctrl(hw);
/* clear the old settings from the multicast hash table */
hw->cbs.clear_mc_addr(hw);
/* comoute mc addresses' hash value ,and put it into hash table */
netdev_for_each_mc_addr(ha, netdev)
hw->cbs.set_mc_addr(hw, ha->addr);
}
--------------------------------------------------------- From: Julia
Lawall
Sent: Monday, June 18, 2012 1:46 PM
To: yafo lee
Cc: [email protected]
Subject: Re: [Cocci] How to replace a macro?
On Mon, 18 Jun 2012, yafo lee wrote:
> Hi guys, I have the following code:
>
> netdev_for_each_mc_addr(ha, netdev)
> hw->cbs.set_mc_addr(hw, ha->addr);
>
>
> And I want it to be converted to:
>
> TAILQ_FOREACH(ha, &netdev->if_multiaddrs, ifma_link) {
> if (ha->ifma_addr->sa_family != AF_LINK)
> continue;
>
> hw->cbs.set_mc_addr(hw,
> LLADDR((struct sockaddr_dl *)ha->ifma_addr));
> }
>
>
> Any suggests?
> I've try :
>
> @@
> identifier ha;
> identifier netdev;
> declarer name TAILQ_FOREACH;
iterator name, not declarer name.
julia
>
> @@
> + TAILQ_FOREACH(ha, &netdev->if_multiaddrs, ifma_link) {
> - netdev_for_each_mc_addr(ha, netdev)
> ...;
> + }
>
> but get error:
>
> init_defs_builtins: /usr/local/share/coccinelle/standard.h
> 125 126
> Fatal error: exception Failure("plus: parse error:
> = File "c1.cocci", line 7, column 55, charpos = 125
> around = '{', whole content = + TAILQ_FOREACH(ha,
> &netdev->if_multiaddrs,
> ifma_link) {
> ")
>
>
> Thanks. _______________________________________________
> Cocci mailing list
> [email protected]
> http://lists.diku.dk/mailman/listinfo/cocci
> (Web access from inside DIKUs LAN only)
>
_______________________________________________
Cocci mailing list
[email protected]
http://lists.diku.dk/mailman/listinfo/cocci
(Web access from inside DIKUs LAN only)