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: <20110430110705.5ca3376b@lxorguk.ukuu.org.uk>
Date:	Sat, 30 Apr 2011 11:07:05 +0100
From:	Alan Cox <alan@...rguk.ukuu.org.uk>
To:	Vivien Didelot <vivien.didelot@...oirfairelinux.com>
Cc:	linux-kernel@...r.kernel.org,
	Jonas Fonseca <jonas.fonseca@...oirfairelinux.com>,
	platform-driver-x86@...r.kernel.org, linux-serial@...r.kernel.org,
	lm-sensors@...sensors.org
Subject: Re: [RFC 1/5] platform-drivers-x86: add support for Technologic
 Systems TS-5xxx detection

> + * ts5xxx_sbcinfo_set() - set the SBC info structure with the current SBC's info
> + * @sbcinfo:		structure containing SBC info to set.
> + */
> +void ts5xxx_sbcinfo_set(struct ts5xxx_sbcinfo *sbcinfo)
> +{
> +	memcpy(sbcinfo, &ts_sbcinfo, sizeof(*sbcinfo));
> +}
> +EXPORT_SYMBOL(ts5xxx_sbcinfo_set);

You export this but it's not clear who for or why - and there is also no
locking, so it seems to be an internal interface ?


> +/**
> + * ts_find_sbc_config() - find a SBC configuration from an id
> + * @id:			ID of the board to find.
> + */
> +static inline struct ts_sbc_config *ts_find_sbc_config(u8 id)
> +{
> +	int i;
> +
> +	for (i = 0; i < ARRAY_SIZE(ts_sbcs_configs); i++)
> +		if (id == ts_sbcs_configs[i].id)
> +			return &ts_sbcs_configs[i];
> +
> +	return NULL;
> +}

gcc will figure out inlines for you in static stuff and normally very well

> +
> +/**
> + * ts_sbcinfo_detect() - detect the TS board
> + * @sbcinfo:		structure where to store the detected board's info.
> + */
> +static int ts_sbcinfo_detect(struct ts5xxx_sbcinfo *sbcinfo)
> +{
> +	u8 temp;
> +	struct ts_sbc_config *sbc;
> +	int ret = 0;
> +
> +	memset(sbcinfo, 0, sizeof(*sbcinfo));
> +
> +	if (!request_region(IOADDR_SBCID, 4, "TS-SBC"))
> +		return -EBUSY;
> +
> +	temp = inb(IOADDR_SBCID);
> +	/* If it is a 3x00 SBC only match against the first 3 bits */
> +	if (temp & 0x07)
> +		temp &= 0x07;

So if this is compiled into a kernel we blindly inb this address and some
platform just crashed on boot. Is this board like other embedded ones in
that there is some safe way to check if its such a board first ?

> +
> +	sbc = ts_find_sbc_config(temp);
> +	if (!sbc) {
> +		ret = -ENODEV;

Assuming you've indentified the board properly this case might be worth a
pr_err giving the fact it seemed to be a TS-5xxx, the config number and
that it is unknown - that will help anyone with future boards realise
their config isn't supported.


> +
> +/**
> + * ts_sbcinfo_proc_read() - function called when a read access is done on
> + *                          /proc/ts-sbcinfo
> + */
> +static int ts_sbcinfo_proc_read(char *page, char **start, off_t off,
> +				int count, int *eof, void *data)
> +{
> +	int to_copy = (procfs_buffer_size <= count) ?
> +		procfs_buffer_size - off : count;

> +
> +	if (off + to_copy >= procfs_buffer_size) {
> +		to_copy = procfs_buffer_size - off;
> +		*eof = 1;
> +	}

Suppose off is 0x7FFFFFFF and count = 100

	to_copy = 100
	off + to_copy >= procfs_buffer_size   [off_t may be 32bit]

	100 + 0x7FFFFFFF (wraps) < buffer size


> +static int __init ts5xxx_sbcinfo_init(void)
> +{
> +	int err;
> +
> +	err = ts_sbcinfo_detect(&ts_sbcinfo);
> +	if (err < 0) {
> +		printk(KERN_ERR KBUILD_MODNAME
> +		       ": Failed to get SBC information\n");
> +		return err;
> +	}

Well that will depend why and probably the caller can give the best
information including silence if the board is just not a ts-5xxx

> +	proc_entry = create_proc_read_entry(PROCFS_NAME, S_IRUGO, NULL,
> +					    ts_sbcinfo_proc_read, 0);
> +	if (proc_entry == NULL) {
> +		printk(KERN_ERR KBUILD_MODNAME
> +		       ": Failed to create proc entry\n");

pr_err

> +		return -ENOMEM;
> +	}
> +
> +	procfs_buffer_size = ts_sbcinfo_init_buffer(procfs_buffer, &ts_sbcinfo);
> +	printk(KBUILD_MODNAME ": TS SBC's info driver loaded.\n");

Printk not needed

Alan
--
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