TTY: snyclinkmp: forever loop in tx_load_dma_buffer()
authorDan Carpenter <dan.carpenter@oracle.com>
Tue, 27 Sep 2011 06:20:50 +0000 (09:20 +0300)
committerGreg Kroah-Hartman <gregkh@suse.de>
Thu, 29 Sep 2011 20:23:33 +0000 (13:23 -0700)
My main concern here was the line that said:
copy_count = min_t(unsigned short,count,SCABUFSIZE);
"count" is an unsigned int here so the cast to unsigned short
truncates the upper bits.  So if count is 0x10000 then copy_count is
0 and the loop never exits.

"count" comes from skb->len in hdlcdev_xmit().

The other min_t() changes are just cleanups.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/tty/synclinkmp.c

index c77831c7675a948db7837c5924380ecd75b9ccd6..0f6b796c95c55015442f9ac1b02ecd89673527f6 100644 (file)
@@ -4950,7 +4950,7 @@ CheckAgain:
 
        if ( debug_level >= DEBUG_LEVEL_DATA )
                trace_block(info,info->rx_buf_list_ex[StartIndex].virt_addr,
-                       min_t(int, framesize,SCABUFSIZE),0);
+                       min_t(unsigned int, framesize, SCABUFSIZE), 0);
 
        if (framesize) {
                if (framesize > info->max_frame_size)
@@ -5015,14 +5015,14 @@ static void tx_load_dma_buffer(SLMP_INFO *info, const char *buf, unsigned int co
        SCADESC_EX *desc_ex;
 
        if ( debug_level >= DEBUG_LEVEL_DATA )
-               trace_block(info,buf, min_t(int, count,SCABUFSIZE), 1);
+               trace_block(info, buf, min_t(unsigned int, count, SCABUFSIZE), 1);
 
        /* Copy source buffer to one or more DMA buffers, starting with
         * the first transmit dma buffer.
         */
        for(i=0;;)
        {
-               copy_count = min_t(unsigned short,count,SCABUFSIZE);
+               copy_count = min_t(unsigned int, count, SCABUFSIZE);
 
                desc = &info->tx_buf_list[i];
                desc_ex = &info->tx_buf_list_ex[i];