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] [day] [month] [year] [list]
Message-ID: <53269056.6000903@hitachi.com>
Date:	Mon, 17 Mar 2014 15:04:06 +0900
From:	Yoshihiro YUNOMAE <yoshihiro.yunomae.ez@...achi.com>
To:	One Thousand Gnomes <gnomes@...rguk.ukuu.org.uk>
Cc:	Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
	Heikki Krogerus <heikki.krogerus@...ux.intel.com>,
	Stephen Warren <swarren@...dia.com>,
	Jingoo Han <jg1.han@...sung.com>, linux-kernel@...r.kernel.org,
	Hidehiro Kawai <hidehiro.kawai.ez@...achi.com>,
	linux-serial@...r.kernel.org, yrl.pp-manager.tt@...achi.com,
	Masami Hiramatsu <masami.hiramatsu.pt@...achi.com>,
	Aaron Sierra <asierra@...-inc.com>, Jiri Slaby <jslaby@...e.cz>
Subject: Re: Re: [PATCH V3] serial/uart/8250: Add tunable RX interrupt
 trigger I/F of FIFO buffers

Hi Alan,

Thank you for your reply.

(2014/03/14 21:04), One Thousand Gnomes wrote:
>> @@ -2325,10 +2323,19 @@ serial8250_do_set_termios(struct uart_port *port, struct ktermios *termios,
>>   		if ((baud < 2400 && !up->dma) || fifo_bug) {
>>   			fcr &= ~UART_FCR_TRIGGER_MASK;
>>   			fcr |= UART_FCR_TRIGGER_1;
>> +			/* Don't use user setting RX trigger */
>> +			up->fcr = 0;
>
> This breaks
>
> 	set fcr via sysfs
> 	set baud rate below 2400
> 	set baud rate higher
>
> If baud < 2400 and the user has set a value then probably we should honour

OK, I'll add !up->fcr in this flow as follows:

/* NOTE: If fifo_bug is not set, a user can set RX trigger. */
if ((baud < 2400 && !up->dma && !up->fcr) || fifo_bug) {
      fcr &= ~UART_TRIGGER_MASK;
      fcr |= UART_FCR_TRIGGER_1;
      up->fcr = 0;
}

> it. If fifo_bug is set then we should never honour it (and should perhaps
> eventually error it in the sysfs set).

When fifo_bug is set to "1", we need to check not only
whether (up->bugs & UART_BUG_PARITY) but whether parity is enabled.
We can check whether parity is enable only in this function currently,
so I think we need to store fifo_bug's value into up->fifo_bug and
refer it in the sysfs set(do_set_rx_int_trig()) as follows:

@do_set_rx_int_trig()
     if (!(up->capabilities & UART_CAP_FIFO) || uport->fifosize <= 1
         || (up->fifo_bug & UART_BUG_PARITY))
         return -EINVAL;

>
>> +static unsigned char convert_fcr2val(struct uart_8250_port *up,
>> +				     unsigned char fcr)
>> +{
>> +	unsigned char val = 0, trig_raw = fcr & UART_FCR_TRIGGER_MASK;
>> +
>> +	switch (up->port.type) {
>> +	case PORT_16550A:
>> +		if (trig_raw == UART_FCR_R_TRIG_00)
>> +			val = 1;
>> +		else if (trig_raw == UART_FCR_R_TRIG_01)
>> +			val = 4;
>> +		else if (trig_raw == UART_FCR_R_TRIG_10)
>> +			val = 8;
>> +		else if (trig_raw == UART_FCR_R_TRIG_11)
>> +			val = 14;
>> +		break;
>
> Surely the default case should be returning 1 not 0 ?

In the default case, it returns "0" meaning error because "1" has
other meaning (1 byte RX trigger). But, "0" is not instinctive value for
the error, so it should return -EOPNOTSUPP here.

>
>> +static int convert_val2rxtrig(struct uart_8250_port *up, unsigned char val)
>> +{
>> +	switch (up->port.type) {
>> +	case PORT_16550A:
>> +		if (val == 1)
>> +			return UART_FCR_R_TRIG_00;
>> +		else if (val == 4)
>> +			return UART_FCR_R_TRIG_01;
>> +		else if (val == 8)
>> +			return UART_FCR_R_TRIG_10;
>> +		else if (val == 14)
>> +			return UART_FCR_R_TRIG_11;
>
> What happens if you specify a meaningless value. Doing exact matching
> means that you have to know the hardware exactly. How about
>
> 	if (val < 4)
> 		return UART_FCR_R_TRIG_00;
> 	else if (val < 8)
> 		return UART_FCR_R_TRIG_01;
> 	else if (val < 14)
> 		return UART_FCR_R_TRIG_10;
> 	else
> 		return UART_FCR_R_TRIG_11;
>
> so you get the nearest lower value that the hardware can provide ?

It is a good idea. I was concerned about the same thing which users
must know the HW exactly.

I'll implement it as you say.

>> +		break;
>> +	default:
>> +		pr_info("Not support RX-trigger setting for this serial %u\n",
>> +			up->port.type);
>
> That lets users spew into the logs. I think actually you just want
>
> 	default:
> 		return -EOPNOTSUPP;

OK, I'll use this.

Thank you,

Yoshihiro YUNOMAE

-- 
Yoshihiro YUNOMAE
Software Platform Research Dept. Linux Technology Center
Hitachi, Ltd., Yokohama Research Laboratory
E-mail: yoshihiro.yunomae.ez@...achi.com


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