lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1436535163.20619.216.camel@tiscali.nl>
Date:	Fri, 10 Jul 2015 15:32:43 +0200
From:	Paul Bolle <pebolle@...cali.nl>
To:	Roy Pledge <Roy.Pledge@...escale.com>
Cc:	linuxppc-dev@...ts.ozlabs.org, scottwood@...escale.com,
	netdev@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH 03/11] soc/fsl: Introduce the DPAA BMan portal driver

On do, 2015-07-09 at 16:21 -0400, Roy Pledge wrote:
> --- a/drivers/soc/fsl/qbman/Kconfig
> +++ b/drivers/soc/fsl/qbman/Kconfig

> +config FSL_DPA_PIRQ_FAST
> +	bool
> +	default y

First used in 04/11.

> +config FSL_DPA_PIRQ_SLOW
> +	bool
> +	default y
> +
> +config FSL_DPA_PORTAL_SHARE
> +	bool
> +	default y

As in 02/11: these three symbols function as aliases for FSL_DPA. Why
are they needed? 

>  config FSL_BMAN
>  	tristate "BMan device management"
>  	default n
>  	help
>  		FSL DPAA BMan driver
>  
> +config FSL_BMAN_PORTAL
> +	tristate "BMan portal(s)"
> +	default n
> +	help
> +		FSL BMan portal driver

> --- /dev/null
> +++ b/drivers/soc/fsl/qbman/bman_api.c

> +struct bman_portal {
> +	[...]
> +#ifdef CONFIG_FSL_DPA_CAN_WAIT_SYNC

This check will always evaluate to true, right? (I'll only report this
once.)

> +	struct bman_pool *rcri_owned; /* only 1 release WAIT_SYNC at 
> a time */
> +#endif
> +#ifdef CONFIG_FSL_DPA_PORTAL_SHARE

Ditto.

> +	raw_spinlock_t sharing_lock; /* only used if is_shared */
> +	int is_shared;
> +	struct bman_portal *sharing_redirect;
> +#endif
> +	[...]
> +};

> +const struct bman_portal_config *bman_get_portal_config(void)
> +{
> +	[...]
> +}

I couldn't find callers of this function.

> +EXPORT_SYMBOL(bman_get_portal_config);

Nor users of this export, obviously.

> +
> +u32 bman_irqsource_get(void)
> +{
> +	[...]
> +}

Ditto.

> +EXPORT_SYMBOL(bman_irqsource_get);

Ditto.

> +int bman_p_irqsource_add(struct bman_portal *p, __maybe_unused u32 bits)
> +{
> +	[...]
> +}
> +EXPORT_SYMBOL(bman_p_irqsource_add);

There seem to be no users of this export.

> +int bman_irqsource_add(__maybe_unused u32 bits)
> +{
> +	[...]
> +}

Unused.

> +EXPORT_SYMBOL(bman_irqsource_add);

Ditto.

> +int bman_irqsource_remove(u32 bits)
> +{
> +	[...]
> +}

Ditto. 

> +EXPORT_SYMBOL(bman_irqsource_remove);

Ditto.

> +u32 bman_poll_slow(void)
> +{
> +	[...]
> +}

Ditto.

> +EXPORT_SYMBOL(bman_poll_slow);

Ditto.

> +void bman_poll(void)
> +{
> +	[...]
> +}

Ditto.

> +EXPORT_SYMBOL(bman_poll);

Ditto.

> +static inline struct bm_rcr_entry *try_rel_start(struct bman_portal **p,
> +#ifdef CONFIG_FSL_DPA_CAN_WAIT

Always true, right?

> +					__maybe_unused struct bman_pool *pool,
> +#endif
> +					__maybe_unused unsigned long *irqflags,
> +					__maybe_unused u32 flags)

And this is a, well, novel way to declare a function.

> +{
> +	[...]
> +}

> +int bman_flush_stockpile(struct bman_pool *pool, u32 flags)
> +{
> +	[...]
> +}

Unused function.

> +EXPORT_SYMBOL(bman_flush_stockpile);

So unused export too.

> +#ifdef CONFIG_FSL_BMAN
> +u32 bman_query_free_buffers(struct bman_pool *pool)
> +{
> +	return bm_pool_free_buffers(pool->params.bpid);
> +}
> +EXPORT_SYMBOL(bman_query_free_buffers);
> +
> +int bman_update_pool_thresholds(struct bman_pool *pool, const u32 *thresholds)
> +{
> +	u32 bpid;
> +
> +	bpid = bman_get_params(pool)->bpid;
> +
> +	return bm_pool_set(bpid, thresholds);
> +}
> +EXPORT_SYMBOL(bman_update_pool_thresholds);

More of the same.

> +#endif

> --- /dev/null
> +++ b/drivers/soc/fsl/qbman/bman_portal.c
> 
> +module_driver(bman_portal_driver,
> +	       bman_portal_driver_register, platform_driver_unregister);

No MODULE_LICENSE() here, nor in the other files that make up this
module. So loading this module will trigger a warning and taint the
kernel.

> --- /dev/null
> +++ b/drivers/soc/fsl/qbman/bman_utils.c

> +EXPORT_SYMBOL(bman_alloc_bpid_range);

Unused export.

> +EXPORT_SYMBOL(bman_release_bpid_range);

Ditto.

> +EXPORT_SYMBOL(bman_seed_bpid_range);

Ditto.

> +int bman_reserve_bpid_range(u32 bpid, u32 count)
> +{
> +	return dpaa_resource_reserve(&bpalloc, bpid, count);
> +}
> +EXPORT_SYMBOL(bman_reserve_bpid_range);

Because bman_reserve_bpid() is unused, see below, this function and this
export are unused too.

> --- /dev/null
> +++ b/drivers/soc/fsl/qbman/dpaa_resource.c
> 
> +#if defined(CONFIG_FSL_BMAN_PORTAL) || defined(CONFIG_FSL_BMAN_PORTAL_MODULE)

#if IS_ENABLED(CONFIG_FSL_BMAN_PORTAL)

> +#ifdef DPAA_RESOURCE_DEBUG

Never defined. So DUMP() is dead code.

> --- a/drivers/soc/fsl/qbman/dpaa_sys.h
> +++ b/drivers/soc/fsl/qbman/dpaa_sys.h
> 
> +#define CONFIG_TRY_BETTER_MEMCPY

Please replace the CONFIG_ prefix with something else.

> +#ifdef CONFIG_TRY_BETTER_MEMCPY

This will always be true, right?

> [...]
> +#else
> +#define copy_words memcpy
> +#define copy_shorts memcpy
> +#define copy_bytes memcpy
> +#endif

> --- /dev/null
> +++ b/include/soc/fsl/bman.h

> +static inline int bman_reserve_bpid(u32 bpid)
> +{
> +	return bman_reserve_bpid_range(bpid, 1);
> +}

Unused.

Thanks,


Paul Bolle
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ