#include <linux/obd_class.h>
static int obd_init_magic;
-int obd_print_entry = 1;
-int obd_debug_level = 0;
+int obd_print_entry = 0;
+int obd_debug_level = D_IOCTL|D_INODE|D_SUPER|D_WARNING;
struct obd_device obd_dev[MAX_OBD_DEVICES];
struct list_head obd_types;
{
struct list_head *tmp;
struct obd_type *type;
- CDEBUG(D_IOCTL, "SEARCH %s\n", nm);
+ CDEBUG(D_INFO, "SEARCH %s\n", nm);
tmp = &obd_types;
while ( (tmp = tmp->next) != &obd_types ) {
type = list_entry(tmp, struct obd_type, typ_chain);
- CDEBUG(D_IOCTL, "TYP %s\n", type->typ_name);
+ CDEBUG(D_INFO, "TYP %s\n", type->typ_name);
if (strlen(type->typ_name) == strlen(nm) &&
strcmp(type->typ_name, nm) == 0 ) {
return type;
if (!len)
return 0;
- CDEBUG(D_IOCTL, "getdata: len %d, add %p\n", len, *data);
+ CDEBUG(D_INFO, "getdata: len %d, add %p\n", len, *data);
OBD_ALLOC(tmp, void *, len);
if ( !tmp )
int err, dev;
long int cli_id; /* connect, disconnect */
- if (!inode)
+ if (!inode) {
+ CDEBUG(D_IOCTL, "invalid inode\n");
return -EINVAL;
+ }
dev = MINOR(inode->i_rdev);
if (dev > MAX_OBD_DEVICES)
#ifdef CONFIG_KMOD
if ( !type ) {
if ( !request_module(nm) ) {
- CDEBUG(D_IOCTL, "Loaded module '%s'\n", nm);
+ CDEBUG(D_PSDEV, "Loaded module '%s'\n", nm);
type = obd_nm_to_type(nm);
} else {
- CDEBUG(D_IOCTL, "Can't load module '%s'\n", nm);
+ CDEBUG(D_PSDEV, "Can't load module '%s'\n", nm);
}
}
#endif
INIT_LIST_HEAD(&obddev->obd_gen_clients);
obddev->obd_multi_count = 0;
- CDEBUG(D_IOCTL, "Attach %d, datalen %d, type %s\n",
+ CDEBUG(D_INFO, "Attach %d, datalen %d, type %s\n",
dev, input->att_datalen, obddev->obd_type->typ_name);
/* maybe we are done */
if ( !OBT(obddev) || !OBP(obddev, attach) ) {
obddev->obd_flags |= OBD_ATTACHED;
type->typ_refcnt++;
- CDEBUG(D_IOCTL, "Dev %d refcount now %d\n", dev,
+ CDEBUG(D_PSDEV, "Dev %d refcount now %d\n", dev,
type->typ_refcnt);
MOD_INC_USE_COUNT;
EXIT;
} else {
obddev->obd_flags |= OBD_ATTACHED;
type->typ_refcnt++;
- CDEBUG(D_IOCTL, "Dev %d refcount now %d\n", dev,
+ CDEBUG(D_PSDEV, "Dev %d refcount now %d\n", dev,
type->typ_refcnt);
MOD_INC_USE_COUNT;
EXIT;
return -EBUSY;
}
- CDEBUG(D_IOCTL, "Detach %d, type %s\n", dev,
+ CDEBUG(D_PSDEV, "Detach %d, type %s\n", dev,
obddev->obd_type->typ_name);
obddev->obd_flags &= ~OBD_ATTACHED;
obddev->obd_type->typ_refcnt--;
- CDEBUG(D_IOCTL, "Dev %d refcount now %d\n", dev,
+ CDEBUG(D_PSDEV, "Dev %d refcount now %d\n", dev,
obddev->obd_type->typ_refcnt);
obddev->obd_type = NULL;
MOD_DEC_USE_COUNT;
}
/* do the setup */
- CDEBUG(D_IOCTL, "Setup %d, type %s\n", dev,
+ CDEBUG(D_PSDEV, "Setup %d, type %s\n", dev,
obddev->obd_type->typ_name);
if ( !OBT(obddev) || !OBP(obddev, setup) ) {
obddev->obd_type->typ_refcnt++;
- CDEBUG(D_IOCTL, "Dev %d refcount now %d\n",
+ CDEBUG(D_PSDEV, "Dev %d refcount now %d\n",
dev, obddev->obd_type->typ_refcnt);
obddev->obd_flags |= OBD_SET_UP;
EXIT;
EXIT;
} else {
obddev->obd_type->typ_refcnt++;
- CDEBUG(D_IOCTL, "Dev %d refcount now %d\n",
+ CDEBUG(D_PSDEV, "Dev %d refcount now %d\n",
dev, obddev->obd_type->typ_refcnt);
obddev->obd_flags |= OBD_SET_UP;
EXIT;
cleanup_out:
obddev->obd_flags &= ~OBD_SET_UP;
obddev->obd_type->typ_refcnt--;
- CDEBUG(D_IOCTL, "Dev %d refcount now %d\n", dev,
+ CDEBUG(D_PSDEV, "Dev %d refcount now %d\n", dev,
obddev->obd_type->typ_refcnt);
EXIT;
return 0;
&rw_s->count, rw_s->offset);
ODEBUG(&rw_s->obdo);
- CDEBUG(D_INODE, "READ: conn %d, count %Ld, offset %Ld, '%s'\n",
+ CDEBUG(D_INFO, "READ: conn %d, count %Ld, offset %Ld, '%s'\n",
rw_s->conn_id, rw_s->count, rw_s->offset, rw_s->buf);
if ( err ) {
EXIT;
return err;
}
- CDEBUG(D_INODE, "WRITE: conn %d, count %Ld, offset %Ld, '%s'\n",
+ CDEBUG(D_INFO, "WRITE: conn %d, count %Ld, offset %Ld, '%s'\n",
rw_s->conn_id, rw_s->count, rw_s->offset, rw_s->buf);
err = OBP(obddev, write)(&conn, &rw_s->obdo, rw_s->buf,
&rw_s->count, rw_s->offset);
return -EOPNOTSUPP;
/* do the partition */
- CDEBUG(D_IOCTL, "Copy %d, type %s dst %Ld src %Ld\n", dev,
+ CDEBUG(D_INFO, "Copy %d, type %s dst %Ld src %Ld\n", dev,
obddev->obd_type->typ_name, mvdata->dst.o_id,
mvdata->src.o_id);
return err;
}
- CDEBUG(D_IOCTL, "Migrate copying %d bytes\n", sizeof(*mvdata));
+ CDEBUG(D_INFO, "Migrate copying %d bytes\n", sizeof(*mvdata));
if ( !OBT(obddev) || !OBP(obddev, migrate) )
return -EOPNOTSUPP;
/* do the partition */
- CDEBUG(D_IOCTL, "Migrate %d, type %s conn %d src %Ld dst %Ld\n",
+ CDEBUG(D_INFO, "Migrate %d, type %s conn %d src %Ld dst %Ld\n",
dev, obddev->obd_type->typ_name, mvdata->src_conn_id,
mvdata->src.o_id, mvdata->dst.o_id);
#ifdef CONFIG_KMOD
if ( !type ) {
if ( !request_module(nm) ) {
- CDEBUG(D_IOCTL, "Loaded module '%s'\n", nm);
+ CDEBUG(D_PSDEV, "Loaded module '%s'\n", nm);
type = obd_nm_to_type(nm);
} else {
- CDEBUG(D_IOCTL, "Can't load module '%s'\n", nm);
+ CDEBUG(D_PSDEV, "Can't load module '%s'\n", nm);
}
}
#endif
}
conn.oc_id = input.att_connid;
- CDEBUG(D_IOCTL, "Calling ioctl %x for type %s, len %d\n",
+ CDEBUG(D_INFO, "Calling ioctl %x for type %s, len %d\n",
cmd, type->typ_name, input.att_datalen);
/* get the generic data */
if (obd_init_magic != 0x11223344) {
+ printk(__FUNCTION__ ": bad magic for type\n");
EXIT;
return -EINVAL;
}
{
ENTRY;
if (obdo_cachep == NULL) {
- CDEBUG(D_INODE, "allocating obdo_cache\n");
+ CDEBUG(D_CACHE, "allocating obdo_cache\n");
obdo_cachep = kmem_cache_create("obdo_cache",
sizeof(struct obdo),
0, SLAB_HWCACHE_ALIGN,
EXIT;
return -ENOMEM;
} else {
- CDEBUG(D_INODE, "allocated cache at %p\n", obdo_cachep);
+ CDEBUG(D_CACHE, "allocated cache at %p\n", obdo_cachep);
}
} else {
- CDEBUG(D_INODE, "using existing cache at %p\n", obdo_cachep);
+ CDEBUG(D_CACHE, "using existing cache at %p\n", obdo_cachep);
}
EXIT;
return 0;
{
ENTRY;
if (obdo_cachep != NULL) {
- CDEBUG(D_INODE, "destroying obdo_cache at %p\n", obdo_cachep);
+ CDEBUG(D_CACHE, "destroying obdo_cache at %p\n", obdo_cachep);
if (kmem_cache_destroy(obdo_cachep))
printk(KERN_WARNING __FUNCTION__
": unable to free cache\n");
cli->cli_obd = conn->oc_dev;
list_add(&(cli->cli_chain), conn->oc_dev->obd_gen_clients.prev);
- CDEBUG(D_IOCTL, "connect: new ID %u\n", cli->cli_id);
+ CDEBUG(D_INFO, "connect: new ID %u\n", cli->cli_id);
conn->oc_id = cli->cli_id;
return 0;
} /* gen_obd_connect */
list_del(&(cli->cli_chain));
OBD_FREE(cli, sizeof(struct obd_client));
- CDEBUG(D_IOCTL, "disconnect: ID %u\n", conn->oc_id);
+ CDEBUG(D_INFO, "disconnect: ID %u\n", conn->oc_id);
EXIT;
return 0;
rc = OBP(ch_conn->oc_dev, connect)(ch_conn);
if ( rc != 0 ) {
- /* XXX disconnect others */
+ int j;
+
+ for (j = --i; j >= 0; --j) {
+ ch_conn = &obddev->obd_multi_conn[i];
+ OBP(ch_conn->oc_dev, disconnect)(ch_conn);
+ }
return -EINVAL;
}
}
for (i=0 ; i<count ; i++) {
rdev = &obd_dev[*((int *)data + i)];
rdev = rdev + 1;
- CDEBUG(D_IOCTL, "OBD RAID1: replicator %d is of type %s\n", i,
+ CDEBUG(D_INFO, "OBD RAID1: replicator %d is of type %s\n", i,
(rdev + i)->obd_type->typ_name);
}
return 0;
lh = tmp = &obddev->obd_gen_clients;
while ((tmp = tmp->next) != lh) {
cli = list_entry(tmp, struct obd_client, cli_chain);
- CDEBUG(D_IOCTL, "Disconnecting obd_connection %d, at %p\n",
+ CDEBUG(D_INFO, "Disconnecting obd_connection %d, at %p\n",
cli->cli_id, cli);
}
return 0;
int err = 0;
ENTRY;
- CDEBUG(D_INODE, "src: ino %Ld blocks %Ld, size %Ld, dst: ino %Ld\n",
+ CDEBUG(D_INFO, "src: ino %Ld blocks %Ld, size %Ld, dst: ino %Ld\n",
src->o_id, src->o_blocks, src->o_size, dst->o_id);
page = alloc_page(GFP_USER);
if ( !page ) {
EXIT;
break;
}
- CDEBUG(D_INODE, "Read page %ld ...\n", page->index);
+ CDEBUG(D_INFO, "Read page %ld ...\n", page->index);
err = OBP(dst_conn->oc_dev, brw)(WRITE, dst_conn, num_oa, &dst,
&num_buf, &buf, &brw_count,
break;
}
- CDEBUG(D_INODE, "Wrote page %ld ...\n", page->index);
+ CDEBUG(D_INFO, "Wrote page %ld ...\n", page->index);
index++;
}