免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3239 | 回复: 0

uart驱动问题 [复制链接]

论坛徽章:
0
发表于 2019-05-23 16:04 |显示全部楼层
小弟最近刚开始接触linux驱动,模仿着例子在ubuntu16下写了个uart的模块,生成了设备结点/dev/ka_uart_dev_name0,但我用命令 echo kaka >> /dev/ka_uart_dev_name0时提示出错:bash: echo: write error: Input/output error,请问这是什么原因以及要怎么解决?  模块代码如下

#include <linux/serial_core.h>

#include <linux/kernel.h>

#include <linux/module.h>

#include <linux/spinlock_types.h>



static unsigned int ka_tx_empty(struct uart_port *port)

{

        printk("tiny_tx_empty()\n";

        return 0;

}



static unsigned int ka_get_mctrl(struct uart_port *port)

{

        printk("tiny_get_mctrl()\n";

        return 0;

}



static void ka_set_mctrl(struct uart_port *port, unsigned int mctrl)

{

        printk("tiny_set_mctrl()\n";

}



static void ka_break_ctl(struct uart_port *port, int break_state)

{

        printk("tiny_break_ctl()\n";

}



static void ka_stop_tx(struct uart_port *uart_port_ptr)

{

        printk("ka_stop_tx()\n";

}



static void ka_start_tx(struct uart_port *uart_port_ptr)

{

        printk("ka_start_tx()\n";

}



static void        ka_stop_rx(struct uart_port *uart_port_ptr)

{

        printk("ka_stop_rx()\n";

}



static void        ka_enable_ms(struct uart_port *uart_port_ptr)

{

        printk("ka_enable_ms()\n";

}



static void ka_set_termios(struct uart_port *port,

                             struct ktermios *new, struct ktermios *old)

{

        int baud, quot, cflag = new->c_cflag;

        printk("tiny_set_termios()\n";

        /* get the byte size */

        switch (cflag & CSIZE) {

        case CS5:

                printk(KERN_DEBUG " - data bits = 5\n";

                break;

        case CS6:

                printk(KERN_DEBUG " - data bits = 6\n");

                break;

        case CS7:

                printk(KERN_DEBUG " - data bits = 7\n");

                break;

        default: // CS8

                printk(KERN_DEBUG " - data bits = 8\n");

                break;

        }



        /* determine the parity */

        if (cflag & PARENB)

                if (cflag & PARODD)

                        pr_debug(" - parity = odd\n");

                else

                        pr_debug(" - parity = even\n");

        else

                pr_debug(" - parity = none\n");



        /* figure out the stop bits requested */

        if (cflag & CSTOPB)

                pr_debug(" - stop bits = 2\n");

        else

                pr_debug(" - stop bits = 1\n");



        /* figure out the flow control settings */

        if (cflag & CRTSCTS)

                pr_debug(" - RTS/CTS is enabled\n");

        else

                pr_debug(" - RTS/CTS is disabled\n");



        /* Set baud rate */

        baud = uart_get_baud_rate(port, new, old, 0, port->uartclk/16);

        quot = uart_get_divisor(port, baud);

       

        //UART_PUT_DIV_LO(port, (quot & 0xff));

        //UART_PUT_DIV_HI(port, ((quot & 0xf00) >> );

}



static int ka_startup(struct uart_port *port)

{

        printk("tiny_startup()\n");

        /* this is the first time this port is opened */

        /* do any hardware initialization needed here */



#ifdef TIMER_EN

        /* create our timer and submit it */

        if (!timer) {

                timer = kmalloc(sizeof(*timer), GFP_KERNEL);

                if (!timer)

                        return -ENOMEM;

        }

        timer->data = (unsigned long)port;

        timer->expires = jiffies + DELAY_TIME;

        timer->function = tiny_timer;

        add_timer(timer);

#endif

        return 0;

}





static void ka_shutdown(struct uart_port *port)

{

        printk("tiny_shutdown()\n");

        /* The port is being closed by the last user. */

        /* Do any hardware specific stuff here */



}



static const char *ka_type(struct uart_port *port)

{

        printk("tiny_type()\n");

        return "katty";

}



static void ka_release_port(struct uart_port *port)

{

        printk("tiny_release_port()\n");

}



static int ka_request_port(struct uart_port *port)

{

        printk("tiny_request_port()\n");

        return 0;

}



static void ka_config_port(struct uart_port *port, int flags)

{

        printk("tiny_config_port()\n");

}



static int ka_verify_port(struct uart_port *port, struct serial_struct *ser)

{

        printk("tiny_verify_port()\n");

        return 0;

}



static void        ka_pm(struct uart_port *port, unsigned int state,

                              unsigned int oldstate)

{

        printk("ka_pm()\n");

}



static void  ka_throttle(struct uart_port *port)

{

        printk("ka_throttle()\n");

}

static void  ka_unthrottle(struct uart_port *port)

{

        printk("ka_unthrottle()\n");

}

static void  ka_send_xchar(struct uart_port *port, char ch)

{

        printk("ka_send_xchar()\n");

}

static void  ka_flush_buffer(struct uart_port *port)

{

        printk("ka_flush_buffer()\n");

}

static void  ka_set_ldisc(struct uart_port *port, struct ktermios *k)

{

        printk("ka_set_ldisc()\n");

}

static int   ka_ioctl(struct uart_port *port, unsigned int f, unsigned long d)

{

        printk("ka_ioctl()\n");

        return 0;

}



static struct uart_ops ka_ops = {

        .tx_empty        = ka_tx_empty,

        .set_mctrl        = ka_set_mctrl,

        .get_mctrl        = ka_get_mctrl,

        .stop_tx        = ka_stop_tx,

        .start_tx        = ka_start_tx,

        .stop_rx        = ka_stop_rx,

        .enable_ms        = ka_enable_ms,

        .break_ctl        = ka_break_ctl,

        .startup        = ka_startup,

        .shutdown        = ka_shutdown,

        .set_termios        = ka_set_termios,

        .type                = ka_type,

        .release_port        = ka_release_port,

        .request_port        = ka_request_port,

        .config_port        = ka_config_port,

        .verify_port        = ka_verify_port,

        .pm = ka_pm,

        .throttle = ka_throttle,

        .unthrottle = ka_unthrottle,

        .send_xchar = ka_send_xchar,

        .flush_buffer = ka_flush_buffer,

        .set_ldisc = ka_set_ldisc,

        .ioctl = ka_ioctl,

};



/*

#define __RAW_SPIN_LOCK_INITIALIZER(lockname)        \

        {                                        \

        .raw_lock = __ARCH_SPIN_LOCK_UNLOCKED,        \

        SPIN_DEBUG_INIT(lockname)                \

        SPIN_DEP_MAP_INIT(lockname) }



#define __SPIN_LOCK_INITIALIZER(lockname) \

        { { .rlock = __RAW_SPIN_LOCK_INITIALIZER(lockname) } }



#define __SPIN_LOCK_UNLOCKED(lockname) \

        (spinlock_t ) __SPIN_LOCK_INITIALIZER(lockname)

*/

static struct uart_port ka_port = {

        .ops                = &ka_ops,

        .line                 = 0,

        .fifosize        = 16,

        .uartclk        = 0,

        .iotype = UPIO_MEM,

        .line                 = 0,

        .flags                = UPF_BOOT_AUTOCONF,

        .lock = __SPIN_LOCK_UNLOCKED(ka_port.lock),

};











static struct uart_driver ka_driver = {

        .owner                = THIS_MODULE,

        .driver_name        = "ka_uart_driver_name",

        .dev_name        = "ka_uart_dev_name",

        .major                = 289,

        .minor                = 1,

        .nr                = 1,

};



static int __init ka_init(void)

{

        int result;

        printk("ka_init()\n");

        result = uart_register_driver(&ka_driver);

        if (result)

        {

                printk("oops line %u\n",__LINE__);

                return result;

        }



        result = uart_add_one_port(&ka_driver, &ka_port);

        if (result)

        {

                printk("oops line %u\n",__LINE__);

                uart_unregister_driver(&ka_driver);

        }



        return result;

}

module_init(ka_init);



static void __exit ka_exit(void)

{

        printk("ka_exit()\n");

        uart_remove_one_port(&ka_driver, &ka_port);

        uart_unregister_driver(&ka_driver);

}

module_exit(ka_exit);



MODULE_LICENSE("Dual BSD/GPL");

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

ITPUB技术栈

ITPUB技术栈:http://z.itpub.net/
ITPUB技术栈是由ITPUB社区打造的垂直于IT领域的知识交流平台,在这里,你既可以是创作者也可以是消费者。如果你的IT生涯丰富多彩,喷薄的个人价值尽可在小栈内体现;如果你渴望找到志同道合的伙伴,拓宽人脉,小栈会是你最好的选择。





点击进入>>
  

北京盛拓优讯信息技术有限公司. 版权所有 16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122
中国互联网协会会员  联系我们:huangweiwei@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP