Re: [PATCH 1/2] serial: samsung: Remove NULL checking for baud clock

2012-06-20 Thread Greg KH
On Wed, Jun 20, 2012 at 01:28:36PM +0900, Kukjin Kim wrote:
> Kukjin Kim wrote:
> > 
> > Kyoungil Kim wrote:
> > >
> > > Kyoungil Kim wrote:
> > >
> > > I missed following.
> > >
> > > Russell King suggested:
> > >
> > > As I said, drivers have no business interpreting anything but
> IS_ERR(clk)
> > > as being an error.  They should not make any other
> > > assumptions.
> > >
> > > Suggested-by: Russell King 
> > >
> > > > Signed-off-by: Kyoungil Kim 
> > > > ---
> > > >  drivers/tty/serial/samsung.c |   21 -
> > > >  1 files changed, 12 insertions(+), 9 deletions(-)
> > > >
> > > > diff --git a/drivers/tty/serial/samsung.c
> > b/drivers/tty/serial/samsung.c
> > > > index d8b0aee..5668538 100644
> > > > --- a/drivers/tty/serial/samsung.c
> > > > +++ b/drivers/tty/serial/samsung.c
> > > > @@ -529,7 +529,7 @@ static void s3c24xx_serial_pm(struct uart_port
> > *port,
> > > unsigned int level,
> > > >
> > > > switch (level) {
> > > > case 3:
> > > > -   if (!IS_ERR(ourport->baudclk) && ourport->baudclk != 
> > > > NULL)
> > > > +   if (!IS_ERR(ourport->baudclk))
> > > > clk_disable(ourport->baudclk);
> > > >
> > > > clk_disable(ourport->clk);
> > > > @@ -538,7 +538,7 @@ static void s3c24xx_serial_pm(struct uart_port
> > *port,
> > > unsigned int level,
> > > > case 0:
> > > > clk_enable(ourport->clk);
> > > >
> > > > -   if (!IS_ERR(ourport->baudclk) && ourport->baudclk != 
> > > > NULL)
> > > > +   if (!IS_ERR(ourport->baudclk))
> > > > clk_enable(ourport->baudclk);
> > > >
> > > > break;
> > > > @@ -604,7 +604,6 @@ static unsigned int s3c24xx_serial_getclk(struct
> > > s3c24xx_uart_port *ourport,
> > > > char clkname[MAX_CLK_NAME_LENGTH];
> > > > int calc_deviation, deviation = (1 << 30) - 1;
> > > >
> > > > -   *best_clk = NULL;
> > > > clk_sel = (ourport->cfg->clk_sel) ? ourport->cfg->clk_sel :
> > > > ourport->info->def_clk_sel;
> > > > for (cnt = 0; cnt < info->num_clks; cnt++) {
> > > > @@ -613,7 +612,7 @@ static unsigned int s3c24xx_serial_getclk(struct
> > > s3c24xx_uart_port *ourport,
> > > >
> > > > sprintf(clkname, "clk_uart_baud%d", cnt);
> > > > clk = clk_get(ourport->port.dev, clkname);
> > > > -   if (IS_ERR_OR_NULL(clk))
> > > > +   if (IS_ERR(clk))
> > > > continue;
> > > >
> > > > rate = clk_get_rate(clk);
> > > > @@ -684,7 +683,7 @@ static void s3c24xx_serial_set_termios(struct
> > > uart_port *port,
> > > >  {
> > > > struct s3c2410_uartcfg *cfg = s3c24xx_port_to_cfg(port);
> > > > struct s3c24xx_uart_port *ourport = to_ourport(port);
> > > > -   struct clk *clk = NULL;
> > > > +   struct clk *clk = ERR_PTR(-EINVAL);
> > > > unsigned long flags;
> > > > unsigned int baud, quot, clk_sel = 0;
> > > > unsigned int ulcon;
> > > > @@ -705,7 +704,7 @@ static void s3c24xx_serial_set_termios(struct
> > > uart_port *port,
> > > > quot = s3c24xx_serial_getclk(ourport, baud, &clk, &clk_sel);
> > > > if (baud == 38400 && (port->flags & UPF_SPD_MASK) == 
> > > > UPF_SPD_CUST)
> > > > quot = port->custom_divisor;
> > > > -   if (!clk)
> > > > +   if (IS_ERR(clk))
> > > > return;
> > > >
> > > > /* check to see if we need  to change clock source */
> > > > @@ -713,9 +712,9 @@ static void s3c24xx_serial_set_termios(struct
> > > uart_port *port,
> > > > if (ourport->baudclk != clk) {
> > > > s3c24xx_serial_setsource(port, clk_sel);
> > > >
> > > > -   if (ourport->baudclk != NULL && 
> > > > !IS_ERR(ourport->baudclk)) {
> > > > +   if (!IS_ERR(ourport->baudclk)) {
> > > > clk_disable(ourport->baudclk);
> > > > -   ourport->baudclk  = NULL;
> > > > +   ourport->baudclk = ERR_PTR(-EINVAL);
> > > > }
> > > >
> > > > clk_enable(clk);
> > > > @@ -1160,6 +1159,9 @@ static ssize_t s3c24xx_serial_show_clksrc(struct
> > > device *dev,
> > > > struct uart_port *port = s3c24xx_dev_to_port(dev);
> > > > struct s3c24xx_uart_port *ourport = to_ourport(port);
> > > >
> > > > +   if (IS_ERR(ourport->baudclk))
> > > > +   return -EINVAL;
> > > > +
> > > > return snprintf(buf, PAGE_SIZE, "* %s\n", 
> > > > ourport->baudclk->name);
> > > >  }
> > > >
> > > > @@ -1200,6 +1202,7 @@ static int s3c24xx_serial_probe(struct
> > > platform_device *pdev)
> > > > return -ENODEV;
> > > > }
> > > >
> > > > +   ourport->baudclk = ERR_PTR(-EINVAL);
> > > > ourport->info = ourport->drv_data->info;
> > > > ourport->cfg = (pdev->dev.platform_data) ?
> > > > 

RE: [PATCH 1/2] serial: samsung: Remove NULL checking for baud clock

2012-06-19 Thread Kukjin Kim
Kukjin Kim wrote:
> 
> Kyoungil Kim wrote:
> >
> > Kyoungil Kim wrote:
> >
> > I missed following.
> >
> > Russell King suggested:
> >
> > As I said, drivers have no business interpreting anything but
IS_ERR(clk)
> > as being an error.  They should not make any other
> > assumptions.
> >
> > Suggested-by: Russell King 
> >
> > > Signed-off-by: Kyoungil Kim 
> > > ---
> > >  drivers/tty/serial/samsung.c |   21 -
> > >  1 files changed, 12 insertions(+), 9 deletions(-)
> > >
> > > diff --git a/drivers/tty/serial/samsung.c
> b/drivers/tty/serial/samsung.c
> > > index d8b0aee..5668538 100644
> > > --- a/drivers/tty/serial/samsung.c
> > > +++ b/drivers/tty/serial/samsung.c
> > > @@ -529,7 +529,7 @@ static void s3c24xx_serial_pm(struct uart_port
> *port,
> > unsigned int level,
> > >
> > >   switch (level) {
> > >   case 3:
> > > - if (!IS_ERR(ourport->baudclk) && ourport->baudclk != NULL)
> > > + if (!IS_ERR(ourport->baudclk))
> > >   clk_disable(ourport->baudclk);
> > >
> > >   clk_disable(ourport->clk);
> > > @@ -538,7 +538,7 @@ static void s3c24xx_serial_pm(struct uart_port
> *port,
> > unsigned int level,
> > >   case 0:
> > >   clk_enable(ourport->clk);
> > >
> > > - if (!IS_ERR(ourport->baudclk) && ourport->baudclk != NULL)
> > > + if (!IS_ERR(ourport->baudclk))
> > >   clk_enable(ourport->baudclk);
> > >
> > >   break;
> > > @@ -604,7 +604,6 @@ static unsigned int s3c24xx_serial_getclk(struct
> > s3c24xx_uart_port *ourport,
> > >   char clkname[MAX_CLK_NAME_LENGTH];
> > >   int calc_deviation, deviation = (1 << 30) - 1;
> > >
> > > - *best_clk = NULL;
> > >   clk_sel = (ourport->cfg->clk_sel) ? ourport->cfg->clk_sel :
> > >   ourport->info->def_clk_sel;
> > >   for (cnt = 0; cnt < info->num_clks; cnt++) {
> > > @@ -613,7 +612,7 @@ static unsigned int s3c24xx_serial_getclk(struct
> > s3c24xx_uart_port *ourport,
> > >
> > >   sprintf(clkname, "clk_uart_baud%d", cnt);
> > >   clk = clk_get(ourport->port.dev, clkname);
> > > - if (IS_ERR_OR_NULL(clk))
> > > + if (IS_ERR(clk))
> > >   continue;
> > >
> > >   rate = clk_get_rate(clk);
> > > @@ -684,7 +683,7 @@ static void s3c24xx_serial_set_termios(struct
> > uart_port *port,
> > >  {
> > >   struct s3c2410_uartcfg *cfg = s3c24xx_port_to_cfg(port);
> > >   struct s3c24xx_uart_port *ourport = to_ourport(port);
> > > - struct clk *clk = NULL;
> > > + struct clk *clk = ERR_PTR(-EINVAL);
> > >   unsigned long flags;
> > >   unsigned int baud, quot, clk_sel = 0;
> > >   unsigned int ulcon;
> > > @@ -705,7 +704,7 @@ static void s3c24xx_serial_set_termios(struct
> > uart_port *port,
> > >   quot = s3c24xx_serial_getclk(ourport, baud, &clk, &clk_sel);
> > >   if (baud == 38400 && (port->flags & UPF_SPD_MASK) == UPF_SPD_CUST)
> > >   quot = port->custom_divisor;
> > > - if (!clk)
> > > + if (IS_ERR(clk))
> > >   return;
> > >
> > >   /* check to see if we need  to change clock source */
> > > @@ -713,9 +712,9 @@ static void s3c24xx_serial_set_termios(struct
> > uart_port *port,
> > >   if (ourport->baudclk != clk) {
> > >   s3c24xx_serial_setsource(port, clk_sel);
> > >
> > > - if (ourport->baudclk != NULL && !IS_ERR(ourport->baudclk)) {
> > > + if (!IS_ERR(ourport->baudclk)) {
> > >   clk_disable(ourport->baudclk);
> > > - ourport->baudclk  = NULL;
> > > + ourport->baudclk = ERR_PTR(-EINVAL);
> > >   }
> > >
> > >   clk_enable(clk);
> > > @@ -1160,6 +1159,9 @@ static ssize_t s3c24xx_serial_show_clksrc(struct
> > device *dev,
> > >   struct uart_port *port = s3c24xx_dev_to_port(dev);
> > >   struct s3c24xx_uart_port *ourport = to_ourport(port);
> > >
> > > + if (IS_ERR(ourport->baudclk))
> > > + return -EINVAL;
> > > +
> > >   return snprintf(buf, PAGE_SIZE, "* %s\n", ourport->baudclk->name);
> > >  }
> > >
> > > @@ -1200,6 +1202,7 @@ static int s3c24xx_serial_probe(struct
> > platform_device *pdev)
> > >   return -ENODEV;
> > >   }
> > >
> > > + ourport->baudclk = ERR_PTR(-EINVAL);
> > >   ourport->info = ourport->drv_data->info;
> > >   ourport->cfg = (pdev->dev.platform_data) ?
> > >   (struct s3c2410_uartcfg *)pdev->dev.platform_data :
> > > @@ -1387,7 +1390,7 @@ s3c24xx_serial_get_options(struct uart_port
> *port,
> > int *baud,
> > >   sprintf(clk_name, "clk_uart_baud%d", clk_sel);
> > >
> > >   clk = clk_get(port->dev, clk_name);
> > > - if (!IS_ERR(clk) && clk != NULL)
> > > + if (!IS_ERR(clk))
> > >   rate = clk_get_rate(clk);
> > >   else
> > >   rate = 1;
> > > --
> > > 1.7.1
> 
> Looks ok to me, will apply.
> Thanks.
> 
(Cc'ed Greg)

I think, would be better if Greg could pick this up in his tree.

Acked-by: Kukjin Kim 

Thanks.

Best regards,
Kgene.
--
Kukjin Kim , Senior Eng

RE: [PATCH 1/2] serial: samsung: Remove NULL checking for baud clock

2012-06-19 Thread Kukjin Kim
Kyoungil Kim wrote:
> 
> Kyoungil Kim wrote:
> 
> I missed following.
> 
> Russell King suggested:
> 
> As I said, drivers have no business interpreting anything but IS_ERR(clk)
> as being an error.  They should not make any other
> assumptions.
> 
> Suggested-by: Russell King 
> 
> > Signed-off-by: Kyoungil Kim 
> > ---
> >  drivers/tty/serial/samsung.c |   21 -
> >  1 files changed, 12 insertions(+), 9 deletions(-)
> >
> > diff --git a/drivers/tty/serial/samsung.c b/drivers/tty/serial/samsung.c
> > index d8b0aee..5668538 100644
> > --- a/drivers/tty/serial/samsung.c
> > +++ b/drivers/tty/serial/samsung.c
> > @@ -529,7 +529,7 @@ static void s3c24xx_serial_pm(struct uart_port
*port,
> unsigned int level,
> >
> > switch (level) {
> > case 3:
> > -   if (!IS_ERR(ourport->baudclk) && ourport->baudclk != NULL)
> > +   if (!IS_ERR(ourport->baudclk))
> > clk_disable(ourport->baudclk);
> >
> > clk_disable(ourport->clk);
> > @@ -538,7 +538,7 @@ static void s3c24xx_serial_pm(struct uart_port
*port,
> unsigned int level,
> > case 0:
> > clk_enable(ourport->clk);
> >
> > -   if (!IS_ERR(ourport->baudclk) && ourport->baudclk != NULL)
> > +   if (!IS_ERR(ourport->baudclk))
> > clk_enable(ourport->baudclk);
> >
> > break;
> > @@ -604,7 +604,6 @@ static unsigned int s3c24xx_serial_getclk(struct
> s3c24xx_uart_port *ourport,
> > char clkname[MAX_CLK_NAME_LENGTH];
> > int calc_deviation, deviation = (1 << 30) - 1;
> >
> > -   *best_clk = NULL;
> > clk_sel = (ourport->cfg->clk_sel) ? ourport->cfg->clk_sel :
> > ourport->info->def_clk_sel;
> > for (cnt = 0; cnt < info->num_clks; cnt++) {
> > @@ -613,7 +612,7 @@ static unsigned int s3c24xx_serial_getclk(struct
> s3c24xx_uart_port *ourport,
> >
> > sprintf(clkname, "clk_uart_baud%d", cnt);
> > clk = clk_get(ourport->port.dev, clkname);
> > -   if (IS_ERR_OR_NULL(clk))
> > +   if (IS_ERR(clk))
> > continue;
> >
> > rate = clk_get_rate(clk);
> > @@ -684,7 +683,7 @@ static void s3c24xx_serial_set_termios(struct
> uart_port *port,
> >  {
> > struct s3c2410_uartcfg *cfg = s3c24xx_port_to_cfg(port);
> > struct s3c24xx_uart_port *ourport = to_ourport(port);
> > -   struct clk *clk = NULL;
> > +   struct clk *clk = ERR_PTR(-EINVAL);
> > unsigned long flags;
> > unsigned int baud, quot, clk_sel = 0;
> > unsigned int ulcon;
> > @@ -705,7 +704,7 @@ static void s3c24xx_serial_set_termios(struct
> uart_port *port,
> > quot = s3c24xx_serial_getclk(ourport, baud, &clk, &clk_sel);
> > if (baud == 38400 && (port->flags & UPF_SPD_MASK) == UPF_SPD_CUST)
> > quot = port->custom_divisor;
> > -   if (!clk)
> > +   if (IS_ERR(clk))
> > return;
> >
> > /* check to see if we need  to change clock source */
> > @@ -713,9 +712,9 @@ static void s3c24xx_serial_set_termios(struct
> uart_port *port,
> > if (ourport->baudclk != clk) {
> > s3c24xx_serial_setsource(port, clk_sel);
> >
> > -   if (ourport->baudclk != NULL && !IS_ERR(ourport->baudclk)) {
> > +   if (!IS_ERR(ourport->baudclk)) {
> > clk_disable(ourport->baudclk);
> > -   ourport->baudclk  = NULL;
> > +   ourport->baudclk = ERR_PTR(-EINVAL);
> > }
> >
> > clk_enable(clk);
> > @@ -1160,6 +1159,9 @@ static ssize_t s3c24xx_serial_show_clksrc(struct
> device *dev,
> > struct uart_port *port = s3c24xx_dev_to_port(dev);
> > struct s3c24xx_uart_port *ourport = to_ourport(port);
> >
> > +   if (IS_ERR(ourport->baudclk))
> > +   return -EINVAL;
> > +
> > return snprintf(buf, PAGE_SIZE, "* %s\n", ourport->baudclk->name);
> >  }
> >
> > @@ -1200,6 +1202,7 @@ static int s3c24xx_serial_probe(struct
> platform_device *pdev)
> > return -ENODEV;
> > }
> >
> > +   ourport->baudclk = ERR_PTR(-EINVAL);
> > ourport->info = ourport->drv_data->info;
> > ourport->cfg = (pdev->dev.platform_data) ?
> > (struct s3c2410_uartcfg *)pdev->dev.platform_data :
> > @@ -1387,7 +1390,7 @@ s3c24xx_serial_get_options(struct uart_port *port,
> int *baud,
> > sprintf(clk_name, "clk_uart_baud%d", clk_sel);
> >
> > clk = clk_get(port->dev, clk_name);
> > -   if (!IS_ERR(clk) && clk != NULL)
> > +   if (!IS_ERR(clk))
> > rate = clk_get_rate(clk);
> > else
> > rate = 1;
> > --
> > 1.7.1

Looks ok to me, will apply.
Thanks.

Best regards,
Kgene.
--
Kukjin Kim , Senior Engineer,
SW Solution Development Team, Samsung Electronics Co., Ltd.

--
To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.htm

RE: [PATCH 1/2] serial: samsung: Remove NULL checking for baud clock

2012-05-24 Thread Kyoungil Kim
Kyoungil Kim wrote:

I missed following.

Russell King suggested:

As I said, drivers have no business interpreting anything but IS_ERR(clk) as 
being an error.  They should not make any other
assumptions.

Suggested-by: Russell King 

> Signed-off-by: Kyoungil Kim 
> ---
>  drivers/tty/serial/samsung.c |   21 -
>  1 files changed, 12 insertions(+), 9 deletions(-)
> 
> diff --git a/drivers/tty/serial/samsung.c b/drivers/tty/serial/samsung.c
> index d8b0aee..5668538 100644
> --- a/drivers/tty/serial/samsung.c
> +++ b/drivers/tty/serial/samsung.c
> @@ -529,7 +529,7 @@ static void s3c24xx_serial_pm(struct uart_port *port, 
> unsigned int level,
> 
>   switch (level) {
>   case 3:
> - if (!IS_ERR(ourport->baudclk) && ourport->baudclk != NULL)
> + if (!IS_ERR(ourport->baudclk))
>   clk_disable(ourport->baudclk);
> 
>   clk_disable(ourport->clk);
> @@ -538,7 +538,7 @@ static void s3c24xx_serial_pm(struct uart_port *port, 
> unsigned int level,
>   case 0:
>   clk_enable(ourport->clk);
> 
> - if (!IS_ERR(ourport->baudclk) && ourport->baudclk != NULL)
> + if (!IS_ERR(ourport->baudclk))
>   clk_enable(ourport->baudclk);
> 
>   break;
> @@ -604,7 +604,6 @@ static unsigned int s3c24xx_serial_getclk(struct 
> s3c24xx_uart_port *ourport,
>   char clkname[MAX_CLK_NAME_LENGTH];
>   int calc_deviation, deviation = (1 << 30) - 1;
> 
> - *best_clk = NULL;
>   clk_sel = (ourport->cfg->clk_sel) ? ourport->cfg->clk_sel :
>   ourport->info->def_clk_sel;
>   for (cnt = 0; cnt < info->num_clks; cnt++) {
> @@ -613,7 +612,7 @@ static unsigned int s3c24xx_serial_getclk(struct 
> s3c24xx_uart_port *ourport,
> 
>   sprintf(clkname, "clk_uart_baud%d", cnt);
>   clk = clk_get(ourport->port.dev, clkname);
> - if (IS_ERR_OR_NULL(clk))
> + if (IS_ERR(clk))
>   continue;
> 
>   rate = clk_get_rate(clk);
> @@ -684,7 +683,7 @@ static void s3c24xx_serial_set_termios(struct uart_port 
> *port,
>  {
>   struct s3c2410_uartcfg *cfg = s3c24xx_port_to_cfg(port);
>   struct s3c24xx_uart_port *ourport = to_ourport(port);
> - struct clk *clk = NULL;
> + struct clk *clk = ERR_PTR(-EINVAL);
>   unsigned long flags;
>   unsigned int baud, quot, clk_sel = 0;
>   unsigned int ulcon;
> @@ -705,7 +704,7 @@ static void s3c24xx_serial_set_termios(struct uart_port 
> *port,
>   quot = s3c24xx_serial_getclk(ourport, baud, &clk, &clk_sel);
>   if (baud == 38400 && (port->flags & UPF_SPD_MASK) == UPF_SPD_CUST)
>   quot = port->custom_divisor;
> - if (!clk)
> + if (IS_ERR(clk))
>   return;
> 
>   /* check to see if we need  to change clock source */
> @@ -713,9 +712,9 @@ static void s3c24xx_serial_set_termios(struct uart_port 
> *port,
>   if (ourport->baudclk != clk) {
>   s3c24xx_serial_setsource(port, clk_sel);
> 
> - if (ourport->baudclk != NULL && !IS_ERR(ourport->baudclk)) {
> + if (!IS_ERR(ourport->baudclk)) {
>   clk_disable(ourport->baudclk);
> - ourport->baudclk  = NULL;
> + ourport->baudclk = ERR_PTR(-EINVAL);
>   }
> 
>   clk_enable(clk);
> @@ -1160,6 +1159,9 @@ static ssize_t s3c24xx_serial_show_clksrc(struct device 
> *dev,
>   struct uart_port *port = s3c24xx_dev_to_port(dev);
>   struct s3c24xx_uart_port *ourport = to_ourport(port);
> 
> + if (IS_ERR(ourport->baudclk))
> + return -EINVAL;
> +
>   return snprintf(buf, PAGE_SIZE, "* %s\n", ourport->baudclk->name);
>  }
> 
> @@ -1200,6 +1202,7 @@ static int s3c24xx_serial_probe(struct platform_device 
> *pdev)
>   return -ENODEV;
>   }
> 
> + ourport->baudclk = ERR_PTR(-EINVAL);
>   ourport->info = ourport->drv_data->info;
>   ourport->cfg = (pdev->dev.platform_data) ?
>   (struct s3c2410_uartcfg *)pdev->dev.platform_data :
> @@ -1387,7 +1390,7 @@ s3c24xx_serial_get_options(struct uart_port *port, int 
> *baud,
>   sprintf(clk_name, "clk_uart_baud%d", clk_sel);
> 
>   clk = clk_get(port->dev, clk_name);
> - if (!IS_ERR(clk) && clk != NULL)
> + if (!IS_ERR(clk))
>   rate = clk_get_rate(clk);
>   else
>   rate = 1;
> --
> 1.7.1


--
To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[PATCH 1/2] serial: samsung: Remove NULL checking for baud clock

2012-05-20 Thread Kyoungil Kim
Signed-off-by: Kyoungil Kim 
---
 drivers/tty/serial/samsung.c |   21 -
 1 files changed, 12 insertions(+), 9 deletions(-)

diff --git a/drivers/tty/serial/samsung.c b/drivers/tty/serial/samsung.c
index d8b0aee..5668538 100644
--- a/drivers/tty/serial/samsung.c
+++ b/drivers/tty/serial/samsung.c
@@ -529,7 +529,7 @@ static void s3c24xx_serial_pm(struct uart_port *port, 
unsigned int level,
 
switch (level) {
case 3:
-   if (!IS_ERR(ourport->baudclk) && ourport->baudclk != NULL)
+   if (!IS_ERR(ourport->baudclk))
clk_disable(ourport->baudclk);
 
clk_disable(ourport->clk);
@@ -538,7 +538,7 @@ static void s3c24xx_serial_pm(struct uart_port *port, 
unsigned int level,
case 0:
clk_enable(ourport->clk);
 
-   if (!IS_ERR(ourport->baudclk) && ourport->baudclk != NULL)
+   if (!IS_ERR(ourport->baudclk))
clk_enable(ourport->baudclk);
 
break;
@@ -604,7 +604,6 @@ static unsigned int s3c24xx_serial_getclk(struct 
s3c24xx_uart_port *ourport,
char clkname[MAX_CLK_NAME_LENGTH];
int calc_deviation, deviation = (1 << 30) - 1;
 
-   *best_clk = NULL;
clk_sel = (ourport->cfg->clk_sel) ? ourport->cfg->clk_sel :
ourport->info->def_clk_sel;
for (cnt = 0; cnt < info->num_clks; cnt++) {
@@ -613,7 +612,7 @@ static unsigned int s3c24xx_serial_getclk(struct 
s3c24xx_uart_port *ourport,
 
sprintf(clkname, "clk_uart_baud%d", cnt);
clk = clk_get(ourport->port.dev, clkname);
-   if (IS_ERR_OR_NULL(clk))
+   if (IS_ERR(clk))
continue;
 
rate = clk_get_rate(clk);
@@ -684,7 +683,7 @@ static void s3c24xx_serial_set_termios(struct uart_port 
*port,
 {
struct s3c2410_uartcfg *cfg = s3c24xx_port_to_cfg(port);
struct s3c24xx_uart_port *ourport = to_ourport(port);
-   struct clk *clk = NULL;
+   struct clk *clk = ERR_PTR(-EINVAL);
unsigned long flags;
unsigned int baud, quot, clk_sel = 0;
unsigned int ulcon;
@@ -705,7 +704,7 @@ static void s3c24xx_serial_set_termios(struct uart_port 
*port,
quot = s3c24xx_serial_getclk(ourport, baud, &clk, &clk_sel);
if (baud == 38400 && (port->flags & UPF_SPD_MASK) == UPF_SPD_CUST)
quot = port->custom_divisor;
-   if (!clk)
+   if (IS_ERR(clk))
return;
 
/* check to see if we need  to change clock source */
@@ -713,9 +712,9 @@ static void s3c24xx_serial_set_termios(struct uart_port 
*port,
if (ourport->baudclk != clk) {
s3c24xx_serial_setsource(port, clk_sel);
 
-   if (ourport->baudclk != NULL && !IS_ERR(ourport->baudclk)) {
+   if (!IS_ERR(ourport->baudclk)) {
clk_disable(ourport->baudclk);
-   ourport->baudclk  = NULL;
+   ourport->baudclk = ERR_PTR(-EINVAL);
}
 
clk_enable(clk);
@@ -1160,6 +1159,9 @@ static ssize_t s3c24xx_serial_show_clksrc(struct device 
*dev,
struct uart_port *port = s3c24xx_dev_to_port(dev);
struct s3c24xx_uart_port *ourport = to_ourport(port);
 
+   if (IS_ERR(ourport->baudclk))
+   return -EINVAL;
+
return snprintf(buf, PAGE_SIZE, "* %s\n", ourport->baudclk->name);
 }
 
@@ -1200,6 +1202,7 @@ static int s3c24xx_serial_probe(struct platform_device 
*pdev)
return -ENODEV;
}
 
+   ourport->baudclk = ERR_PTR(-EINVAL);
ourport->info = ourport->drv_data->info;
ourport->cfg = (pdev->dev.platform_data) ?
(struct s3c2410_uartcfg *)pdev->dev.platform_data :
@@ -1387,7 +1390,7 @@ s3c24xx_serial_get_options(struct uart_port *port, int 
*baud,
sprintf(clk_name, "clk_uart_baud%d", clk_sel);
 
clk = clk_get(port->dev, clk_name);
-   if (!IS_ERR(clk) && clk != NULL)
+   if (!IS_ERR(clk))
rate = clk_get_rate(clk);
else
rate = 1;
-- 
1.7.1


--
To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html