tag 标签: ft5406

相关博文
  • 热度 20
    2012-4-18 10:34
    2705 次阅读|
    1 个评论
         static int __devexit ft5x0x_ts_remove(struct i2c_client *client)   {       struct ft5x0x_ts_data *ft5x0x_ts = i2c_get_clientdata(client);      #ifdef CONFIG_HAS_EARLYSUSPEND       unregister_early_suspend(ft5x0x_ts-early_suspend);   #endif       free_irq(client-irq, ft5x0x_ts);       input_unregister_device(ft5x0x_ts-input_dev);       kfree(ft5x0x_ts);       cancel_work_sync(ft5x0x_ts-pen_event_work);       destroy_workqueue(ft5x0x_ts-ts_workqueue);       i2c_set_cleintdata(client, NULL);          return 0;   }       static const struct i2c_device_id  ft5x0x_ts_id[] = {       {FT5X0X_NAME, 0}   };   MODULE_DEVICE_TABLE(i2c, ft5x0x_id);      static struct i2c_driver ft5x0x_ts_driver = {       .probe    = ft5x0x_ts_probe,       .remove   = __devexit_p(ft5x0x_ts_remove),       .id_table = ft5x0x_ts_id,       .driver   = {           .name  = FT5X0X_TS,           .owner = THIS_MODULE,       },   };      static int __init ft5x0x_ts_init(void)   {       int ret;          ret = i2c_add_driver(ft5x0x_ts_driver);          return ret;   }      static void __exit ft5x0x_ts_exit(void)   {       i2c_delete_driver(ft5x0x_ts_driver);   }      module_init(ft5x0x_ts_init);   module_exit(ft5x0x_ts_exit);    
  • 热度 17
    2012-4-18 10:33
    2936 次阅读|
    1 个评论
         static void ft5x0x_ts_pen_irq_work(struct work_struct *work)   {       int ret = -1;          ret = ft5x0x_read_data();       if (ret == 0)           ft5x0x_report_value();   }      static interrupt_r ft5x0x_ts_interrupt(int irq, void *dev_id)   {       struct ft5x0x_ts_data *ft5x0x_ts = dev_id;          if (!work_pending(ft5x0x_ts-pen_irq_work))           queue_work(ft5x0x_ts-ts_workqueue, ft5x0x_ts-pen_irq_work);          return IRQ_HANDLED;   }      #ifdef CONFIG_HAS_EARLYSUSPEND   static void ft5x0x_ts_suspend(struct early_suspend *handler)   {       struct ft5x0x_ts_data *ft5x0x_ts;          ts = container_of(handler, struct ft5x0x_ts_data, early_suspend);       disable_irq(this_client-irq);       cancel_workqueue(ft5x0x_ts-pen_irq_work);       flush_workqueue(ft5x0x_ts-ts_workqueue);          ft5x0x_write_reg(FT5X0X_REG_PMODE, PMODE_MONITOR);          printk(" %s\n", __func__);   }      static void ft5x0x_ts_resume(struct early_suspend *handler)   {       ventana_touchscreen_reset();          enable_irq(this_client-irq);              ft5x0x_write_reg(FT5X0X_REG_PMODE, PMODE_ACTIVE);              printk(" %s\n", __func__);   }   #endif      static int ft5x0x_ts_probe(struct i2c_client *client, const struct i2c_device_id, *id)   {          int err = 0;       struct ft5x0x_ts_data *ft5x0x_ts;       struct input_dev *input_dev;          if (!i2c_check_functionality(client-adapter, I2C_FUNC_I2C)) {           err = -ENODEV;           goto exit_i2c_check_functionality;       }              ft5x0x_ts = kzalloc(sizeof(ft5x0x_ts_data), GPL_KERNEL);       if (!ft5x0x_ts) {           err = -ENOMEM;           goto exit_alloc_data;       }          this_client = client;          i2c_set_clientdata(client, ft5x0x_ts);          INIT_WORK(ft5x0x_ts-pen_event_work, ft5x0x_ts_pen_irq_work);          ft5x0x_ts-ts_workqueue = create_siglethread_workqueue(dev_name(client-dev));          if (!ft5x0x_ts-ts_workqueue) {           err = -ESRCH;           goto exit_create_siglethread;       }          err = request_irq(client-irq, ft5x0x_ts_interrupt, IRQF_TRIGGER_FALLING, "ft5x0x-irq", ft5x0x_ts);       if (err 0) {           dev_err(client-dev, "ft5x0x_ts_probe: request irq failed\n");           goto exit_irq_request;       }          disable_irq(this_client-irq);          input_dev = input_allocate_device();       if (!input_dev) {           err = -ENOMEM;           dev_err(client-dev, "ft5x0x_ts_probe: failed alloc input device\n");       }          ft5x0x_ts-input_dev = input_dev;          input_dev-name = FT5X0X_NAME;          set_bit(EV_ABS, input_dev-evbit);       set_bit(EV_KEY, input_dev-evbit);       set_bit(BTN_TOUCH, input_dev-keybit);      #ifdef FT5X0X_MULTI_TOUCH       set_bit(ABS_MT_TOUCH_MAJOR, input_dev-absbit);       set_bit(ABS_MT_POSITION_X, input_dev-absbit);       set_bit(ABS_MT_POSITION_Y, input_dev-absbit);       set_bit(ABS_MT_WIDTH_MAJOR, input_dev-absbit);          input_set_abs_params(input_dev, ABS_MT_POSITION_X, 0, SCREEN_MAX_X, 0, 0);       input_set_abs_params(input_dev, ABS_MT_POSITION_Y, 0, SCREEN_MAX_Y, 0, 0);       input_set_abs_params(input_dev, ABS_MT_TOUCH_MAJOR, 0, PRESS_MAX, 0, 0);       input_set_abs_params(input_dev, ABS_MT_WIDTH_MAJOR, 0, 200, 0, 0);   #else       set_bit(ABS_X, input_dev-absbit);       set_bit(ABS_Y, input_dev-absbit);       set_bit(ABS_PRESSURE, input_dev-absbit);       set_bit(BTN_TOUCH, input_dev-keybit);          input_set_abs_params(input_dev, ABS_X, 0, SCREEN_MAX_X, 0, 0);       input_set_abs_params(input_dev, ABS_Y, 0, SCREEN_MAX_Y, 0, 0);       input_set_abs_params(input_dev, ABS_PRESSURE, 0, PRESS_MAX, 0 , 0);          err = input_register_device(input_dev);       if (err) {           dev_err(client-dev, "ft5x0x_ts_probe: failed to register input device: %s\n",                    dev_name(client-dev));           goto exit_input_register_device;       }   #endif      #ifdef CONFIG_HAS_EARLYSUSPEND       ft5x0x_ts-early_suspend.level = EARLY_SUSPEND_LEVEL_BLANK_SCREEN + 1;       ft5x0x_ts-early_suspend.suspend = ft5x0x_ts_suspend;       ft5x0x_ts-early_suspend.resume = ft5x0x_ts_resume;       register_early_suspend(ft5x0x_ts-early_suspend);   #endif       msleep(50);          //Get some register information       uc_reg_value = ft5x0x_read_fw_ver();       printk(" Firmware version = 0x%sx\n", uc_reg_value);          //Auto calibration       err = ft5x0x_write_reg(CALIBRATION_REG, 0x00);       if (err)           printk(" Auto calibration failed.\n");       else           printk(" Auto calibration successfully.\n");       //Config the run mode of TPM, reg - 0xa7 : auto calibration - 0x04       ft5x0x_write_reg(FT5X0X_REG_STATE, 0x00);       printk(" Auto calibration during running.\n");          enable_irq(this_client-irq);          return 0;      exit_input_register_device:       input_free_device(input_dev);      exit_alloc_data:       free_irq(client-irq, ft5x0x_ts);      exit_irq_request:      exit_create_siglethread:       i2c_set_clientdata(client, NULL);      exit_alloc_data:      exit_i2c_check_functionality:       return err;      }      
  • 热度 26
    2012-4-18 10:31
    32462 次阅读|
    1 个评论
    view plaincopyprint? static void ft5x0x_ts_release(void)   {       struct ft5x0x_ts_data *data = i2c_get_clientdata(this_client);      #ifdef FT5X0X_MULTI_TOUCH       input_report_abs(data-input_dev, ABS_MT_TOUCH_MAJOR, 0);       input_report_abs(data-input_dev, ABS_MT_WIDTH_MAJOR, 0);       input_report_key(data-input_dev, BTN_TOUCH, 0);   #else       input_report_abs(data-input_dev, ABS_PRESSURE, 0);       input_report_key(data-input_dev, BTN_TOUCH, 0);   #endif       input_sync(data-input_dev);   }      static int ft5x0x_read_data(void)   {       struct ft5x0x_ts_data *data = i2c_get_clientdata(this_client);       struct ts_event *event = data-event;       u32 buf = {0};       int ret = -1;          #ifdef FT5X0X_MULTI_TOUCH       ret = ft5x0x_i2c_rxdata(buf, 31);   #else       ret = ft5x0x_i2c_rxdata(buf, 7);   #endif       if (ret 0) {           printk("%s read_data i2c_rxdata failed: %d\n", __func__, ret);       }          memset(event, 0, sizeof(struct ts_event));       event-touch_point = buf 0x07;          if (event-touch_point == 0) {           ft5x0x_ts_release();           return 1;       }      #ifdef FT5X0X_MULTI_TOUCH       switch (event-touch_point) {           case 5:               event-x5 = (s16)(buf 0x0F)8 | (s16)buf ;               event-y5 = (s16)(buf 0x0F)8 | (s16)buf ;           case 4:               event-x4 = (s16)(buf 0x0F)8 | (s16)buf ;               event-y4 = (s16)(buf 0x0F)8 | (s16)buf ;           case 3:               event-x3 = (s16)(buf 0x0F)8 | (s16)buf ;               event-y3 = (s16)(buf 0x0F)8 | (s16)buf ;           case 2:               event-x2 = (s16)(buf 0x0F)8 | (s16)buf ;               event-y2 = (s16)(buf 0x0F)8 | (s16)buf ;           case 1:               event-x1 = (s16)(buf 0x0F)8 | (s16)buf ;               event-y1 = (s16)(buf 0x0F)8 | (s16)buf ;               break;           default:               return -1;       }   #else       if (event-touch_point == 1) {            event-x1 = (s16)(buf 0x0F)8 | (s16)buf ;           event-y1 = (s16)(buf 0x0F)8 | (s16)buf ;       }   #endif          event-pressure = 200;          return 0;   }      static void ft5x0x_reprot_value(void)   {       struct ft5x0x_ts_data *data = i2c_get_clientdata(this_client);       struct ts_event *event = data-event;      #ifdef FT5X0X_MULTI_TOUCH       switch(event-touch_point) {           case 5:               input_report_abs(data-input_dev, ABS_MT_TOUCH_MAJOR, event-pressure);               input_report_abs(data-input_dev, ABS_MT_POSITION_X,  event-x5);               input_report_abs(data-input_dev, ABS_MT_POSITION_Y,  event-y5);               input_report_abs(data-input_dev, ABS_MT_WIDTH_MAJOR, event-pressure);               input_mt_sync(data-input_dev);           case 4:               input_report_abs(data-input_dev, ABS_MT_TOUCH_MAJOR, event-pressure);               input_report_abs(data-input_dev, ABS_MT_POSITION_X,  event-x4);               input_report_abs(data-input_dev, ABS_MT_POSITION_Y,  event-y4);               input_report_abs(data-input_dev, ABS_MT_WIDTH_MAJOR, event-pressure);               input_mt_sync(data-input_dev);           case 3:               input_report_abs(data-input_dev, ABS_MT_TOUCH_MAJOR, event-pressure);               input_report_abs(data-input_dev, ABS_MT_POSITION_X,  event-x3);               input_report_abs(data-input_dev, ABS_MT_POSITION_Y,  event-y3);               input_report_abs(data-input_dev, ABS_MT_WIDTH_MAJOR, event-pressure);               input_mt_sync(data-input_dev);           case 2:               input_report_abs(data-input_dev, ABS_MT_TOUCH_MAJOR, event-pressure);               input_report_abs(data-input_dev, ABS_MT_POSITION_X,  event-x2);               input_report_abs(data-input_dev, ABS_MT_POSITION_Y,  event-y2);               input_report_abs(data-input_dev, ABS_MT_WIDTH_MAJOR, event-pressure);               input_mt_sync(data-input_dev);           case 1:               input_report_abs(data-input_dev, ABS_MT_TOUCH_MAJOR, event-pressure);               input_report_abs(data-input_dev, ABS_MT_POSITION_X,  event-x1);               input_report_abs(data-input_dev, ABS_MT_POSITION_Y,  event-y1);               input_report_abs(data-input_dev, ABS_MT_WIDTH_MAJOR, event-pressure);               input_mt_sync(data-input_dev);               break;           default:               break;       }   #else       if (event-touch_point == 1) {           input_report_abs(data-input_dev, ABS_X, event-x1);           input_report_abs(data-input_dev, ABS_Y, event-y1);           input_report_abs(data-input_dev, ABS_PRESSURE, event-pressure);       }       input_report_key(data-input_dev, BTN_TOUCH, 1);   #endif          input_sync(data-input_dev);     //摘自:http://blog.csdn.net/sunsea1026/article/details/7415803  
  • 热度 22
    2012-3-22 09:38
    2683 次阅读|
    0 个评论
      产品描述 l 支持2.8" - 12.1"的触控面板 l 真实多点触控,多达10点 l 采用跳频技术,超强抗RF干扰能力 l 优异防水、防静电特性 l 高信噪比:≥ 150 l 高线性度:≤ ±1mm l 高解析度:≥ 100 DPI l 低功耗 l 适用于多种类型(如Glass、Film等)的触摸屏 l 环境自适应校正 l 内置MCU,Flash l 支持I2C,SPI接口 l 通道 28Tx/ 16Rx     INTRODUCTION  The FT5x06 Series ICs are single-chip capacitive touch panel controller ICs with a built-in 8 bit Micro-controller unit (MCU).They  adopt the mutual capacitance approach, which supports true multi-touch capability. In conjunction with a mutual capacitive touch  panel, the FT5x06 have user-friendly input functions, which can be applied on many portable devices, such as cellular phones, MIDs,  netbook and notebook personal computers.  The FT5x06 series ICs include FT5206/FT5306/FT5406, the difference of their specifications will be listed individually in this  datasheet. FEATURES   Mutual Capacitive Sensing Techniques   True Multi-touch with up to 10 Points of Absolution X and  Y Coordinates   Immune to RF Interferences   Auto-calibration: Insensitive to Capacitance and Environ- mental Variations   Supports up to 28 Transmit Lines and 16 Receive Lines   Supports up to 12.1” Touch Screen    Full Programmable Scan Sequences with Individual Ad- justable Receive Lines and Transmit Lines to Support  Various Applications   High Report Rate: More than 100Hz   Touch Resolution of 100 Dots per Inch (dpi) or above --  depending on the Panel Size   Optional Interfaces :I2C/SPI   2.7V to 3.6V Operating Voltage   Supports 1.8V/AVDD IOVCC       Capable of Driving Single Channel (transmit/receive) Re- sistance: Up to15K    Capable of Supporting Single Channel (transmit/receive)  Capacitance: 60 pF   Optimal Sensing Mutual Capacitor: 1pF~4pF   12-Bit ADC Accuracy   Built-in MCU with 28KB Program Memory, 6KB Data  Memory and 256B Internal Data Space   11 Internal Interrupt Sources and 2 External Interrupt  Sources   3 Operating Modes   Active   Monitor   Hibernate   Operating Temperature Range: -20°C to +85°C 
  • 热度 24
    2012-3-21 23:24
    1607 次阅读|
    0 个评论
      深圳市恒诚科技有限公司 成立于 2002 年,是集研发,生产,销售微电子产品于一体的高新技术企业。现有员工86人,其中95%的员工具有大专以上学历。30%的员工具有助理工程师以上技术职称,且都在技术研发第一线。45%的员工担当市场营销工作。总部设在深圳,销售网络涵盖整个中 国,在上海、南京、及香港设有分公司或办事处。       恒诚科技一直不断加大对技术研发人员及科研资金的投入,现已建立了公司技术研发中心,下设数字电视移动多媒体研发部,自动化控制研发部,汽车电子研发部,工业自动化研发部以及医疗电子技术服务部等。公司研发生产的产品,在数字移动多媒体,手持电子设备,汽车电子,医疗电子,工业自动化控制等不同行业中都占有一定的市场份额。       恒诚科技除了营销自已研发生产的产品外,还代理国内外10多条高端产品线和30多条热销产品线,其中有以色列Siano公司生产提供的高集成芯片接收器;美国Freescale公司生产的专为汽车,手机,网络提供嵌入式半导体器件;台湾Focaltech公司生产提供的电容式触摸屏芯片,美国IML公司生产提供的模拟和混合信号器件;中国X-power公司生产提供的智能化电源管理芯片;Highvision公司生产提供的导航定位系统核心芯片,以及TI,ADI,CADEKA的放大器和数模转换器等产品。所营销的产品涵盖MID,GPS,PMP,手机,LCD Monitor,LCD TV等行业以及工业控制,医疗,安防等领域。         恒诚科技作为专业的电子元器件代理商和整体方案提供商,与客户、供应商紧密合作,努力创造三方共赢局面。公司在提供有价格竞争力的优质产品同时,通过经验丰富的专业销售人才、力量雄厚的技术研发队伍和高效快捷的物流服务团队,为客户提供完善的全方位服务,最大程度地满足客户的需求。     恒诚科技在对外狠抓市场开拓的同时,对内强化管理内劲。早在2002年就引入ERP管理系统,2005年引入CRM客户关系管理系统,之后又实施了ISO9001质量管理系统,现在,恒诚科技在长期经营发展过程中,逐步形成,确认并付诸着公司文化: 恒心立业,诚信为本。