[PATCH] WAN/pc300: handle, propagate minor errors
- move definition of 'tmc' and 'br' locals closer to usage - handle clock_rate_calc() error - propagate errors back to upper level open routine Signed-off-by: Jeff Garzik <jeff@garzik.org> Cc: Krzysztof Halasa <khc@pm.waw.pl> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Jeff Garzik <jeff@garzik.org>
This commit is contained in:
parent
718ecac2ed
commit
6f0f6d87a2
1 changed files with 19 additions and 5 deletions
|
@ -2867,7 +2867,6 @@ static int ch_config(pc300dev_t * d)
|
||||||
uclong clktype = chan->conf.phys_settings.clock_type;
|
uclong clktype = chan->conf.phys_settings.clock_type;
|
||||||
ucshort encoding = chan->conf.proto_settings.encoding;
|
ucshort encoding = chan->conf.proto_settings.encoding;
|
||||||
ucshort parity = chan->conf.proto_settings.parity;
|
ucshort parity = chan->conf.proto_settings.parity;
|
||||||
int tmc, br;
|
|
||||||
ucchar md0, md2;
|
ucchar md0, md2;
|
||||||
|
|
||||||
/* Reset the channel */
|
/* Reset the channel */
|
||||||
|
@ -2940,8 +2939,12 @@ static int ch_config(pc300dev_t * d)
|
||||||
case PC300_RSV:
|
case PC300_RSV:
|
||||||
case PC300_X21:
|
case PC300_X21:
|
||||||
if (clktype == CLOCK_INT || clktype == CLOCK_TXINT) {
|
if (clktype == CLOCK_INT || clktype == CLOCK_TXINT) {
|
||||||
|
int tmc, br;
|
||||||
|
|
||||||
/* Calculate the clkrate parameters */
|
/* Calculate the clkrate parameters */
|
||||||
tmc = clock_rate_calc(clkrate, card->hw.clock, &br);
|
tmc = clock_rate_calc(clkrate, card->hw.clock, &br);
|
||||||
|
if (tmc < 0)
|
||||||
|
return -EIO;
|
||||||
cpc_writeb(scabase + M_REG(TMCT, ch), tmc);
|
cpc_writeb(scabase + M_REG(TMCT, ch), tmc);
|
||||||
cpc_writeb(scabase + M_REG(TXS, ch),
|
cpc_writeb(scabase + M_REG(TXS, ch),
|
||||||
(TXS_DTRXC | TXS_IBRG | br));
|
(TXS_DTRXC | TXS_IBRG | br));
|
||||||
|
@ -3097,14 +3100,16 @@ static int cpc_attach(struct net_device *dev, unsigned short encoding,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cpc_opench(pc300dev_t * d)
|
static int cpc_opench(pc300dev_t * d)
|
||||||
{
|
{
|
||||||
pc300ch_t *chan = (pc300ch_t *) d->chan;
|
pc300ch_t *chan = (pc300ch_t *) d->chan;
|
||||||
pc300_t *card = (pc300_t *) chan->card;
|
pc300_t *card = (pc300_t *) chan->card;
|
||||||
int ch = chan->channel;
|
int ch = chan->channel, rc;
|
||||||
void __iomem *scabase = card->hw.scabase;
|
void __iomem *scabase = card->hw.scabase;
|
||||||
|
|
||||||
ch_config(d);
|
rc = ch_config(d);
|
||||||
|
if (rc)
|
||||||
|
return rc;
|
||||||
|
|
||||||
rx_config(d);
|
rx_config(d);
|
||||||
|
|
||||||
|
@ -3113,6 +3118,8 @@ static void cpc_opench(pc300dev_t * d)
|
||||||
/* Assert RTS and DTR */
|
/* Assert RTS and DTR */
|
||||||
cpc_writeb(scabase + M_REG(CTL, ch),
|
cpc_writeb(scabase + M_REG(CTL, ch),
|
||||||
cpc_readb(scabase + M_REG(CTL, ch)) & ~(CTL_RTS | CTL_DTR));
|
cpc_readb(scabase + M_REG(CTL, ch)) & ~(CTL_RTS | CTL_DTR));
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cpc_closech(pc300dev_t * d)
|
static void cpc_closech(pc300dev_t * d)
|
||||||
|
@ -3168,9 +3175,16 @@ int cpc_open(struct net_device *dev)
|
||||||
}
|
}
|
||||||
|
|
||||||
sprintf(ifr.ifr_name, "%s", dev->name);
|
sprintf(ifr.ifr_name, "%s", dev->name);
|
||||||
cpc_opench(d);
|
result = cpc_opench(d);
|
||||||
|
if (result)
|
||||||
|
goto err_out;
|
||||||
|
|
||||||
netif_start_queue(dev);
|
netif_start_queue(dev);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
err_out:
|
||||||
|
hdlc_close(dev);
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int cpc_close(struct net_device *dev)
|
static int cpc_close(struct net_device *dev)
|
||||||
|
|
Loading…
Add table
Reference in a new issue