On Mon, May 28, 2018 at 03:59:46PM +0000, Oleksandr Shamray wrote: > > > + const struct jtag_ops *ops; > > > + int id; > > > + bool opened; > > > > You shouldn't care about this, but ok... > > Jtag HW not support to using with multiple requests from different users. So we prohibit this. Ok, but then that's a userspace problem, not your driver's problem. Serial ports can't handle multiple requests in a sane way either, and so it's a userspace bug if they do that. It's not up to the kernel to try to prevent it, and really, you are not preventing this from happening at all, you are only keeping more than one open() call from happening. You aren't serializing the device access at all. So you are giving yourself a false sense of "We are protecting the device" here. Just drop the whole "only one open() call" logic entirely. It will make your kernel code simpler and you aren't giving yourself false-hope that you really prevented userspace from doing something stupid :) > > > + case JTAG_IOCRUNTEST: > > > + if (copy_from_user(&idle, (const void __user *)arg, > > > + sizeof(struct jtag_run_test_idle))) > > > + return -EFAULT; > > > + > > > + if (idle.endstate > JTAG_STATE_PAUSEDR) > > > + return -EINVAL; > > > > No validation that idle contains sane values? Don't make every jtag driver > > have to do this type of validation please. > > > > I have partially validation of idle structure (if (idle.endstate > JTAG_STATE_PAUSEDR)). > But I will add more validation. Go to the nearest whiteboard and write this at the top: ALL INPUT IS EVIL Don't erase it. You have to validate all the things, otherwise something bad will happen, I guarantee it. Wait until the syzbot gets ahold of this layer if you don't believe me :) > > > +static int jtag_open(struct inode *inode, struct file *file) { > > > + struct jtag *jtag = container_of(file->private_data, struct jtag, > > > +miscdev); > > > + > > > + if (mutex_lock_interruptible(&jtag->open_lock)) > > > + return -ERESTARTSYS; > > > > Why restart? Just grab the lock, you don't want to have to do restartable > > logic in userspace, right? > > Will change like: > > ret = mutex_lock_interruptible(&jtag->open_lock); > if (ret) > return ret; No, what's wrong with a simple: mutex_lock(); ? You are only holding it for a very short time, people can wait, there is no rush here or "fast path" happening. Anyway, this whole lock should just go away entirely, due to the lack of needing to track open() calls. But in the future, keep locks simple, no need to add complexity when it is not warranted. > > > + if (jtag->opened) { > > > + mutex_unlock(&jtag->open_lock); > > > + return -EBUSY; > > > > Why do you care about only 1 userspace open call? What does that buy you? > > Userspace can always pass around that file descriptor and use it in multiple > > places, so you are not really "protecting" yourself from anything. > > > > Accessing to JTAG HW from multiple processes will make confusion in the work of the JTAG protocol. > And I want to prohibit this. See my previous comments for why your attempt at protecting open() does not prevent this from happening. Hint, you forgot about dup(3) :( thanks, greg k-h -- To unsubscribe from this list: send the line "unsubscribe linux-serial" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html