Commit c3036752 authored by Martin Schwidefsky's avatar Martin Schwidefsky Committed by Linus Torvalds

[PATCH] s390: network driver changes

From: Ursula Braun-Krahl <braunu@de.ibm.com>
From: Thomas Spatzier <tspat@de.ibm.com>
From: Peter Tiedemann <ptiedem@de.ibm.com>

network driver changes.
 - iucv: add missing symbolic links between /sys/bus/iucv/drivers/netiucv
   and /sys/class/net.
 - iucv: make use of the debug feature.
 - iucv: 0 vs. NULL cleanup, avoid build warnings.
 - iucv: remove unnecessary -ENODEV check after call to iucv_declare_buffer.
 - ctc: adjust debug feature log levels.
 - lcs: replace broken schedule_timeout call with msleep.
 - qeth: add missing link type.
 - qeth: treat add_hhlen attribute as decimal value.
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 795f05ec
/* /*
* *
* linux/drivers/s390/net/ctcdbug.c ($Revision: 1.1 $) * linux/drivers/s390/net/ctcdbug.c ($Revision: 1.2 $)
* *
* Linux on zSeries OSA Express and HiperSockets support * CTC / ESCON network driver - s390 dbf exploit.
* *
* Copyright 2000,2003 IBM Corporation * Copyright 2000,2003 IBM Corporation
* *
* Author(s): Original Code written by * Author(s): Original Code written by
* Peter Tiedemann (ptiedem@de.ibm.com) * Peter Tiedemann (ptiedem@de.ibm.com)
* *
* $Revision: 1.1 $ $Date: 2004/07/02 16:31:22 $ * $Revision: 1.2 $ $Date: 2004/07/15 16:03:08 $
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
......
/* /*
* *
* linux/drivers/s390/net/ctcdbug.h ($Revision: 1.1 $) * linux/drivers/s390/net/ctcdbug.h ($Revision: 1.2 $)
* *
* Linux on zSeries OSA Express and HiperSockets support * CTC / ESCON network driver - s390 dbf exploit.
* *
* Copyright 2000,2003 IBM Corporation * Copyright 2000,2003 IBM Corporation
* *
* Author(s): Original Code written by * Author(s): Original Code written by
* Peter Tiedemann (ptiedem@de.ibm.com) * Peter Tiedemann (ptiedem@de.ibm.com)
* *
* $Revision: 1.1 $ $Date: 2004/07/02 16:31:22 $ * $Revision: 1.2 $ $Date: 2004/07/15 16:03:08 $
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
......
This diff is collapsed.
/* /*
* $Id: ctctty.c,v 1.21 2004/07/02 16:31:22 ptiedem Exp $ * $Id: ctctty.c,v 1.24 2004/07/15 16:03:08 ptiedem Exp $
* *
* CTC / ESCON network driver, tty interface. * CTC / ESCON network driver, tty interface.
* *
...@@ -104,7 +104,7 @@ ctc_tty_try_read(ctc_tty_info * info, struct sk_buff *skb) ...@@ -104,7 +104,7 @@ ctc_tty_try_read(ctc_tty_info * info, struct sk_buff *skb)
int len; int len;
struct tty_struct *tty; struct tty_struct *tty;
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 5, __FUNCTION__);
if ((tty = info->tty)) { if ((tty = info->tty)) {
if (info->mcr & UART_MCR_RTS) { if (info->mcr & UART_MCR_RTS) {
c = TTY_FLIPBUF_SIZE - tty->flip.count; c = TTY_FLIPBUF_SIZE - tty->flip.count;
...@@ -134,7 +134,7 @@ ctc_tty_readmodem(ctc_tty_info *info) ...@@ -134,7 +134,7 @@ ctc_tty_readmodem(ctc_tty_info *info)
int ret = 1; int ret = 1;
struct tty_struct *tty; struct tty_struct *tty;
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 5, __FUNCTION__);
if ((tty = info->tty)) { if ((tty = info->tty)) {
if (info->mcr & UART_MCR_RTS) { if (info->mcr & UART_MCR_RTS) {
int c = TTY_FLIPBUF_SIZE - tty->flip.count; int c = TTY_FLIPBUF_SIZE - tty->flip.count;
...@@ -168,7 +168,7 @@ ctc_tty_setcarrier(struct net_device *netdev, int on) ...@@ -168,7 +168,7 @@ ctc_tty_setcarrier(struct net_device *netdev, int on)
{ {
int i; int i;
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 4, __FUNCTION__);
if ((!driver) || ctc_tty_shuttingdown) if ((!driver) || ctc_tty_shuttingdown)
return; return;
for (i = 0; i < CTC_TTY_MAX_DEVICES; i++) for (i = 0; i < CTC_TTY_MAX_DEVICES; i++)
...@@ -189,7 +189,7 @@ ctc_tty_netif_rx(struct sk_buff *skb) ...@@ -189,7 +189,7 @@ ctc_tty_netif_rx(struct sk_buff *skb)
int i; int i;
ctc_tty_info *info = NULL; ctc_tty_info *info = NULL;
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 5, __FUNCTION__);
if (!skb) if (!skb)
return; return;
if ((!skb->dev) || (!driver) || ctc_tty_shuttingdown) { if ((!skb->dev) || (!driver) || ctc_tty_shuttingdown) {
...@@ -254,7 +254,7 @@ ctc_tty_tint(ctc_tty_info * info) ...@@ -254,7 +254,7 @@ ctc_tty_tint(ctc_tty_info * info)
int wake = 1; int wake = 1;
int rc; int rc;
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 4, __FUNCTION__);
if (!info->netdev) { if (!info->netdev) {
if (skb) if (skb)
kfree_skb(skb); kfree_skb(skb);
...@@ -347,7 +347,7 @@ ctc_tty_inject(ctc_tty_info *info, char c) ...@@ -347,7 +347,7 @@ ctc_tty_inject(ctc_tty_info *info, char c)
int skb_res; int skb_res;
struct sk_buff *skb; struct sk_buff *skb;
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 4, __FUNCTION__);
if (ctc_tty_shuttingdown) if (ctc_tty_shuttingdown)
return; return;
skb_res = info->netdev->hard_header_len + sizeof(info->mcr) + skb_res = info->netdev->hard_header_len + sizeof(info->mcr) +
...@@ -368,7 +368,7 @@ ctc_tty_inject(ctc_tty_info *info, char c) ...@@ -368,7 +368,7 @@ ctc_tty_inject(ctc_tty_info *info, char c)
static void static void
ctc_tty_transmit_status(ctc_tty_info *info) ctc_tty_transmit_status(ctc_tty_info *info)
{ {
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 5, __FUNCTION__);
if (ctc_tty_shuttingdown) if (ctc_tty_shuttingdown)
return; return;
info->flags |= CTC_ASYNC_TX_LINESTAT; info->flags |= CTC_ASYNC_TX_LINESTAT;
...@@ -382,7 +382,7 @@ ctc_tty_change_speed(ctc_tty_info * info) ...@@ -382,7 +382,7 @@ ctc_tty_change_speed(ctc_tty_info * info)
unsigned int quot; unsigned int quot;
int i; int i;
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 3, __FUNCTION__);
if (!info->tty || !info->tty->termios) if (!info->tty || !info->tty->termios)
return; return;
cflag = info->tty->termios->c_cflag; cflag = info->tty->termios->c_cflag;
...@@ -421,7 +421,7 @@ ctc_tty_change_speed(ctc_tty_info * info) ...@@ -421,7 +421,7 @@ ctc_tty_change_speed(ctc_tty_info * info)
static int static int
ctc_tty_startup(ctc_tty_info * info) ctc_tty_startup(ctc_tty_info * info)
{ {
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 3, __FUNCTION__);
if (info->flags & CTC_ASYNC_INITIALIZED) if (info->flags & CTC_ASYNC_INITIALIZED)
return 0; return 0;
#ifdef CTC_DEBUG_MODEM_OPEN #ifdef CTC_DEBUG_MODEM_OPEN
...@@ -464,7 +464,7 @@ ctc_tty_stopdev(unsigned long data) ...@@ -464,7 +464,7 @@ ctc_tty_stopdev(unsigned long data)
static void static void
ctc_tty_shutdown(ctc_tty_info * info) ctc_tty_shutdown(ctc_tty_info * info)
{ {
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 3, __FUNCTION__);
if (!(info->flags & CTC_ASYNC_INITIALIZED)) if (!(info->flags & CTC_ASYNC_INITIALIZED))
return; return;
#ifdef CTC_DEBUG_MODEM_OPEN #ifdef CTC_DEBUG_MODEM_OPEN
...@@ -497,7 +497,7 @@ ctc_tty_write(struct tty_struct *tty, int from_user, const u_char * buf, int cou ...@@ -497,7 +497,7 @@ ctc_tty_write(struct tty_struct *tty, int from_user, const u_char * buf, int cou
int total = 0; int total = 0;
ctc_tty_info *info = (ctc_tty_info *) tty->driver_data; ctc_tty_info *info = (ctc_tty_info *) tty->driver_data;
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 5, __FUNCTION__);
if (ctc_tty_shuttingdown) if (ctc_tty_shuttingdown)
goto ex; goto ex;
if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_write")) if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_write"))
...@@ -575,7 +575,7 @@ ctc_tty_flush_buffer(struct tty_struct *tty) ...@@ -575,7 +575,7 @@ ctc_tty_flush_buffer(struct tty_struct *tty)
ctc_tty_info *info; ctc_tty_info *info;
unsigned long flags; unsigned long flags;
DBF_TEXT(trace, 2, __FUNCTION__); DBF_TEXT(trace, 4, __FUNCTION__);
if (!tty) if (!tty)
goto ex; goto ex;
spin_lock_irqsave(&ctc_tty_lock, flags); spin_lock_irqsave(&ctc_tty_lock, flags);
...@@ -601,6 +601,7 @@ ctc_tty_flush_chars(struct tty_struct *tty) ...@@ -601,6 +601,7 @@ ctc_tty_flush_chars(struct tty_struct *tty)
{ {
ctc_tty_info *info = (ctc_tty_info *) tty->driver_data; ctc_tty_info *info = (ctc_tty_info *) tty->driver_data;
DBF_TEXT(trace, 4, __FUNCTION__);
if (ctc_tty_shuttingdown) if (ctc_tty_shuttingdown)
return; return;
if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_flush_chars")) if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_flush_chars"))
...@@ -623,6 +624,7 @@ ctc_tty_throttle(struct tty_struct *tty) ...@@ -623,6 +624,7 @@ ctc_tty_throttle(struct tty_struct *tty)
{ {
ctc_tty_info *info = (ctc_tty_info *) tty->driver_data; ctc_tty_info *info = (ctc_tty_info *) tty->driver_data;
DBF_TEXT(trace, 4, __FUNCTION__);
if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_throttle")) if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_throttle"))
return; return;
info->mcr &= ~UART_MCR_RTS; info->mcr &= ~UART_MCR_RTS;
...@@ -636,6 +638,7 @@ ctc_tty_unthrottle(struct tty_struct *tty) ...@@ -636,6 +638,7 @@ ctc_tty_unthrottle(struct tty_struct *tty)
{ {
ctc_tty_info *info = (ctc_tty_info *) tty->driver_data; ctc_tty_info *info = (ctc_tty_info *) tty->driver_data;
DBF_TEXT(trace, 4, __FUNCTION__);
if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_unthrottle")) if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_unthrottle"))
return; return;
info->mcr |= UART_MCR_RTS; info->mcr |= UART_MCR_RTS;
...@@ -667,6 +670,7 @@ ctc_tty_get_lsr_info(ctc_tty_info * info, uint __user *value) ...@@ -667,6 +670,7 @@ ctc_tty_get_lsr_info(ctc_tty_info * info, uint __user *value)
uint result; uint result;
ulong flags; ulong flags;
DBF_TEXT(trace, 4, __FUNCTION__);
spin_lock_irqsave(&ctc_tty_lock, flags); spin_lock_irqsave(&ctc_tty_lock, flags);
status = info->lsr; status = info->lsr;
spin_unlock_irqrestore(&ctc_tty_lock, flags); spin_unlock_irqrestore(&ctc_tty_lock, flags);
...@@ -684,6 +688,7 @@ static int ctc_tty_tiocmget(struct tty_struct *tty, struct file *file) ...@@ -684,6 +688,7 @@ static int ctc_tty_tiocmget(struct tty_struct *tty, struct file *file)
uint result; uint result;
ulong flags; ulong flags;
DBF_TEXT(trace, 4, __FUNCTION__);
if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_ioctl")) if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_ioctl"))
return -ENODEV; return -ENODEV;
if (tty->flags & (1 << TTY_IO_ERROR)) if (tty->flags & (1 << TTY_IO_ERROR))
...@@ -708,6 +713,7 @@ ctc_tty_tiocmset(struct tty_struct *tty, struct file *file, ...@@ -708,6 +713,7 @@ ctc_tty_tiocmset(struct tty_struct *tty, struct file *file,
{ {
ctc_tty_info *info = (ctc_tty_info *) tty->driver_data; ctc_tty_info *info = (ctc_tty_info *) tty->driver_data;
DBF_TEXT(trace, 4, __FUNCTION__);
if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_ioctl")) if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_ioctl"))
return -ENODEV; return -ENODEV;
if (tty->flags & (1 << TTY_IO_ERROR)) if (tty->flags & (1 << TTY_IO_ERROR))
...@@ -736,6 +742,7 @@ ctc_tty_ioctl(struct tty_struct *tty, struct file *file, ...@@ -736,6 +742,7 @@ ctc_tty_ioctl(struct tty_struct *tty, struct file *file,
int error; int error;
int retval; int retval;
DBF_TEXT(trace, 4, __FUNCTION__);
if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_ioctl")) if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_ioctl"))
return -ENODEV; return -ENODEV;
if (tty->flags & (1 << TTY_IO_ERROR)) if (tty->flags & (1 << TTY_IO_ERROR))
...@@ -803,6 +810,8 @@ ctc_tty_set_termios(struct tty_struct *tty, struct termios *old_termios) ...@@ -803,6 +810,8 @@ ctc_tty_set_termios(struct tty_struct *tty, struct termios *old_termios)
{ {
ctc_tty_info *info = (ctc_tty_info *) tty->driver_data; ctc_tty_info *info = (ctc_tty_info *) tty->driver_data;
unsigned int cflag = tty->termios->c_cflag; unsigned int cflag = tty->termios->c_cflag;
DBF_TEXT(trace, 4, __FUNCTION__);
ctc_tty_change_speed(info); ctc_tty_change_speed(info);
/* Handle transition to B0 */ /* Handle transition to B0 */
...@@ -840,6 +849,7 @@ ctc_tty_block_til_ready(struct tty_struct *tty, struct file *filp, ctc_tty_info ...@@ -840,6 +849,7 @@ ctc_tty_block_til_ready(struct tty_struct *tty, struct file *filp, ctc_tty_info
unsigned long flags; unsigned long flags;
int retval; int retval;
DBF_TEXT(trace, 4, __FUNCTION__);
/* /*
* If the device is in the middle of being closed, then block * If the device is in the middle of being closed, then block
* until it's done, and then try again. * until it's done, and then try again.
...@@ -944,6 +954,7 @@ ctc_tty_open(struct tty_struct *tty, struct file *filp) ...@@ -944,6 +954,7 @@ ctc_tty_open(struct tty_struct *tty, struct file *filp)
int retval, int retval,
line; line;
DBF_TEXT(trace, 3, __FUNCTION__);
line = tty->index; line = tty->index;
if (line < 0 || line > CTC_TTY_MAX_DEVICES) if (line < 0 || line > CTC_TTY_MAX_DEVICES)
return -ENODEV; return -ENODEV;
...@@ -990,7 +1001,7 @@ ctc_tty_close(struct tty_struct *tty, struct file *filp) ...@@ -990,7 +1001,7 @@ ctc_tty_close(struct tty_struct *tty, struct file *filp)
ctc_tty_info *info = (ctc_tty_info *) tty->driver_data; ctc_tty_info *info = (ctc_tty_info *) tty->driver_data;
ulong flags; ulong flags;
ulong timeout; ulong timeout;
DBF_TEXT(trace, 3, __FUNCTION__);
if (!info || ctc_tty_paranoia_check(info, tty->name, "ctc_tty_close")) if (!info || ctc_tty_paranoia_check(info, tty->name, "ctc_tty_close"))
return; return;
spin_lock_irqsave(&ctc_tty_lock, flags); spin_lock_irqsave(&ctc_tty_lock, flags);
...@@ -1080,6 +1091,7 @@ ctc_tty_hangup(struct tty_struct *tty) ...@@ -1080,6 +1091,7 @@ ctc_tty_hangup(struct tty_struct *tty)
{ {
ctc_tty_info *info = (ctc_tty_info *)tty->driver_data; ctc_tty_info *info = (ctc_tty_info *)tty->driver_data;
unsigned long saveflags; unsigned long saveflags;
DBF_TEXT(trace, 3, __FUNCTION__);
if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_hangup")) if (ctc_tty_paranoia_check(info, tty->name, "ctc_tty_hangup"))
return; return;
ctc_tty_shutdown(info); ctc_tty_shutdown(info);
...@@ -1103,6 +1115,7 @@ ctc_tty_task(unsigned long arg) ...@@ -1103,6 +1115,7 @@ ctc_tty_task(unsigned long arg)
unsigned long saveflags; unsigned long saveflags;
int again; int again;
DBF_TEXT(trace, 3, __FUNCTION__);
spin_lock_irqsave(&ctc_tty_lock, saveflags); spin_lock_irqsave(&ctc_tty_lock, saveflags);
if ((!ctc_tty_shuttingdown) && info) { if ((!ctc_tty_shuttingdown) && info) {
again = ctc_tty_tint(info); again = ctc_tty_tint(info);
...@@ -1140,6 +1153,7 @@ ctc_tty_init(void) ...@@ -1140,6 +1153,7 @@ ctc_tty_init(void)
ctc_tty_info *info; ctc_tty_info *info;
struct tty_driver *device; struct tty_driver *device;
DBF_TEXT(trace, 2, __FUNCTION__);
driver = kmalloc(sizeof(ctc_tty_driver), GFP_KERNEL); driver = kmalloc(sizeof(ctc_tty_driver), GFP_KERNEL);
if (driver == NULL) { if (driver == NULL) {
printk(KERN_WARNING "Out of memory in ctc_tty_modem_init\n"); printk(KERN_WARNING "Out of memory in ctc_tty_modem_init\n");
...@@ -1199,6 +1213,7 @@ ctc_tty_register_netdev(struct net_device *dev) { ...@@ -1199,6 +1213,7 @@ ctc_tty_register_netdev(struct net_device *dev) {
char *err; char *err;
char *p; char *p;
DBF_TEXT(trace, 2, __FUNCTION__);
if ((!dev) || (!dev->name)) { if ((!dev) || (!dev->name)) {
printk(KERN_WARNING printk(KERN_WARNING
"ctc_tty_register_netdev called " "ctc_tty_register_netdev called "
...@@ -1246,6 +1261,7 @@ ctc_tty_unregister_netdev(struct net_device *dev) { ...@@ -1246,6 +1261,7 @@ ctc_tty_unregister_netdev(struct net_device *dev) {
unsigned long saveflags; unsigned long saveflags;
ctc_tty_info *info = NULL; ctc_tty_info *info = NULL;
DBF_TEXT(trace, 2, __FUNCTION__);
spin_lock_irqsave(&ctc_tty_lock, saveflags); spin_lock_irqsave(&ctc_tty_lock, saveflags);
for (i = 0; i < CTC_TTY_MAX_DEVICES; i++) for (i = 0; i < CTC_TTY_MAX_DEVICES; i++)
if (driver->info[i].netdev == dev) { if (driver->info[i].netdev == dev) {
...@@ -1264,6 +1280,7 @@ void ...@@ -1264,6 +1280,7 @@ void
ctc_tty_cleanup(void) { ctc_tty_cleanup(void) {
unsigned long saveflags; unsigned long saveflags;
DBF_TEXT(trace, 2, __FUNCTION__);
spin_lock_irqsave(&ctc_tty_lock, saveflags); spin_lock_irqsave(&ctc_tty_lock, saveflags);
ctc_tty_shuttingdown = 1; ctc_tty_shuttingdown = 1;
spin_unlock_irqrestore(&ctc_tty_lock, saveflags); spin_unlock_irqrestore(&ctc_tty_lock, saveflags);
......
/* /*
* $Id: iucv.c,v 1.38 2004/07/09 15:59:53 mschwide Exp $ * $Id: iucv.c,v 1.39 2004/07/12 06:54:14 braunu Exp $
* *
* IUCV network driver * IUCV network driver
* *
...@@ -29,7 +29,7 @@ ...@@ -29,7 +29,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
* *
* RELEASE-TAG: IUCV lowlevel driver $Revision: 1.38 $ * RELEASE-TAG: IUCV lowlevel driver $Revision: 1.39 $
* *
*/ */
...@@ -354,7 +354,7 @@ do { \ ...@@ -354,7 +354,7 @@ do { \
static void static void
iucv_banner(void) iucv_banner(void)
{ {
char vbuf[] = "$Revision: 1.38 $"; char vbuf[] = "$Revision: 1.39 $";
char *version = vbuf; char *version = vbuf;
if ((version = strchr(version, ':'))) { if ((version = strchr(version, ':'))) {
...@@ -874,9 +874,6 @@ iucv_register_program (__u8 pgmname[16], ...@@ -874,9 +874,6 @@ iucv_register_program (__u8 pgmname[16],
iucv_remove_handler(new_handler); iucv_remove_handler(new_handler);
kfree(new_handler); kfree(new_handler);
switch(rc) { switch(rc) {
case -ENODEV:
err = "No CPU can be reserved";
break;
case 0x03: case 0x03:
err = "Directory error"; err = "Directory error";
break; break;
......
...@@ -30,6 +30,94 @@ ...@@ -30,6 +30,94 @@
*/ */
#include <linux/types.h> #include <linux/types.h>
#include <asm/debug.h>
/**
* Debug Facility stuff
*/
#define IUCV_DBF_SETUP_NAME "iucv_setup"
#define IUCV_DBF_SETUP_LEN 32
#define IUCV_DBF_SETUP_INDEX 1
#define IUCV_DBF_SETUP_NR_AREAS 1
#define IUCV_DBF_SETUP_LEVEL 3
#define IUCV_DBF_DATA_NAME "iucv_data"
#define IUCV_DBF_DATA_LEN 128
#define IUCV_DBF_DATA_INDEX 1
#define IUCV_DBF_DATA_NR_AREAS 1
#define IUCV_DBF_DATA_LEVEL 2
#define IUCV_DBF_TRACE_NAME "iucv_trace"
#define IUCV_DBF_TRACE_LEN 16
#define IUCV_DBF_TRACE_INDEX 2
#define IUCV_DBF_TRACE_NR_AREAS 1
#define IUCV_DBF_TRACE_LEVEL 3
#define IUCV_DBF_TEXT(name,level,text) \
do { \
debug_text_event(iucv_dbf_##name,level,text); \
} while (0)
#define IUCV_DBF_HEX(name,level,addr,len) \
do { \
debug_event(iucv_dbf_##name,level,(void*)(addr),len); \
} while (0)
extern DEFINE_PER_CPU(char[256], iucv_dbf_txt_buf);
#define IUCV_DBF_TEXT_(name,level,text...) \
do { \
char* iucv_dbf_txt_buf = get_cpu_var(iucv_dbf_txt_buf); \
sprintf(iucv_dbf_txt_buf, text); \
debug_text_event(iucv_dbf_##name,level,iucv_dbf_txt_buf); \
put_cpu_var(iucv_dbf_txt_buf); \
} while (0)
#define IUCV_DBF_SPRINTF(name,level,text...) \
do { \
debug_sprintf_event(iucv_dbf_trace, level, ##text ); \
debug_sprintf_event(iucv_dbf_trace, level, text ); \
} while (0)
/**
* some more debug stuff
*/
#define IUCV_HEXDUMP16(importance,header,ptr) \
PRINT_##importance(header "%02x %02x %02x %02x %02x %02x %02x %02x " \
"%02x %02x %02x %02x %02x %02x %02x %02x\n", \
*(((char*)ptr)),*(((char*)ptr)+1),*(((char*)ptr)+2), \
*(((char*)ptr)+3),*(((char*)ptr)+4),*(((char*)ptr)+5), \
*(((char*)ptr)+6),*(((char*)ptr)+7),*(((char*)ptr)+8), \
*(((char*)ptr)+9),*(((char*)ptr)+10),*(((char*)ptr)+11), \
*(((char*)ptr)+12),*(((char*)ptr)+13), \
*(((char*)ptr)+14),*(((char*)ptr)+15)); \
PRINT_##importance(header "%02x %02x %02x %02x %02x %02x %02x %02x " \
"%02x %02x %02x %02x %02x %02x %02x %02x\n", \
*(((char*)ptr)+16),*(((char*)ptr)+17), \
*(((char*)ptr)+18),*(((char*)ptr)+19), \
*(((char*)ptr)+20),*(((char*)ptr)+21), \
*(((char*)ptr)+22),*(((char*)ptr)+23), \
*(((char*)ptr)+24),*(((char*)ptr)+25), \
*(((char*)ptr)+26),*(((char*)ptr)+27), \
*(((char*)ptr)+28),*(((char*)ptr)+29), \
*(((char*)ptr)+30),*(((char*)ptr)+31));
static inline void
iucv_hex_dump(unsigned char *buf, size_t len)
{
size_t i;
for (i = 0; i < len; i++) {
if (i && !(i % 16))
printk("\n");
printk("%02x ", *(buf + i));
}
printk("\n");
}
/**
* end of debug stuff
*/
#define uchar unsigned char #define uchar unsigned char
#define ushort unsigned short #define ushort unsigned short
#define ulong unsigned long #define ulong unsigned long
......
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
* Frank Pavlic (pavlic@de.ibm.com) and * Frank Pavlic (pavlic@de.ibm.com) and
* Martin Schwidefsky <schwidefsky@de.ibm.com> * Martin Schwidefsky <schwidefsky@de.ibm.com>
* *
* $Revision: 1.83 $ $Date: 2004/06/30 12:48:14 $ * $Revision: 1.84 $ $Date: 2004/07/14 07:23:15 $
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -58,7 +58,7 @@ ...@@ -58,7 +58,7 @@
/** /**
* initialization string for output * initialization string for output
*/ */
#define VERSION_LCS_C "$Revision: 1.83 $" #define VERSION_LCS_C "$Revision: 1.84 $"
static char version[] __initdata = "LCS driver ("VERSION_LCS_C "/" VERSION_LCS_H ")"; static char version[] __initdata = "LCS driver ("VERSION_LCS_C "/" VERSION_LCS_H ")";
static char debug_buffer[255]; static char debug_buffer[255];
...@@ -1420,7 +1420,7 @@ lcs_resetcard(struct lcs_card *card) ...@@ -1420,7 +1420,7 @@ lcs_resetcard(struct lcs_card *card)
card->dev->name); card->dev->name);
return 0; return 0;
} }
schedule_timeout(3 * HZ); msleep(30);
} }
PRINT_ERR("Error in Reseting LCS card!\n"); PRINT_ERR("Error in Reseting LCS card!\n");
return -EIO; return -EIO;
......
This diff is collapsed.
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
#ifndef __QETH_FS_H__ #ifndef __QETH_FS_H__
#define __QETH_FS_H__ #define __QETH_FS_H__
#define VERSION_QETH_FS_H "$Revision: 1.8 $" #define VERSION_QETH_FS_H "$Revision: 1.9 $"
extern const char *VERSION_QETH_PROC_C; extern const char *VERSION_QETH_PROC_C;
extern const char *VERSION_QETH_SYS_C; extern const char *VERSION_QETH_SYS_C;
...@@ -138,6 +138,8 @@ qeth_get_cardname_short(struct qeth_card *card) ...@@ -138,6 +138,8 @@ qeth_get_cardname_short(struct qeth_card *card)
return "HSTR"; return "HSTR";
case QETH_LINK_TYPE_GBIT_ETH: case QETH_LINK_TYPE_GBIT_ETH:
return "OSD_1000"; return "OSD_1000";
case QETH_LINK_TYPE_10GBIT_ETH:
return "OSD_10GIG";
case QETH_LINK_TYPE_LANE_ETH100: case QETH_LINK_TYPE_LANE_ETH100:
return "OSD_FE_LANE"; return "OSD_FE_LANE";
case QETH_LINK_TYPE_LANE_TR: case QETH_LINK_TYPE_LANE_TR:
......
/* /*
* *
* linux/drivers/s390/net/qeth_main.c ($Revision: 1.125 $) * linux/drivers/s390/net/qeth_main.c ($Revision: 1.127 $)
* *
* Linux on zSeries OSA Express and HiperSockets support * Linux on zSeries OSA Express and HiperSockets support
* *
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
* Frank Pavlic (pavlic@de.ibm.com) and * Frank Pavlic (pavlic@de.ibm.com) and
* Thomas Spatzier <tspat@de.ibm.com> * Thomas Spatzier <tspat@de.ibm.com>
* *
* $Revision: 1.125 $ $Date: 2004/06/29 17:28:24 $ * $Revision: 1.127 $ $Date: 2004/07/14 21:46:40 $
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -78,7 +78,7 @@ qeth_eyecatcher(void) ...@@ -78,7 +78,7 @@ qeth_eyecatcher(void)
#include "qeth_mpc.h" #include "qeth_mpc.h"
#include "qeth_fs.h" #include "qeth_fs.h"
#define VERSION_QETH_C "$Revision: 1.125 $" #define VERSION_QETH_C "$Revision: 1.127 $"
static const char *version = "qeth S/390 OSA-Express driver"; static const char *version = "qeth S/390 OSA-Express driver";
/** /**
...@@ -3853,7 +3853,8 @@ qeth_mdio_read(struct net_device *dev, int phy_id, int regnum) ...@@ -3853,7 +3853,8 @@ qeth_mdio_read(struct net_device *dev, int phy_id, int regnum)
switch(regnum){ switch(regnum){
case MII_BMCR: /* Basic mode control register */ case MII_BMCR: /* Basic mode control register */
rc = BMCR_FULLDPLX; rc = BMCR_FULLDPLX;
if(card->info.link_type != QETH_LINK_TYPE_GBIT_ETH) if ((card->info.link_type != QETH_LINK_TYPE_GBIT_ETH)&&
(card->info.link_type != QETH_LINK_TYPE_10GBIT_ETH))
rc |= BMCR_SPEED100; rc |= BMCR_SPEED100;
break; break;
case MII_BMSR: /* Basic mode status register */ case MII_BMSR: /* Basic mode status register */
......
/* /*
* *
* linux/drivers/s390/net/qeth_sys.c ($Revision: 1.32 $) * linux/drivers/s390/net/qeth_sys.c ($Revision: 1.33 $)
* *
* Linux on zSeries OSA Express and HiperSockets support * Linux on zSeries OSA Express and HiperSockets support
* This file contains code related to sysfs. * This file contains code related to sysfs.
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
#include "qeth_mpc.h" #include "qeth_mpc.h"
#include "qeth_fs.h" #include "qeth_fs.h"
const char *VERSION_QETH_SYS_C = "$Revision: 1.32 $"; const char *VERSION_QETH_SYS_C = "$Revision: 1.33 $";
/*****************************************************************************/ /*****************************************************************************/
/* */ /* */
...@@ -476,7 +476,7 @@ qeth_dev_add_hhlen_store(struct device *dev, const char *buf, size_t count) ...@@ -476,7 +476,7 @@ qeth_dev_add_hhlen_store(struct device *dev, const char *buf, size_t count)
(card->state != CARD_STATE_RECOVER)) (card->state != CARD_STATE_RECOVER))
return -EPERM; return -EPERM;
i = simple_strtoul(buf, &tmp, 16); i = simple_strtoul(buf, &tmp, 10);
if ((i < 0) || (i > MAX_ADD_HHLEN)) { if ((i < 0) || (i > MAX_ADD_HHLEN)) {
PRINT_WARN("add_hhlen out of range\n"); PRINT_WARN("add_hhlen out of range\n");
return -EINVAL; return -EINVAL;
......
...@@ -4788,6 +4788,7 @@ zfcp_fsf_req_create(struct zfcp_adapter *adapter, u32 fsf_cmd, int req_flags, ...@@ -4788,6 +4788,7 @@ zfcp_fsf_req_create(struct zfcp_adapter *adapter, u32 fsf_cmd, int req_flags,
if (!atomic_test_mask(ZFCP_STATUS_ADAPTER_QDIOUP, &adapter->status)) { if (!atomic_test_mask(ZFCP_STATUS_ADAPTER_QDIOUP, &adapter->status)) {
write_unlock_irqrestore(&req_queue->queue_lock, *lock_flags); write_unlock_irqrestore(&req_queue->queue_lock, *lock_flags);
ret = -EIO;
goto failed_sbals; goto failed_sbals;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment