Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 184527
b: refs/heads/master
c: 773c3e7
h: refs/heads/master
i:
  184525: 6e082b5
  184523: 7ba108e
  184519: 3ebdbe0
  184511: 4c941b0
v: v3
  • Loading branch information
Sriramakrishnan authored and David S. Miller committed Feb 26, 2010
1 parent 85a95bc commit 187574e
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 4 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 738b0343e73604750feb107e063c28b3ca36cb84
refs/heads/master: 773c3e75d1fc7ea5058bfeab5d82bac5b85f8cd8
17 changes: 16 additions & 1 deletion trunk/drivers/net/can/ti_hecc.c
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,11 @@
* .mbx_offset = 0x2000,
* .int_line = 0,
* .revision = 1,
* .transceiver_switch = hecc_phy_control,
* };
*
* Please see include/can/platform/ti_hecc.h for description of above fields
* Please see include/linux/can/platform/ti_hecc.h for description of
* above fields.
*
*/

Expand Down Expand Up @@ -220,6 +222,7 @@ struct ti_hecc_priv {
u32 tx_head;
u32 tx_tail;
u32 rx_next;
void (*transceiver_switch)(int);
};

static inline int get_tx_head_mb(struct ti_hecc_priv *priv)
Expand Down Expand Up @@ -317,6 +320,13 @@ static int ti_hecc_set_btc(struct ti_hecc_priv *priv)
return 0;
}

static void ti_hecc_transceiver_switch(const struct ti_hecc_priv *priv,
int on)
{
if (priv->transceiver_switch)
priv->transceiver_switch(on);
}

static void ti_hecc_reset(struct net_device *ndev)
{
u32 cnt;
Expand Down Expand Up @@ -818,10 +828,13 @@ static int ti_hecc_open(struct net_device *ndev)
return err;
}

ti_hecc_transceiver_switch(priv, 1);

/* Open common can device */
err = open_candev(ndev);
if (err) {
dev_err(ndev->dev.parent, "open_candev() failed %d\n", err);
ti_hecc_transceiver_switch(priv, 0);
free_irq(ndev->irq, ndev);
return err;
}
Expand All @@ -842,6 +855,7 @@ static int ti_hecc_close(struct net_device *ndev)
ti_hecc_stop(ndev);
free_irq(ndev->irq, ndev);
close_candev(ndev);
ti_hecc_transceiver_switch(priv, 0);

return 0;
}
Expand Down Expand Up @@ -903,6 +917,7 @@ static int ti_hecc_probe(struct platform_device *pdev)
priv->hecc_ram_offset = pdata->hecc_ram_offset;
priv->mbx_offset = pdata->mbx_offset;
priv->int_line = pdata->int_line;
priv->transceiver_switch = pdata->transceiver_switch;

priv->can.bittiming_const = &ti_hecc_bittiming_const;
priv->can.do_set_mode = ti_hecc_do_set_mode;
Expand Down
8 changes: 6 additions & 2 deletions trunk/include/linux/can/platform/ti_hecc.h
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
#ifndef __CAN_PLATFORM_TI_HECC_H__
#define __CAN_PLATFORM_TI_HECC_H__

/*
* TI HECC (High End CAN Controller) driver platform header
*
Expand All @@ -23,6 +26,7 @@
* @mbx_offset: Mailbox RAM offset
* @int_line: Interrupt line to use - 0 or 1
* @version: version for future use
* @transceiver_switch: platform specific callback fn for transceiver control
*
* Platform data structure to get all platform specific settings.
* this structure also accounts the fact that the IP may have different
Expand All @@ -35,6 +39,6 @@ struct ti_hecc_platform_data {
u32 mbx_offset;
u32 int_line;
u32 version;
void (*transceiver_switch) (int);
};


#endif

0 comments on commit 187574e

Please sign in to comment.