99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于i.MX6ULL點亮LED

玩轉單片機 ? 來源:玩轉單片機 ? 2023-03-06 09:09 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

都說入門一款芯片的第一步是點亮LED,但是i.MX6ULL入門門檻比較高,特別是通過自學入門的,這個系列已經(jīng)寫了好久了,最近打算在項目不急的時候加快一下學習進度,現(xiàn)在就開始學習一下怎么點亮一個LED,前邊學的框架就是為了點亮LED做基礎,點亮LED主要是學習怎么操作實際地址,都知道內核是不能直接操作地址的,就需要通過內核提供的API去操作實際地址;

|測試寫入

在點亮LED前先測試一下APP往驅動寫入數(shù)據(jù),避免寫入數(shù)據(jù)階段就出現(xiàn)數(shù)據(jù)異常,再往下寫就沒多大意義;

chrdevbaseApp.c文件

#include "stdio.h"
#include "unistd.h"
#include "sys/types.h"
#include "sys/stat.h"
#include "fcntl.h"
#include "stdlib.h"
#include "string.h"


/*
 * @description    : main主程序
 * @param - argc   : argv數(shù)組元素個數(shù)
 * @param - argv   : 具體參數(shù)
 * @return       : 0 成功;其他 失敗
 */
int main(int argc, char *argv[])
{
  int fd, retvalue;
  char *filename;
  char writebuf[100];
  unsigned char databuf[1];


  if(argc != 3){
    printf("[APP]Error Usage!
");
    return -1;
  }


  filename = argv[1];


  /* 打開驅動文件 */
  fd  = open(filename, O_RDWR);
  if(fd < 0){
    printf("[APP]Can't open file %s
", filename);
    return -1;
  }


  /* 把第三個參數(shù)賦值給databuf */
  databuf[0] = atoi(argv[2]);


  /* 向設備驅動寫數(shù)據(jù) */
  memcpy(writebuf, databuf, sizeof(databuf));
  retvalue = write(fd, writebuf, sizeof(databuf));
  if(retvalue < 0){
    printf("[APP]write file %s failed!
", filename);
  }


  /* 關閉設備 */
  retvalue = close(fd);
  if(retvalue < 0){
    printf("[APP]Can't close file %s
", filename);
    return -1;
  }


  return 0;
}

chrdevbase.c文件

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 


#define CHRDEVBASE_CNT      1    /* 設備號個數(shù) */
#define CHRDEVBASE_NAME   "chrdevbase"  /* 名字 */


/* chrdevbase 設備結構體 */
struct newchr_dev{
  dev_t devid;       /* 設備號 */
  struct cdev cdev;     /* cdev */
  struct class *class;   /* 類 */
  struct device *device;   /* 設備 */
  int major;         /* 主設備號 */
  int minor;         /* 次設備號 */
};


struct newchr_dev chrdevbase;/* 自定義字符設備 */


/*
 * @description    : 打開設備
 * @param - inode   : 傳遞給驅動的inode
 * @param - filp   : 設備文件,file結構體有個叫做private_data的成員變量
 *             一般在open的時候將private_data指向設備結構體。
 * @return       : 0 成功;其他 失敗
 */
static int chrdevbase_open(struct inode *inode, struct file *filp)
{
  printk("[BSP]chrdevbase open!
");
  filp->private_data = &chrdevbase; /* 設置私有數(shù)據(jù) */
  return 0;
}


/*
 * @description    : 從設備讀取數(shù)據(jù) 
 * @param - filp   : 要打開的設備文件(文件描述符)
 * @param - buf   : 返回給用戶空間的數(shù)據(jù)緩沖區(qū)
 * @param - cnt   : 要讀取的數(shù)據(jù)長度
 * @param - offt   : 相對于文件首地址的偏移
 * @return       : 讀取的字節(jié)數(shù),如果為負值,表示讀取失敗
 */
static ssize_t chrdevbase_read(struct file *filp, char __user *buf, size_t cnt, loff_t *offt)
{
  printk("chrdevbase read!
");
  return 0;
}


/*
 * @description    : 向設備寫數(shù)據(jù) 
 * @param - filp   : 設備文件,表示打開的文件描述符
 * @param - buf   : 要寫給設備寫入的數(shù)據(jù)
 * @param - cnt   : 要寫入的數(shù)據(jù)長度
 * @param - offt   : 相對于文件首地址的偏移
 * @return       : 寫入的字節(jié)數(shù),如果為負值,表示寫入失敗
 */
static ssize_t chrdevbase_write(struct file *filp, const char __user *buf, size_t cnt, loff_t *offt)
{
  int retvalue = 0;
  char writebuf[1];


  /* 接收用戶空間傳遞給內核的數(shù)據(jù)并且打印出來 */
  retvalue = copy_from_user(writebuf, buf, cnt);
  printk("[BSP]kernel recevdata data:%d!
",writebuf[0]);


  // printk("chrdevbase write!
");
  return 0;
}


/*
 * @description    : 關閉/釋放設備
 * @param - filp   : 要關閉的設備文件(文件描述符)
 * @return       : 0 成功;其他 失敗
 */
static int chrdevbase_release(struct inode *inode, struct file *filp)
{
  printk("[BSP]release!
");
  return 0;
}


/*
 * 設備操作函數(shù)結構體
 */
static struct file_operations chrdevbase_fops = {
  .owner = THIS_MODULE,  
  .open = chrdevbase_open,
  .read = chrdevbase_read,
  .write = chrdevbase_write,
  .release = chrdevbase_release,
};


/*
 * @description  : 驅動入口函數(shù) 
 * @param     : 無
 * @return     : 0 成功;其他 失敗
 */
static int __init chrdevbase_init(void)
{
  /* 注冊字符設備驅動 */
  /* 1、創(chuàng)建設備號 */
  if (chrdevbase.major) { /* 定義了設備號 */
    chrdevbase.devid = MKDEV(chrdevbase.major, 0);
    register_chrdev_region(chrdevbase.devid, CHRDEVBASE_CNT, CHRDEVBASE_NAME);
  } else { /* 沒有定義設備號 */
    alloc_chrdev_region(&chrdevbase.devid, 0, CHRDEVBASE_CNT,CHRDEVBASE_NAME); /* 申請設備號 */
    chrdevbase.major = MAJOR(chrdevbase.devid); /* 獲取主設備號 */
    chrdevbase.minor = MINOR(chrdevbase.devid); /* 獲取次設備號 */
  }
  printk("newcheled major=%d,minor=%d
",chrdevbase.major,chrdevbase.minor);


  /* 2、初始化 cdev */
  chrdevbase.cdev.owner = THIS_MODULE;
  cdev_init(&chrdevbase.cdev, &chrdevbase_fops);


  /* 3、添加一個 cdev */
  cdev_add(&chrdevbase.cdev, chrdevbase.devid, CHRDEVBASE_CNT);


  /* 4、創(chuàng)建類 */
  chrdevbase.class = class_create(THIS_MODULE, CHRDEVBASE_NAME);
  if (IS_ERR(chrdevbase.class)) {
    return PTR_ERR(chrdevbase.class);
  }


  /* 5、創(chuàng)建設備 */
  chrdevbase.device = device_create(chrdevbase.class, NULL,chrdevbase.devid, NULL, CHRDEVBASE_NAME);
  if (IS_ERR(chrdevbase.device)) {
    return PTR_ERR(chrdevbase.device);
  }


  return 0;
}


/*
 * @description  : 驅動出口函數(shù)
 * @param     : 無
 * @return     : 無
 */
static void __exit chrdevbase_exit(void)
{
  /* 注銷字符設備 */
  cdev_del(&chrdevbase.cdev);/* 刪除 cdev */
  unregister_chrdev_region(chrdevbase.devid, CHRDEVBASE_CNT);/* 注銷設備號 */


  device_destroy(chrdevbase.class, chrdevbase.devid);/* 銷毀設備 */
  class_destroy(chrdevbase.class);/* 銷毀類 */


  printk("[BSP]chrdevbase exit!
");
}


/* 
 * 將上面兩個函數(shù)指定為驅動的入口和出口函數(shù) 
 */
module_init(chrdevbase_init);
module_exit(chrdevbase_exit);


/* 
 * LICENSE和作者信息
 */
MODULE_LICENSE("GPL");
MODULE_AUTHOR("zuozhongkai");

實測操作如下圖所示,沒有問題就可以繼續(xù)編寫!

14dc525a-bb71-11ed-bfe3-dac502259ad0.png

|寄存器點亮LED

測試寫入沒有問題就繼續(xù)補充驅動,通過配置寄存器來實現(xiàn)點亮LED,不同板子LED燈在不同的GPIO上,根據(jù)實際配置,下方是補充完整的驅動:

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 


#define CHRDEVBASE_CNT      1    /* 設備號個數(shù) */
#define CHRDEVBASE_NAME   "chrdevbase"  /* 名字 */


#define LEDOFF 0 /* 關燈 */
#define LEDON 1 /* 開燈 */


/* 寄存器物理地址 */
// GPIO1時鐘
#define CCM_CCGR1_BASE (0X020C406C)
// GPIO1 多路選擇
#define SW_MUX_GPIO1_IO04_BASE  (0X020E006C)
// GPIO模式配置
#define SW_PAD_GPIO1_IO04_BASE  (0X020E02F8)
#define GPIO1_DR_BASE (0X0209C000)
#define GPIO1_GDIR_BASE (0X0209C004)


/* 映射后的寄存器虛擬地址指針 */
static void __iomem *IMX6U_CCM_CCGR1;
static void __iomem *SW_MUX_GPIO1_IO04;
static void __iomem *SW_PAD_GPIO1_IO04;
static void __iomem *GPIO1_DR;
static void __iomem *GPIO1_GDIR;


/* chrdevbase 設備結構體 */
struct newchr_dev{
  dev_t devid;       /* 設備號 */
  struct cdev cdev;     /* cdev */
  struct class *class;   /* 類 */
  struct device *device;   /* 設備 */
  int major;         /* 主設備號 */
  int minor;         /* 次設備號 */
};


struct newchr_dev chrdevbase;/* 自定義字符設備 */


/*
* @description : LED 打開/關閉
* @param - sta : LEDON(0) 打開 LED,LEDOFF(1) 關閉 LED
* @return : 無
*/
void led_switch(u8 sta)
{
  u32 val = 0;
  if(sta == LEDON) {
    val = readl(GPIO1_DR);
    val &= ~(1 << 4); 
    writel(val, GPIO1_DR);
  }else if(sta == LEDOFF) {
    val = readl(GPIO1_DR);
    val|= (1 << 4);
    writel(val, GPIO1_DR);
  } 
}


/*
* @description : LED 硬件初始化
* @param : 無
* @return : 無
*/
void led_hal_init(void)
{
  u32 val = 0;


  /* 初始化 LED */
  /* 1、寄存器地址映射 */
  IMX6U_CCM_CCGR1 = ioremap(CCM_CCGR1_BASE, 4);
  SW_MUX_GPIO1_IO04 = ioremap(SW_MUX_GPIO1_IO04_BASE, 4);
  SW_PAD_GPIO1_IO04 = ioremap(SW_PAD_GPIO1_IO04_BASE, 4);
  GPIO1_DR = ioremap(GPIO1_DR_BASE, 4);
  GPIO1_GDIR = ioremap(GPIO1_GDIR_BASE, 4);


  /* 2、使能 GPIO1 時鐘 */
  val = readl(IMX6U_CCM_CCGR1);
  val &= ~(3 << 26); /* 清楚以前的設置 */
  val |= (3 << 26); /* 設置新值 */
  writel(val, IMX6U_CCM_CCGR1);


  /* 3、設置 GPIO1_IO04 的復用功能,將其復用為
  * GPIO1_IO04,最后設置 IO 屬性。
  */
  writel(5, SW_MUX_GPIO1_IO04);


  /* 寄存器 SW_PAD_GPIO1_IO04 設置 IO 屬性 */
  writel(0xD0B1, SW_PAD_GPIO1_IO04);


  /* 4、設置 GPIO1_IO04 為輸出功能 */
  val = readl(GPIO1_GDIR);
  val &= ~(1 << 4); /* 清除以前的設置 */
  val |= (1 << 4); /* 設置為輸出 */
  writel(val, GPIO1_GDIR);


  /* 5、默認關閉 LED */
  val = readl(GPIO1_DR);
  val |= (1 << 4); 
  writel(val, GPIO1_DR);
}


/*
* @description : 取消映射
* @param : 無
* @return : 無
*/
void led_hal_exit(void)
{
  iounmap(IMX6U_CCM_CCGR1);
  iounmap(SW_MUX_GPIO1_IO04);
  iounmap(SW_PAD_GPIO1_IO04);
  iounmap(GPIO1_DR);
  iounmap(GPIO1_GDIR);
}


/*
 * @description    : 打開設備
 * @param - inode   : 傳遞給驅動的inode
 * @param - filp   : 設備文件,file結構體有個叫做private_data的成員變量
 *             一般在open的時候將private_data指向設備結構體。
 * @return       : 0 成功;其他 失敗
 */
static int chrdevbase_open(struct inode *inode, struct file *filp)
{
  printk("[BSP]chrdevbase open!
");
  filp->private_data = &chrdevbase; /* 設置私有數(shù)據(jù) */
  return 0;
}


/*
 * @description    : 從設備讀取數(shù)據(jù) 
 * @param - filp   : 要打開的設備文件(文件描述符)
 * @param - buf   : 返回給用戶空間的數(shù)據(jù)緩沖區(qū)
 * @param - cnt   : 要讀取的數(shù)據(jù)長度
 * @param - offt   : 相對于文件首地址的偏移
 * @return       : 讀取的字節(jié)數(shù),如果為負值,表示讀取失敗
 */
static ssize_t chrdevbase_read(struct file *filp, char __user *buf, size_t cnt, loff_t *offt)
{
  printk("chrdevbase read!
");
  return 0;
}


/*
 * @description    : 向設備寫數(shù)據(jù) 
 * @param - filp   : 設備文件,表示打開的文件描述符
 * @param - buf   : 要寫給設備寫入的數(shù)據(jù)
 * @param - cnt   : 要寫入的數(shù)據(jù)長度
 * @param - offt   : 相對于文件首地址的偏移
 * @return       : 寫入的字節(jié)數(shù),如果為負值,表示寫入失敗
 */
static ssize_t chrdevbase_write(struct file *filp, const char __user *buf, size_t cnt, loff_t *offt)
{
  int retvalue = 0;
  char writebuf[1];


  /* 接收用戶空間傳遞給內核的數(shù)據(jù)并且打印出來 */
  retvalue = copy_from_user(writebuf, buf, cnt);
  printk("[BSP]kernel recevdata data:%d!
",writebuf[0]);


  if(writebuf[0] == LEDON) { 
    led_switch(LEDON); /* 打開 LED 燈 */
  } else if(writebuf[0] == LEDOFF) {
    led_switch(LEDOFF); /* 關閉 LED 燈 */
  }


  // printk("chrdevbase write!
");
  return 0;
}


/*
 * @description    : 關閉/釋放設備
 * @param - filp   : 要關閉的設備文件(文件描述符)
 * @return       : 0 成功;其他 失敗
 */
static int chrdevbase_release(struct inode *inode, struct file *filp)
{
  printk("[BSP]release!
");
  return 0;
}


/*
 * 設備操作函數(shù)結構體
 */
static struct file_operations chrdevbase_fops = {
  .owner = THIS_MODULE,  
  .open = chrdevbase_open,
  .read = chrdevbase_read,
  .write = chrdevbase_write,
  .release = chrdevbase_release,
};


/*
 * @description  : 驅動入口函數(shù) 
 * @param     : 無
 * @return     : 0 成功;其他 失敗
 */
static int __init chrdevbase_init(void)
{
  /* 初始化硬件 */
  led_hal_init();


  /* 注冊字符設備驅動 */
  /* 1、創(chuàng)建設備號 */
  if (chrdevbase.major) { /* 定義了設備號 */
    chrdevbase.devid = MKDEV(chrdevbase.major, 0);
    register_chrdev_region(chrdevbase.devid, CHRDEVBASE_CNT, CHRDEVBASE_NAME);
  } else { /* 沒有定義設備號 */
    alloc_chrdev_region(&chrdevbase.devid, 0, CHRDEVBASE_CNT,CHRDEVBASE_NAME); /* 申請設備號 */
    chrdevbase.major = MAJOR(chrdevbase.devid); /* 獲取主設備號 */
    chrdevbase.minor = MINOR(chrdevbase.devid); /* 獲取次設備號 */
  }
  printk("newcheled major=%d,minor=%d
",chrdevbase.major,chrdevbase.minor);


  /* 2、初始化 cdev */
  chrdevbase.cdev.owner = THIS_MODULE;
  cdev_init(&chrdevbase.cdev, &chrdevbase_fops);


  /* 3、添加一個 cdev */
  cdev_add(&chrdevbase.cdev, chrdevbase.devid, CHRDEVBASE_CNT);


  /* 4、創(chuàng)建類 */
  chrdevbase.class = class_create(THIS_MODULE, CHRDEVBASE_NAME);
  if (IS_ERR(chrdevbase.class)) {
    return PTR_ERR(chrdevbase.class);
  }


  /* 5、創(chuàng)建設備 */
  chrdevbase.device = device_create(chrdevbase.class, NULL,chrdevbase.devid, NULL, CHRDEVBASE_NAME);
  if (IS_ERR(chrdevbase.device)) {
    return PTR_ERR(chrdevbase.device);
  }


  return 0;
}


/*
 * @description  : 驅動出口函數(shù)
 * @param     : 無
 * @return     : 無
 */
static void __exit chrdevbase_exit(void)
{
  /* 取消映射 */
  led_hal_exit();


  /* 注銷字符設備 */
  cdev_del(&chrdevbase.cdev);/* 刪除 cdev */
  unregister_chrdev_region(chrdevbase.devid, CHRDEVBASE_CNT);/* 注銷設備號 */


  device_destroy(chrdevbase.class, chrdevbase.devid);/* 銷毀設備 */
  class_destroy(chrdevbase.class);/* 銷毀類 */


  printk("[BSP]chrdevbase exit!
");
}


/* 
 * 將上面兩個函數(shù)指定為驅動的入口和出口函數(shù) 
 */
module_init(chrdevbase_init);
module_exit(chrdevbase_exit);


/* 
 * LICENSE和作者信息
 */
MODULE_LICENSE("GPL");
MODULE_AUTHOR("zuozhongkai");

| 細節(jié)剖析

1、先看地址定義,包括物理地址和映射后的地址指針:

1504c5e6-bb71-11ed-bfe3-dac502259ad0.png

2、再看具體的配置,封裝在led_hal_init函數(shù)中:

void led_hal_init(void)
{
  // LED 硬件初始化
}

3、再看輸出電平配置,封裝在led_switch函數(shù)中:

void led_switch(u8 sta)
{
//電平配置
}

4、再看調用位置,一般在加載驅動的時候就初始化寄存器,在寫函數(shù)中判斷參數(shù)來進行亮滅切換;

5、最后注銷驅動的時候,需要把映射地址進行取消,一般都是初始化申請了什么資源,注銷的時候就需要釋放什么資源;

6、多次注銷和加載驅動,看看效果是否正常,注意野火的板子是多彩燈,只操作一個gpio效果不是很明顯,上面的代碼就是控制R燈的亮滅;

152b3e2e-bb71-11ed-bfe3-dac502259ad0.png

又學會了一種點燈方式,在點燈的道路上越走越遠,哈哈哈!

審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • led
    led
    +關注

    關注

    242

    文章

    23796

    瀏覽量

    672777
  • 芯片
    +關注

    關注

    459

    文章

    52383

    瀏覽量

    439119
  • 內核
    +關注

    關注

    3

    文章

    1415

    瀏覽量

    41284
  • 函數(shù)
    +關注

    關注

    3

    文章

    4378

    瀏覽量

    64611
  • IMX6ULL
    +關注

    關注

    3

    文章

    16

    瀏覽量

    4310

原文標題:i.MX6ULL|點亮LED

文章出處:【微信號:玩轉單片機,微信公眾號:玩轉單片機】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    i.MX6ULL 驅動開發(fā)7—按鍵輸入捕獲與GPIO輸入配置與高低電平讀取

    本篇主要介紹了i.MX6ULL的按鍵檢測的使用,主要的知識點是設備樹的修改,以及GPIO的輸入配置與高低電平的讀取。
    的頭像 發(fā)表于 05-24 09:11 ?6874次閱讀
    <b class='flag-5'>i.MX6ULL</b> 驅動開發(fā)7—按鍵輸入捕獲與GPIO輸入配置與高低電平讀取

    使用i.MX6ULL開發(fā)板進行Linux根文件系統(tǒng)的完善

    上一篇推文講了怎么移植根文件系統(tǒng),并在i.MX6ULL開發(fā)板中運行起來,但是會出現(xiàn)一些提示,現(xiàn)在來進行根文件的完善。
    發(fā)表于 10-17 11:13 ?974次閱讀

    移植NXP官方linux 5.4內核到i.MX6ULL開發(fā)板

    本文描述移植NXP官方 linux 5.4 內核到i.MX6ULL開發(fā)板。
    發(fā)表于 12-19 11:10 ?2354次閱讀

    如何在i.MX6ULL睡眠時停止刷新LCD?

    為了更好的 EMC,我們需要在 i.MX6ULL 進入睡眠狀態(tài)時停止 LCD 刷新。 能否實現(xiàn) ? 平臺: i.MX6ULL 系統(tǒng): Linux
    發(fā)表于 04-03 07:14

    i.MX6ULL開發(fā)板硬件資源

    迅為i.MX6ULL 終結者開發(fā)板硬件資源非常豐富,幾乎將 i.MX6ULL 芯片的所有資源都擴展引出到底板上了,底板提供了豐富的外設接口,開發(fā)板的尺寸是 190mm*125mm,充分考慮了人性化設計,整體顯得十分大。
    發(fā)表于 12-29 06:18

    初識 i.MX6ULL 寄存器

    裸機開發(fā)_L1_匯編LED實驗0. 本節(jié)目標1. 硬件層電路2. 初識 i.MX6ULL 寄存器2.1 i.MX6ULL 時鐘控制寄存器2.2 i.MX6ULL IO復用寄存器2.3
    發(fā)表于 12-20 07:13

    關于i.MX6ULL配置GPIO

    正如學習C語言時寫的第一段代碼都是“HelloWorld!”,接觸一款新的處理器時往往是從點亮一個LED開始;而點亮一個LED,則需要操作這款芯片的GPIO外設。那么作為廣受歡迎的
    發(fā)表于 08-05 10:37

    I.MX6ULL UART傳輸問題求解

    I.MX6ULL UART傳輸問題
    發(fā)表于 04-21 08:09

    珠海明遠智??萍悸?lián)合NXP強勢推出i.MX6ull核心板

    NXP I.MX6ULL是一個高性能、低功耗、高性價比處理器系列,基于ARM Cortex-A7內核,主頻可達900MHz。i.MX 6ULL應用處理器包括一個集成的電源管理模塊,可以省掉外部
    發(fā)表于 04-24 14:10 ?725次閱讀

    飛凌i.MX6ULL開發(fā)板的評測,再次進階擁有更高的性價比

    處理器MCIMX6Y2開發(fā)設計,采用先進的ARMCortex-A7內核,運行速度高達800MHz。i.MX6ULL應用處理器包括一個集成的電源管理模塊,降低了外接電源的復雜性,并簡化了上電時序。 i.MX6ULL
    發(fā)表于 10-27 11:55 ?1670次閱讀
    飛凌<b class='flag-5'>i.MX6ULL</b>開發(fā)板的評測,再次進階擁有更高的性價比

    基于NXP i.MX6ULL處理器的FETMX6ULL-C核心板

    “性價比高,功能接口豐富,資料齊全,穩(wěn)定性強”這是許多用戶對飛凌FETMX6ULL-S核心板的評價。作為NXP公司一顆經(jīng)典的MPU,i.MX6ULL的市場認可度無需多言。而作為NXP公司的金牌
    發(fā)表于 04-11 15:05 ?1304次閱讀
    基于NXP <b class='flag-5'>i.MX6ULL</b>處理器的FETMX<b class='flag-5'>6ULL</b>-C核心板

    i.MX6ULL】驅動開發(fā)4——點亮LED(寄存器版)

    本篇主要介紹了如何通過操作寄存器來點亮i.MX6ULL開發(fā)板上的led,通過編寫LED對應的驅動程序和應用程序,實現(xiàn)程序設計的分層。
    的頭像 發(fā)表于 05-21 21:26 ?3316次閱讀
    【<b class='flag-5'>i.MX6ULL</b>】驅動開發(fā)4——<b class='flag-5'>點亮</b><b class='flag-5'>LED</b>(寄存器版)

    【北京迅為】i.MX6ULL開發(fā)板移植 Debian 文件系統(tǒng)

    【北京迅為】i.MX6ULL開發(fā)板移植 Debian 文件系統(tǒng)
    的頭像 發(fā)表于 02-10 15:34 ?1500次閱讀
    【北京迅為】<b class='flag-5'>i.MX6ULL</b>開發(fā)板移植 Debian 文件系統(tǒng)

    基于i.MX6ULL的掉電檢測設計與軟件測試

    基于i.MX6ULL的掉電檢測設計與軟件測試基于i.MX6ULL平臺設計實現(xiàn)掉電檢測功能,首先選擇一路IO,利用IO電平變化觸發(fā)中斷,在編寫驅動時捕獲該路GPIO的中斷,然后在中斷響應函數(shù)中發(fā)
    的頭像 發(fā)表于 11-09 10:40 ?1171次閱讀
    基于<b class='flag-5'>i.MX6ULL</b>的掉電檢測設計與軟件測試

    【迅為電子】i.MX6UL和i.MX6ULL芯片區(qū)別與開發(fā)板對比

    【迅為電子】i.MX6UL和i.MX6ULL芯片區(qū)別與開發(fā)板對比
    的頭像 發(fā)表于 11-28 14:31 ?1294次閱讀
    【迅為電子】<b class='flag-5'>i.MX6</b>UL和<b class='flag-5'>i.MX6ULL</b>芯片區(qū)別與開發(fā)板對比