PTR_RET is now PTR_ERR_OR_ZERO(): Replace most.

Sweep of the simple cases.

Cc: netdev@vger.kernel.org
Cc: linuxppc-dev@lists.ozlabs.org
Cc: linux-arm-kernel@lists.infradead.org
Cc: Julia Lawall <julia.lawall@lip6.fr>
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Acked-by: David S. Miller <davem@davemloft.net>
Acked-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
This commit is contained in:
Rusty Russell 2013-07-15 11:20:32 +09:30
parent 6e8b8726ad
commit 8c6ffba0ed
43 changed files with 47 additions and 47 deletions

View File

@ -181,7 +181,7 @@ int __init omap_i2c_add_bus(struct omap_i2c_bus_platform_data *i2c_pdata,
sizeof(struct omap_i2c_bus_platform_data)); sizeof(struct omap_i2c_bus_platform_data));
WARN(IS_ERR(pdev), "Could not build omap_device for %s\n", name); WARN(IS_ERR(pdev), "Could not build omap_device for %s\n", name);
return PTR_RET(pdev); return PTR_ERR_OR_ZERO(pdev);
} }
static int __init omap_i2c_cmdline(void) static int __init omap_i2c_cmdline(void)

View File

@ -56,7 +56,7 @@ static int __init amiga_init_bus(void)
n = AMIGAHW_PRESENT(ZORRO3) ? 4 : 2; n = AMIGAHW_PRESENT(ZORRO3) ? 4 : 2;
pdev = platform_device_register_simple("amiga-zorro", -1, pdev = platform_device_register_simple("amiga-zorro", -1,
zorro_resources, n); zorro_resources, n);
return PTR_RET(pdev); return PTR_ERR_OR_ZERO(pdev);
} }
subsys_initcall(amiga_init_bus); subsys_initcall(amiga_init_bus);

View File

@ -90,7 +90,7 @@ static int __init rtc_init(void)
return -ENODEV; return -ENODEV;
pdev = platform_device_register_simple("rtc-generic", -1, NULL, 0); pdev = platform_device_register_simple("rtc-generic", -1, NULL, 0);
return PTR_RET(pdev); return PTR_ERR_OR_ZERO(pdev);
} }
module_init(rtc_init); module_init(rtc_init);

View File

@ -338,6 +338,6 @@ static __init int q40_add_kbd_device(void)
return -ENODEV; return -ENODEV;
pdev = platform_device_register_simple("q40kbd", -1, NULL, 0); pdev = platform_device_register_simple("q40kbd", -1, NULL, 0);
return PTR_RET(pdev); return PTR_ERR_OR_ZERO(pdev);
} }
arch_initcall(q40_add_kbd_device); arch_initcall(q40_add_kbd_device);

View File

@ -105,7 +105,7 @@ static int __init fail_iommu_debugfs(void)
struct dentry *dir = fault_create_debugfs_attr("fail_iommu", struct dentry *dir = fault_create_debugfs_attr("fail_iommu",
NULL, &fail_iommu); NULL, &fail_iommu);
return PTR_RET(dir); return PTR_ERR_OR_ZERO(dir);
} }
late_initcall(fail_iommu_debugfs); late_initcall(fail_iommu_debugfs);

View File

@ -1049,7 +1049,7 @@ static int __init rtc_init(void)
pdev = platform_device_register_simple("rtc-generic", -1, NULL, 0); pdev = platform_device_register_simple("rtc-generic", -1, NULL, 0);
return PTR_RET(pdev); return PTR_ERR_OR_ZERO(pdev);
} }
module_init(rtc_init); module_init(rtc_init);

View File

@ -90,7 +90,7 @@ static int __init ps3_rtc_init(void)
pdev = platform_device_register_simple("rtc-ps3", -1, NULL, 0); pdev = platform_device_register_simple("rtc-ps3", -1, NULL, 0);
return PTR_RET(pdev); return PTR_ERR_OR_ZERO(pdev);
} }
module_init(ps3_rtc_init); module_init(ps3_rtc_init);

View File

@ -62,7 +62,7 @@ static int __init add_rtc(void)
pd = platform_device_register_simple("rtc_cmos", -1, pd = platform_device_register_simple("rtc_cmos", -1,
&res[0], num_res); &res[0], num_res);
return PTR_RET(pd); return PTR_ERR_OR_ZERO(pd);
} }
fs_initcall(add_rtc); fs_initcall(add_rtc);

View File

@ -105,7 +105,7 @@ void hypfs_dbfs_remove_file(struct hypfs_dbfs_file *df)
int hypfs_dbfs_init(void) int hypfs_dbfs_init(void)
{ {
dbfs_dir = debugfs_create_dir("s390_hypfs", NULL); dbfs_dir = debugfs_create_dir("s390_hypfs", NULL);
return PTR_RET(dbfs_dir); return PTR_ERR_OR_ZERO(dbfs_dir);
} }
void hypfs_dbfs_exit(void) void hypfs_dbfs_exit(void)

View File

@ -349,7 +349,7 @@ static int srom_setup_minor(struct srom_dev *srom, int index)
dev = device_create(srom_class, &platform_bus, dev = device_create(srom_class, &platform_bus,
MKDEV(srom_major, index), srom, "%d", index); MKDEV(srom_major, index), srom, "%d", index);
return PTR_RET(dev); return PTR_ERR_OR_ZERO(dev);
} }
/** srom_init() - Initialize the driver's module. */ /** srom_init() - Initialize the driver's module. */

View File

@ -3205,7 +3205,7 @@ static int cma_join_ib_multicast(struct rdma_id_private *id_priv,
id_priv->id.port_num, &rec, id_priv->id.port_num, &rec,
comp_mask, GFP_KERNEL, comp_mask, GFP_KERNEL,
cma_ib_mc_handler, mc); cma_ib_mc_handler, mc);
return PTR_RET(mc->multicast.ib); return PTR_ERR_OR_ZERO(mc->multicast.ib);
} }
static void iboe_mcast_work_handler(struct work_struct *work) static void iboe_mcast_work_handler(struct work_struct *work)

View File

@ -996,7 +996,7 @@ static int __init cops_module_init(void)
printk(KERN_WARNING "%s: You shouldn't autoprobe with insmod\n", printk(KERN_WARNING "%s: You shouldn't autoprobe with insmod\n",
cardname); cardname);
cops_dev = cops_probe(-1); cops_dev = cops_probe(-1);
return PTR_RET(cops_dev); return PTR_ERR_OR_ZERO(cops_dev);
} }
static void __exit cops_module_exit(void) static void __exit cops_module_exit(void)

View File

@ -1243,7 +1243,7 @@ static int __init ltpc_module_init(void)
"ltpc: Autoprobing is not recommended for modules\n"); "ltpc: Autoprobing is not recommended for modules\n");
dev_ltpc = ltpc_probe(); dev_ltpc = ltpc_probe();
return PTR_RET(dev_ltpc); return PTR_ERR_OR_ZERO(dev_ltpc);
} }
module_init(ltpc_module_init); module_init(ltpc_module_init);
#endif #endif

View File

@ -1147,7 +1147,7 @@ static struct net_device *atarilance_dev;
static int __init atarilance_module_init(void) static int __init atarilance_module_init(void)
{ {
atarilance_dev = atarilance_probe(-1); atarilance_dev = atarilance_probe(-1);
return PTR_RET(atarilance_dev); return PTR_ERR_OR_ZERO(atarilance_dev);
} }
static void __exit atarilance_module_exit(void) static void __exit atarilance_module_exit(void)

View File

@ -188,7 +188,7 @@ static struct net_device *dev_mvme147_lance;
int __init init_module(void) int __init init_module(void)
{ {
dev_mvme147_lance = mvme147lance_probe(-1); dev_mvme147_lance = mvme147lance_probe(-1);
return PTR_RET(dev_mvme147_lance); return PTR_ERR_OR_ZERO(dev_mvme147_lance);
} }
void __exit cleanup_module(void) void __exit cleanup_module(void)

View File

@ -1238,7 +1238,7 @@ MODULE_PARM_DESC(dma, "ni6510 ISA DMA channel (ignored for some cards)");
int __init init_module(void) int __init init_module(void)
{ {
dev_ni65 = ni65_probe(-1); dev_ni65 = ni65_probe(-1);
return PTR_RET(dev_ni65); return PTR_ERR_OR_ZERO(dev_ni65);
} }
void __exit cleanup_module(void) void __exit cleanup_module(void)

View File

@ -940,7 +940,7 @@ static struct net_device *sun3lance_dev;
int __init init_module(void) int __init init_module(void)
{ {
sun3lance_dev = sun3lance_probe(-1); sun3lance_dev = sun3lance_probe(-1);
return PTR_RET(sun3lance_dev); return PTR_ERR_OR_ZERO(sun3lance_dev);
} }
void __exit cleanup_module(void) void __exit cleanup_module(void)

View File

@ -50,7 +50,7 @@ int brcmf_debugfs_attach(struct brcmf_pub *drvr)
return -ENODEV; return -ENODEV;
drvr->dbgfs_dir = debugfs_create_dir(dev_name(dev), root_folder); drvr->dbgfs_dir = debugfs_create_dir(dev_name(dev), root_folder);
return PTR_RET(drvr->dbgfs_dir); return PTR_ERR_OR_ZERO(drvr->dbgfs_dir);
} }
void brcmf_debugfs_detach(struct brcmf_pub *drvr) void brcmf_debugfs_detach(struct brcmf_pub *drvr)

View File

@ -56,7 +56,7 @@ int brcms_debugfs_attach(struct brcms_pub *drvr)
drvr->dbgfs_dir = debugfs_create_dir( drvr->dbgfs_dir = debugfs_create_dir(
dev_name(&drvr->wlc->hw->d11core->dev), root_folder); dev_name(&drvr->wlc->hw->d11core->dev), root_folder);
return PTR_RET(drvr->dbgfs_dir); return PTR_ERR_OR_ZERO(drvr->dbgfs_dir);
} }
void brcms_debugfs_detach(struct brcms_pub *drvr) void brcms_debugfs_detach(struct brcms_pub *drvr)

View File

@ -176,7 +176,7 @@ static int __init samsungq10_init(void)
samsungq10_probe, samsungq10_probe,
NULL, 0, NULL, 0); NULL, 0, NULL, 0);
return PTR_RET(samsungq10_device); return PTR_ERR_OR_ZERO(samsungq10_device);
} }
static void __exit samsungq10_exit(void) static void __exit samsungq10_exit(void)

View File

@ -219,7 +219,7 @@ static int fan53555_regulator_register(struct fan53555_device_info *di,
rdesc->owner = THIS_MODULE; rdesc->owner = THIS_MODULE;
di->rdev = regulator_register(&di->desc, config); di->rdev = regulator_register(&di->desc, config);
return PTR_RET(di->rdev); return PTR_ERR_OR_ZERO(di->rdev);
} }

View File

@ -901,7 +901,7 @@ static int plat_mpc8xxx_spi_probe(struct platform_device *pdev)
return -EINVAL; return -EINVAL;
master = fsl_spi_probe(&pdev->dev, mem, irq); master = fsl_spi_probe(&pdev->dev, mem, irq);
return PTR_RET(master); return PTR_ERR_OR_ZERO(master);
} }
static int plat_mpc8xxx_spi_remove(struct platform_device *pdev) static int plat_mpc8xxx_spi_remove(struct platform_device *pdev)

View File

@ -603,7 +603,7 @@ static int spidev_probe(struct spi_device *spi)
dev = device_create(spidev_class, &spi->dev, spidev->devt, dev = device_create(spidev_class, &spi->dev, spidev->devt,
spidev, "spidev%d.%d", spidev, "spidev%d.%d",
spi->master->bus_num, spi->chip_select); spi->master->bus_num, spi->chip_select);
status = PTR_RET(dev); status = PTR_ERR_OR_ZERO(dev);
} else { } else {
dev_dbg(&spi->dev, "no minor number available!\n"); dev_dbg(&spi->dev, "no minor number available!\n");
status = -ENODEV; status = -ENODEV;

View File

@ -189,7 +189,7 @@ int dss_debugfs_create_file(const char *name, void (*write)(struct seq_file *))
d = debugfs_create_file(name, S_IRUGO, dss_debugfs_dir, d = debugfs_create_file(name, S_IRUGO, dss_debugfs_dir,
write, &dss_debug_fops); write, &dss_debug_fops);
return PTR_RET(d); return PTR_ERR_OR_ZERO(d);
} }
#else /* CONFIG_OMAP2_DSS_DEBUGFS */ #else /* CONFIG_OMAP2_DSS_DEBUGFS */
static inline int dss_initialize_debugfs(void) static inline int dss_initialize_debugfs(void)

View File

@ -747,7 +747,7 @@ int btrfs_resume_dev_replace_async(struct btrfs_fs_info *fs_info)
WARN_ON(atomic_xchg( WARN_ON(atomic_xchg(
&fs_info->mutually_exclusive_operation_running, 1)); &fs_info->mutually_exclusive_operation_running, 1));
task = kthread_run(btrfs_dev_replace_kthread, fs_info, "btrfs-devrepl"); task = kthread_run(btrfs_dev_replace_kthread, fs_info, "btrfs-devrepl");
return PTR_RET(task); return PTR_ERR_OR_ZERO(task);
} }
static int btrfs_dev_replace_kthread(void *data) static int btrfs_dev_replace_kthread(void *data)

View File

@ -3166,7 +3166,7 @@ int btrfs_orphan_cleanup(struct btrfs_root *root)
found_key.type = BTRFS_INODE_ITEM_KEY; found_key.type = BTRFS_INODE_ITEM_KEY;
found_key.offset = 0; found_key.offset = 0;
inode = btrfs_iget(root->fs_info->sb, &found_key, root, NULL); inode = btrfs_iget(root->fs_info->sb, &found_key, root, NULL);
ret = PTR_RET(inode); ret = PTR_ERR_OR_ZERO(inode);
if (ret && ret != -ESTALE) if (ret && ret != -ESTALE)
goto out; goto out;

View File

@ -590,7 +590,7 @@ int __init bt_sysfs_init(void)
bt_class = class_create(THIS_MODULE, "bluetooth"); bt_class = class_create(THIS_MODULE, "bluetooth");
return PTR_RET(bt_class); return PTR_ERR_OR_ZERO(bt_class);
} }
void bt_sysfs_cleanup(void) void bt_sysfs_cleanup(void)

View File

@ -64,7 +64,7 @@ static int ebt_broute(struct sk_buff *skb)
static int __net_init broute_net_init(struct net *net) static int __net_init broute_net_init(struct net *net)
{ {
net->xt.broute_table = ebt_register_table(net, &broute_table); net->xt.broute_table = ebt_register_table(net, &broute_table);
return PTR_RET(net->xt.broute_table); return PTR_ERR_OR_ZERO(net->xt.broute_table);
} }
static void __net_exit broute_net_exit(struct net *net) static void __net_exit broute_net_exit(struct net *net)

View File

@ -100,7 +100,7 @@ static struct nf_hook_ops ebt_ops_filter[] __read_mostly = {
static int __net_init frame_filter_net_init(struct net *net) static int __net_init frame_filter_net_init(struct net *net)
{ {
net->xt.frame_filter = ebt_register_table(net, &frame_filter); net->xt.frame_filter = ebt_register_table(net, &frame_filter);
return PTR_RET(net->xt.frame_filter); return PTR_ERR_OR_ZERO(net->xt.frame_filter);
} }
static void __net_exit frame_filter_net_exit(struct net *net) static void __net_exit frame_filter_net_exit(struct net *net)

View File

@ -100,7 +100,7 @@ static struct nf_hook_ops ebt_ops_nat[] __read_mostly = {
static int __net_init frame_nat_net_init(struct net *net) static int __net_init frame_nat_net_init(struct net *net)
{ {
net->xt.frame_nat = ebt_register_table(net, &frame_nat); net->xt.frame_nat = ebt_register_table(net, &frame_nat);
return PTR_RET(net->xt.frame_nat); return PTR_ERR_OR_ZERO(net->xt.frame_nat);
} }
static void __net_exit frame_nat_net_exit(struct net *net) static void __net_exit frame_nat_net_exit(struct net *net)

View File

@ -48,7 +48,7 @@ static int __net_init arptable_filter_net_init(struct net *net)
net->ipv4.arptable_filter = net->ipv4.arptable_filter =
arpt_register_table(net, &packet_filter, repl); arpt_register_table(net, &packet_filter, repl);
kfree(repl); kfree(repl);
return PTR_RET(net->ipv4.arptable_filter); return PTR_ERR_OR_ZERO(net->ipv4.arptable_filter);
} }
static void __net_exit arptable_filter_net_exit(struct net *net) static void __net_exit arptable_filter_net_exit(struct net *net)

View File

@ -69,7 +69,7 @@ static int __net_init iptable_filter_net_init(struct net *net)
net->ipv4.iptable_filter = net->ipv4.iptable_filter =
ipt_register_table(net, &packet_filter, repl); ipt_register_table(net, &packet_filter, repl);
kfree(repl); kfree(repl);
return PTR_RET(net->ipv4.iptable_filter); return PTR_ERR_OR_ZERO(net->ipv4.iptable_filter);
} }
static void __net_exit iptable_filter_net_exit(struct net *net) static void __net_exit iptable_filter_net_exit(struct net *net)

View File

@ -107,7 +107,7 @@ static int __net_init iptable_mangle_net_init(struct net *net)
net->ipv4.iptable_mangle = net->ipv4.iptable_mangle =
ipt_register_table(net, &packet_mangler, repl); ipt_register_table(net, &packet_mangler, repl);
kfree(repl); kfree(repl);
return PTR_RET(net->ipv4.iptable_mangle); return PTR_ERR_OR_ZERO(net->ipv4.iptable_mangle);
} }
static void __net_exit iptable_mangle_net_exit(struct net *net) static void __net_exit iptable_mangle_net_exit(struct net *net)

View File

@ -292,7 +292,7 @@ static int __net_init iptable_nat_net_init(struct net *net)
return -ENOMEM; return -ENOMEM;
net->ipv4.nat_table = ipt_register_table(net, &nf_nat_ipv4_table, repl); net->ipv4.nat_table = ipt_register_table(net, &nf_nat_ipv4_table, repl);
kfree(repl); kfree(repl);
return PTR_RET(net->ipv4.nat_table); return PTR_ERR_OR_ZERO(net->ipv4.nat_table);
} }
static void __net_exit iptable_nat_net_exit(struct net *net) static void __net_exit iptable_nat_net_exit(struct net *net)

View File

@ -48,7 +48,7 @@ static int __net_init iptable_raw_net_init(struct net *net)
net->ipv4.iptable_raw = net->ipv4.iptable_raw =
ipt_register_table(net, &packet_raw, repl); ipt_register_table(net, &packet_raw, repl);
kfree(repl); kfree(repl);
return PTR_RET(net->ipv4.iptable_raw); return PTR_ERR_OR_ZERO(net->ipv4.iptable_raw);
} }
static void __net_exit iptable_raw_net_exit(struct net *net) static void __net_exit iptable_raw_net_exit(struct net *net)

View File

@ -66,7 +66,7 @@ static int __net_init iptable_security_net_init(struct net *net)
net->ipv4.iptable_security = net->ipv4.iptable_security =
ipt_register_table(net, &security_table, repl); ipt_register_table(net, &security_table, repl);
kfree(repl); kfree(repl);
return PTR_RET(net->ipv4.iptable_security); return PTR_ERR_OR_ZERO(net->ipv4.iptable_security);
} }
static void __net_exit iptable_security_net_exit(struct net *net) static void __net_exit iptable_security_net_exit(struct net *net)

View File

@ -61,7 +61,7 @@ static int __net_init ip6table_filter_net_init(struct net *net)
net->ipv6.ip6table_filter = net->ipv6.ip6table_filter =
ip6t_register_table(net, &packet_filter, repl); ip6t_register_table(net, &packet_filter, repl);
kfree(repl); kfree(repl);
return PTR_RET(net->ipv6.ip6table_filter); return PTR_ERR_OR_ZERO(net->ipv6.ip6table_filter);
} }
static void __net_exit ip6table_filter_net_exit(struct net *net) static void __net_exit ip6table_filter_net_exit(struct net *net)

View File

@ -101,7 +101,7 @@ static int __net_init ip6table_mangle_net_init(struct net *net)
net->ipv6.ip6table_mangle = net->ipv6.ip6table_mangle =
ip6t_register_table(net, &packet_mangler, repl); ip6t_register_table(net, &packet_mangler, repl);
kfree(repl); kfree(repl);
return PTR_RET(net->ipv6.ip6table_mangle); return PTR_ERR_OR_ZERO(net->ipv6.ip6table_mangle);
} }
static void __net_exit ip6table_mangle_net_exit(struct net *net) static void __net_exit ip6table_mangle_net_exit(struct net *net)

View File

@ -293,7 +293,7 @@ static int __net_init ip6table_nat_net_init(struct net *net)
return -ENOMEM; return -ENOMEM;
net->ipv6.ip6table_nat = ip6t_register_table(net, &nf_nat_ipv6_table, repl); net->ipv6.ip6table_nat = ip6t_register_table(net, &nf_nat_ipv6_table, repl);
kfree(repl); kfree(repl);
return PTR_RET(net->ipv6.ip6table_nat); return PTR_ERR_OR_ZERO(net->ipv6.ip6table_nat);
} }
static void __net_exit ip6table_nat_net_exit(struct net *net) static void __net_exit ip6table_nat_net_exit(struct net *net)

View File

@ -40,7 +40,7 @@ static int __net_init ip6table_raw_net_init(struct net *net)
net->ipv6.ip6table_raw = net->ipv6.ip6table_raw =
ip6t_register_table(net, &packet_raw, repl); ip6t_register_table(net, &packet_raw, repl);
kfree(repl); kfree(repl);
return PTR_RET(net->ipv6.ip6table_raw); return PTR_ERR_OR_ZERO(net->ipv6.ip6table_raw);
} }
static void __net_exit ip6table_raw_net_exit(struct net *net) static void __net_exit ip6table_raw_net_exit(struct net *net)

View File

@ -58,7 +58,7 @@ static int __net_init ip6table_security_net_init(struct net *net)
net->ipv6.ip6table_security = net->ipv6.ip6table_security =
ip6t_register_table(net, &security_table, repl); ip6t_register_table(net, &security_table, repl);
kfree(repl); kfree(repl);
return PTR_RET(net->ipv6.ip6table_security); return PTR_ERR_OR_ZERO(net->ipv6.ip6table_security);
} }
static void __net_exit ip6table_security_net_exit(struct net *net) static void __net_exit ip6table_security_net_exit(struct net *net)

View File

@ -1,5 +1,5 @@
/// ///
/// Use PTR_RET rather than if(IS_ERR(...)) + PTR_ERR /// Use PTR_ERR_OR_ZERO rather than if(IS_ERR(...)) + PTR_ERR
/// ///
// Confidence: High // Confidence: High
// Copyright: (C) 2012 Julia Lawall, INRIA/LIP6. GPLv2. // Copyright: (C) 2012 Julia Lawall, INRIA/LIP6. GPLv2.
@ -7,7 +7,7 @@
// URL: http://coccinelle.lip6.fr/ // URL: http://coccinelle.lip6.fr/
// Options: --no-includes --include-headers // Options: --no-includes --include-headers
// //
// Keywords: ERR_PTR, PTR_ERR, PTR_RET // Keywords: ERR_PTR, PTR_ERR, PTR_RET, PTR_ERR_OR_ZERO
// Version min: 2.6.39 // Version min: 2.6.39
// //
@ -21,21 +21,21 @@ expression ptr;
@@ @@
- if (IS_ERR(ptr)) return PTR_ERR(ptr); else return 0; - if (IS_ERR(ptr)) return PTR_ERR(ptr); else return 0;
+ return PTR_RET(ptr); + return PTR_ERR_OR_ZERO(ptr);
@depends on patch@ @depends on patch@
expression ptr; expression ptr;
@@ @@
- if (IS_ERR(ptr)) return PTR_ERR(ptr); return 0; - if (IS_ERR(ptr)) return PTR_ERR(ptr); return 0;
+ return PTR_RET(ptr); + return PTR_ERR_OR_ZERO(ptr);
@depends on patch@ @depends on patch@
expression ptr; expression ptr;
@@ @@
- (IS_ERR(ptr) ? PTR_ERR(ptr) : 0) - (IS_ERR(ptr) ? PTR_ERR(ptr) : 0)
+ PTR_RET(ptr) + PTR_ERR_OR_ZERO(ptr)
@r1 depends on !patch@ @r1 depends on !patch@
expression ptr; expression ptr;

View File

@ -158,7 +158,7 @@ int snd_soc_codec_set_cache_io(struct snd_soc_codec *codec,
return -EINVAL; return -EINVAL;
} }
return PTR_RET(codec->control_data); return PTR_ERR_OR_ZERO(codec->control_data);
} }
EXPORT_SYMBOL_GPL(snd_soc_codec_set_cache_io); EXPORT_SYMBOL_GPL(snd_soc_codec_set_cache_io);
#else #else