精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

鴻蒙移植樹莓派(下)修改源碼

開發
文章由鴻蒙社區產出,想要了解更多內容請前往:51CTO和華為官方戰略合作共建的鴻蒙技術社區https://harmonyos.51cto.com/#zz

[[378481]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com/#zz

項目最新更新,可以查看碼倉 https://gitee.com/liangzili/harmony-raspberry

1、切換啟動模式

樹莓派默認啟動在HYP模式,我們需要在內核啟動前改為SVC模式

kernel\liteos_a\arch\arm\arm\src\startup\reset_vector_up.S 在115行左右,reset_vector:下面添加

  1. mrs r0,cpsr         //讀取CPU模式寄存器 
  2.    bic r0,r0,#0x1F     //清除CPU模式位(如果處于催眠模式,它將是1A)保留所有其他   
  3.    orr r0,r0,#0x13     //設置CPU_MODE為SVC_MODE (0x13),而ORR仍然保留所有其他位 
  4.    msr spsr_cxsf,r0    //將其寫入spsr_cxsf寄存器,以便在調用交換機時加載該寄存器。 
  5.    add r0,pc,#4        //從pc計算要進入SVC_MODE的地址(后面的兩個操作碼很長) 
  6.    msr ELR_hyp,r0      //將地址值寫入ELR_hyp寄存器 
  7.    eret                //執行了回車指令 

 2、修改串口驅動

2.1、為了方便調試,先設置一個字符打印函數

kernel\liteos_a\platform\uart\amba_pl011\amba_pl011.c在46行左右處添加下面的代碼,uart_putc_phy使用物理地址打印字符,uart_putc_virt使用虛擬地址打印。當內核代碼啟動MMU之后,需用使用uart_putc_virt來打印字符。

  1. /*---------自定義函數----------*/ 
  2. #define RPI_BASE_UART_REGISTER (0x3f201000) //HI3516:0x120A0000 rpi2:0x3F201000 
  3. #define AMBA_UART_DR (*(volatile unsigned char *)(RPI_BASE_UART_REGISTER + 0x00)) 
  4. #define AMBA_UART_FR (*(volatile unsigned char *)(RPI_BASE_UART_REGISTER + 0x18)) 
  5. ​ 
  6. #define RPI_BASE_UART_REGISTER1 IO_DEVICE_ADDR(0x3F201000) //HI3516:0x120A0000 rpi2:0x3F201000 
  7. #define AMBA_UART_DR1 (*(volatile unsigned char *)(RPI_BASE_UART_REGISTER1 + 0x00)) 
  8. #define AMBA_UART_FR1 (*(volatile unsigned char *)(RPI_BASE_UART_REGISTER1 + 0x18)) 
  9. /*---------------------------*/ 
  10. ​ 
  11. void uart_putc_phy(unsigned char c) 
  12.     //UART_Type *uartRegs = (UART_Type *)UART4_REG_PBASE; 
  13.     //while ((uartRegs->USART_ISR & (1<<5)) == 0); 
  14.     //uartRegs->USART_TDR = c; 
  15.     while (AMBA_UART_FR & (1 << 5)); 
  16.     AMBA_UART_DR = c; 
  17. ​ 
  18. void uart_putc_virt(unsigned char c) 
  19.     //UART_Type *uartRegs = (UART_Type *)UART_REG_BASE; 
  20.     //while ((uartRegs->USART_ISR & (1<<5)) == 0); 
  21.     //uartRegs->USART_TDR = c; 
  22.     while (AMBA_UART_FR1 & (1 << 5)); 
  23.     AMBA_UART_DR1 = c; 

 例如:kernel\liteos_a\arch\arm\arm\src\startup\reset_vector_up.S 

  1. ldr sp, =0x00000000 + 0x5000000  //調用C函數前,得先設置棧,樹莓派物理內存從0x0開始 
  2.    mov r0, #'m' 
  3.    bl uart_putc_phy                //在MMU啟動之前使用的是物理地址打印 
  4.     
  5.    bl      mmu_setup                           /* set up the mmu */ 
  6.     
  7.    mov r0, #'M' 
  8.    bl uart_putc_virt               //在MMU啟動之后使用的是虛擬地址打印 

 2.2、添加串口中斷,串口輸入代碼

  1. vendor\broadcom\BCM2836\driver\uart\uart_hardware.c 

2.2.1、 串口的中斷函數,產生中斷時,這個函數調用

  1. static irqreturn_t BCM2836_uart_irq(int irq, void *data) 
  2.     char buf[FIFO_SIZE]; 
  3.     unsigned int count = 0; 
  4.     struct BCM2836_port *port = NULL
  5.     struct uart_driver_data *udd = (struct uart_driver_data *)data; 
  6.     UART_Type *uartRegs; 
  7.     uint32_t status; 
  8.      
  9.     if (udd == NULL) { 
  10.         uart_error("udd is null!\n"); 
  11.         return IRQ_HANDLED; 
  12.     } 
  13.     port = (struct BCM2836_port *)udd->private; 
  14.     uartRegs = (UART_Type *)port->phys_base; 
  15.     READ_UINT32(status, UART_REG_BASE + UART_FR); 
  16.     if ((UARTREG(UART_REG_BASE,UART_FR)&(1<<4)) == 0) { 
  17.         do { 
  18.             buf[count++] = UARTREG(UART_REG_BASE,UART_DR);//*(volatile UINT32 *)((UINTPTR)(UART_REG_BASE + UART_DR)); //去讀取硬件得到數據 
  19.             if (udd->num != CONSOLE_UART) { 
  20.                 continue
  21.             } 
  22.             if (CheckMagicKey(buf[count - 1])) { //數據放在buf里 
  23.                 goto end
  24.             } 
  25. ​ 
  26.             if (buf[count-1] == '\r') //對windows和liteos回車換行的處理 
  27.                 buf[count-1] = '\n'
  28.         } while (UARTREG(UART_REG_BASE,UART_DR)); 
  29.         udd->recv(udd, buf, count); //調用udd里的recv函數把數據發送給上一級 
  30.     } 
  31.     UARTREG(UART_REG_BASE, UART_ICR) = 0x3ff; 
  32. end
  33.     /* clear all interrupt */ 
  34.     return 0; 

 2.2.2、串口的初始化函數

  1. static int BCM2836_startup(struct uart_driver_data *udd)  
  2.     int ret = 0; 
  3.     struct BCM2836_port *port = NULL
  4.     if (udd == NULL) { 
  5.         uart_error("udd is null!\n"); 
  6.         return -EFAULT; 
  7.     } 
  8.     port = (struct BCM2836_port *)udd->private;//*private是一個指針,指向 struct {enable,phys_base,irq_num,*udd} 
  9.     if (!port) { 
  10.         uart_error("port is null!"); 
  11.         return -EFAULT; 
  12.     } 
  13.     /* enable the clock */ 
  14.     LOS_TaskLock(); 
  15.     LOS_TaskUnlock(); 
  16. ​ 
  17.     ret = request_irq(port->irq_num, (irq_handler_t)BCM2836_uart_irq,0, "uart_dw", udd);  //去注冊一個串口的接收中斷函數 
  18.     /* 1.uart interrupt priority should be the highest in interrupt preemption mode */ 
  19.     //ret = LOS_HwiCreate(NUM_HAL_INTERRUPT_UART, 0, 0, (HWI_PROC_FUNC)uart_handler, NULL); 
  20. ​ 
  21.     /* 2.clear all irqs */ 
  22.     UARTREG(UART_REG_BASE, UART_ICR) = 0x3ff; 
  23.     //*(volatile UINT32 *)((UINTPTR)IO_DEVICE_ADDR(0x3F201044)) = 0x3ff; 
  24. ​ 
  25.     /* disable FIFO mode */ 
  26.     //uartRegs->USART_CR1 &= ~(1<<29); 
  27.     //*(volatile UINT32 *)((UINTPTR)IO_DEVICE_ADDR(0x3F20102C)) = 0x60; 
  28.     UARTREG(UART_REG_BASE, UART_LCR_H) = (1 << 6 | 1 << 5| 1 << 4);  
  29. ​ 
  30.     /* 3.set fifo trigger level */ 
  31.     //*(volatile UINT32 *)((UINTPTR)IO_DEVICE_ADDR(0x3F201034)) = 0x0; 
  32.     UARTREG(UART_REG_BASE, UART_IFLS) = 0; 
  33. ​ 
  34.     /* 4.enable rx interrupt 開啟串口接收中斷,第4位*/ 
  35.     UARTREG(UART_REG_BASE, UART_IMSC) = (1 << 4 | 1 << 6); //*(volatile UINT32 *)((UINTPTR)IO_DEVICE_ADDR(0x3F201038)) = 0x10; 
  36. ​ 
  37.     /* 5.enable receive */ 
  38.     UARTREG(UART_REG_BASE, UART_CR) |= (1 << 9); //*(volatile UINT32 *)((UINTPTR)IO_DEVICE_ADDR(0x3F201030)) = 0x301; 
  39. ​ 
  40.     //HalIrqUnmask(NUM_HAL_INTERRUPT_UART);//6.  
  41.     *(volatile UINT32 *)((UINTPTR)IO_DEVICE_ADDR(0x3F00B214)) = 0x02000000;//Unmask接收25號中斷 
  42. ​ 
  43.     BCM2836_config_in(udd); 
  44. ​ 
  45.     return ret; 

 2.2.3、串口寫函數

  1. static int BCM2836_start_tx(struct uart_driver_data *udd, const char *buf, size_t count
  2.     unsigned int tx_len = count
  3.     struct BCM2836_port *port = NULL
  4.     char value; 
  5.     unsigned int i; 
  6.     int ret = 0; 
  7. ​ 
  8.     if (udd == NULL) { 
  9.         uart_error("udd is null!\n"); 
  10.         return -EFAULT; 
  11.     } 
  12.     port = (struct BCM2836_port *)udd->private; 
  13.     if (!port) { 
  14.         uart_error("port is null!"); 
  15.         return -EFAULT; 
  16.     } 
  17.     /* UART_WITH_LOCK: there is a spinlock in the function to write reg in order. */ 
  18.     for (i = 0; i < tx_len; i++ ){ 
  19.         ret = LOS_CopyToKernel((void *)&value, sizeof(char),(void *)(buf++), sizeof(char)); 
  20.         if (ret) { 
  21.             return i; 
  22.         } 
  23.         (void)UartPutsReg(port->phys_base, &value, 1, UART_WITH_LOCK); 
  24.     } 
  25.     return count

 2、系統時鐘初始化

2.1、main函數的各種調用,驗證參數

kernel\liteos_a\platform\main.c->main()

kernel\liteos_a\kernel\common\los_config.c->OsMain()

kernel\liteos_a\arch\arm\arm\src\los_hw_tick.c->OsTickInit()

  1. systemClock     //vendor里設置的是50000000 
  2. tickPerSecond   //鴻蒙默認設置的是100 
  3. LITE_OS_SEC_TEXT_INIT UINT32 OsTickInit(UINT32 systemClock, UINT32 tickPerSecond) 
  4. {    //只是驗證了下傳入的這兩個參數,并未使用 
  5.     HalClockInit(); 
  6.     return LOS_OK; 

 2.2、先獲取當前時鐘頻率,注冊中斷

kernel\liteos_a\platform\hw\arm\timer\arm_generic\arm_generic_timer.c

  1. OS_TICK_INT_NUM//中斷號,在vendor\***\***\board\include\asm\hal_platform_ints.h下定義,查手冊確定 
  2. MIN_INTERRUPT_PRIORITY//優先級 
  3. OsTickEntry//中斷函數 
  4. LITE_OS_SEC_TEXT_INIT VOID HalClockInit(VOID) 
  5. {   ... 
  6.     g_sysClock = HalClockFreqRead(); //先獲取當前時鐘頻率 
  7.      
  8.     //調用LOS_HwiCreate函數新建中斷,系統中斷由它注冊 
  9.     ret = LOS_HwiCreate(OS_TICK_INT_NUM, MIN_INTERRUPT_PRIORITY, 0, OsTickEntry, 0);//參數1:中斷號、參數4:執行函數 
  10.     //這個函數就不深入了,大體就是將中斷號好和對應的執行函數放到一個數組 
  11.     //比如這里就是,當發生OS_TICK_INT_NUM這個中斷時,執行OsTickEntry()函數 
  12.     ... 

 2.3、時鐘中斷的執行函數OsTickEntry()

kernel\liteos_a\platform\hw\arm\timer\arm_generic\arm_generic_timer.c

  1. 不過此時這是注冊了這個函數,時鐘并未啟動,得執行了(三.啟動時鐘)之后才會調用這個函數 
  2. LITE_OS_SEC_TEXT VOID OsTickEntry(VOID) 
  3.     TimerCtlWrite(0); 
  4.     OsTickHandler(); 
  5.     TimerCvalWrite(TimerCvalRead() + OS_CYCLE_PER_TICK); 
  6.     TimerCtlWrite(1); 
  7.     //使用最后一個cval生成下一個tick的時間是絕對和準確的。不要使用tval來驅動一般時間,在這種情況下tick會變慢。 

 2.3、啟動時鐘

main() => OsStart(VOID) => OsTickStart() => HalClockStart(VOID)

kernel\liteos_a\platform\hw\arm\timer\arm_generic\arm_generic_timer.c => HalClockStart(VOID)

  1. //樹莓派2沒有GIC所以這個函數要爆改 
  2. LITE_OS_SEC_TEXT_INIT VOID HalClockStart(VOID) 
  3.     HalIrqUnmask(OS_TICK_INT_NUM);  //wendor里定義的 OS_TICK_INT_NUM = 29 
  4.     TimerCtlWrite(0); 
  5.     TimerTvalWrite(OS_CYCLE_PER_TICK); 
  6.     TimerCtlWrite(1); 

 2.3.1、HalIrqUnmask; //接收中斷(通過設置寄存器,允許CPU響應該中斷)

  1. HalIrqUnmask(OS_TICK_INT_NUM); 
  2. HalIrqUnmask(29); 
  3. GIC_REG_32(GICD_ISENABLER(29 >> 5)) = 1U << (29 % 32); 
  4. ​ 
  5. (GICD_ISENABLER(29 >> 5))拆開 
  6. GIC_REG_32(GICD_OFFSET + 0x100 + (29 >> 5) * 4) = 1U << (29 % 32);/* 中斷使能 Registers */ 
  7. ​ 
  8. GIC_REG_32拆開,(29 % 32)=1D 
  9. GIC_BASE_ADDR + (GICD_OFFSET + 0x100 + (29 >> 5) * 4) = 1U << (29 % 32) 
  10. ​ 
  11. #define GIC_BASE_ADDR             IO_DEVICE_ADDR(0x3F00A100) 
  12. #define GICD_OFFSET               0x1000     /* interrupt distributor offset */ 

 2.3.2、TimerCtlWrite(0); //關閉Timer

參考:ARM ArchitectureReference Manual ARMv7-A and ARMv7-R edition.pdf

《B3.17 Organization of the CP15 registers in a VMSA implementation》

  1. WRITE_TIMER_REG32(TIMER_REG_CTL, 0); 
  2. ARM_SYSREG_WRITE(TIMER_REG_CTL, 0) 
  3. ARM_SYSREG_WRITE(TIMER_REG(_CTL), 0) 
  4. ARM_SYSREG_WRITE(CP15_REG(c14, 0, c2, 1)), 0) 
  5. "mcr " (CP15_REG(c14, 0, c2, 1) :: "r" (val) 
  6. 反匯編 
  7. r8 0 
  8. mcr p15, #0, r8, c14, c2, #1    CNTP_CTL,PL1物理定時器控制寄存器 

 2.3.3、TimerTvalWrite(OS_CYCLE_PER_TICK); //設置Tval

  1. 反匯編 
  2. r0 192000 
  3. mcr p15, #0, r0, c14, c2, #0    CNTP_TVAL,PL1物理時間值寄存器 

 2.3.4、TimerCtlWrite(1); //再開啟Timer

  1. 反匯編 
  2. r5 1 
  3. mcr p15, #0, r5, c14, c2, #1    CNTP_CTL,PL1物理定時器控制寄存器 

 2.4、代碼移植

Z:\bright\harmony-100ask\kernel\liteos_a\platform\hw\arm\interrupt\gic\gic_v2.c

  1. VOID HalIrqUnmask(UINT32 vector) 
  2.     if ((vector > OS_USER_HWI_MAX) || (vector < OS_USER_HWI_MIN)) { 
  3.         return
  4.     } 
  5.     //GIC_REG_32(GICD_ISENABLER(vector >> 5)) = 1U << (vector % 32);  //替換 
  6.     *(volatile UINT32 *)((UINTPTR)IO_DEVICE_ADDR(0x3F00B218)) = 1; //使能ARM Timer IRQ     
  7. ​} 

 Z:\bright\harmony-100ask\kernel\liteos_a\platform\hw\arm\timer\arm_generic\arm_generic_timer.c

  1. STATIC_INLINE VOID TimerCtlWrite(UINT32 cntpCtl) 
  2.     //WRITE_TIMER_REG32(TIMER_REG_CTL, cntpCtl);//替換 
  3.     if(cntpCtl == 0){ 
  4.         *(volatile UINT32 *)((UINTPTR)IO_DEVICE_ADDR(0x3F00B408)) = 0x003E0000; 
  5.         } 
  6.     else 
  7.     { 
  8.         *(volatile UINT32 *)((UINTPTR)IO_DEVICE_ADDR(0x3F00B408)) = 0x003E00A2; 
  9.     } 
  10. ​STATIC_INLINE VOID TimerTvalWrite(UINT32 tval) 
  11.     //WRITE_TIMER_REG32(TIMER_REG_TVAL, tval);//替換 
  12.     *(volatile UINT32 *)((UINTPTR)IO_DEVICE_ADDR(0x3F00B400)) = tval;  //設置倒計時時間,鴻蒙是10ms     

 =======完整內容======

#2020征文-開發板# 鴻蒙 移植 樹莓派(上)搭建環境下載源碼

#2020征文-開發板# 鴻蒙 移植 樹莓派(中)添加單板

#2020征文-開發板# 鴻蒙 移植 樹莓派(下)修改源碼

©著作權歸作者和HarmonyOS技術社區共同所有,如需轉載,請注明出處,否則將追究法律責任.

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com/#zz

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2021-01-25 16:28:10

鴻蒙HarmonyOS搭建環境

2021-01-25 16:39:08

鴻蒙HarmonyOS添加單板

2019-03-31 08:00:02

樹莓派更新樹莓派 Linux

2019-03-24 20:30:18

樹莓派Linux

2021-12-31 10:00:30

鴻蒙HarmonyOS應用

2021-11-23 15:35:05

鴻蒙HarmonyOS應用

2019-03-12 18:33:57

樹莓派Linux

2021-03-29 21:24:40

樹莓派Linux

2022-02-11 09:24:05

樹莓派OpenWrt固定IP服務

2019-03-23 19:33:14

樹莓派Linux操作系統

2018-10-12 11:20:20

樹莓派NAS Linux

2020-07-16 21:00:05

樹莓派Kubernetes集Linux

2024-03-22 15:28:36

樹莓派Linux

2021-07-25 10:30:04

樹莓派Linux

2019-05-24 13:30:57

PiShrink樹莓派Linux

2013-08-26 11:00:27

RaspbianHard Float.NET環境

2019-03-28 18:51:52

樹莓派Linux編程語言

2022-02-11 14:28:50

樹莓派Openharmon鴻蒙

2020-08-16 09:00:15

樹莓派FedoraLinux

2021-09-19 10:41:02

樹莓派ZeroZero W
點贊
收藏

51CTO技術棧公眾號

色悠悠久久综合| 日韩在线无毛| 欧美日韩中字| 亚洲成人一区二区| 女人一区二区三区| 久久久久久无码精品大片| 国产成人调教视频在线观看| 91精品国产综合久久久久久漫画| 国产成人艳妇aa视频在线| 国产黄色av网站| 国产字幕视频一区二区| 亚洲视频在线观看视频| 91日韩视频在线观看| 麻豆免费在线观看| 久久网这里都是精品| 成人av.网址在线网站| 久久精品免费在线| 日韩在线不卡| 亚洲成在人线av| 日本xxxx黄色| 另类激情视频| 一个色在线综合| 亚洲欧美日韩精品久久久 | 永久免费在线观看视频| av在线综合网| a级国产乱理论片在线观看99| 日韩在线视频不卡| 亚洲激情国产| 日韩在线视频国产| 国产亚洲精品熟女国产成人| 成人豆花视频| 欧美日韩国产一区| 国产精品日韩欧美一区二区三区 | 欧美性感一类影片在线播放| 久久国产午夜精品理论片最新版本| melody高清在线观看| 国产精品一二三四| 国产精品丝袜一区二区三区| 日韩av在线天堂| 欧美777四色影| 国产一区二区三区免费视频| 中文字幕色网站| 蜜桃在线视频| 午夜视频在线观看一区二区三区| 亚洲综合第一| 欧美孕妇性xxxⅹ精品hd| 国产另类ts人妖一区二区| 国产日韩在线亚洲字幕中文| 中国精品一区二区| 秋霞电影一区二区| 国产精品人人做人人爽| 无码人妻av一区二区三区波多野 | 久久99成人| 欧美日本一区二区| 成人一区二区三| а√天堂中文在线资源8| 一区二区三区四区蜜桃| 日韩欧美精品一区二区三区经典| 日本不卡视频一区二区| 91丝袜美腿高跟国产极品老师 | 草草地址线路①屁屁影院成人| 亚洲一区二区三区免费| 日韩女优av电影| 亚洲一区在线不卡| 久久av影院| 欧美丰满一区二区免费视频| 欧美日韩一区二区三区69堂| 免费在线成人激情电影| 欧美日韩一区二区三区高清| wwwwwxxxx日本| 麻豆一区在线| 日韩女优视频免费观看| 国产极品一区二区| 亚洲精品国产精品粉嫩| 亚洲精品视频免费| 特级西西www444人体聚色| 久久人人99| 欧美成人精品三级在线观看 | 小小影院久久| 欧美二区在线播放| 亚洲另类在线观看| 麻豆精品在线观看| 成人91视频| 无码精品人妻一区二区| 久久久久国产精品麻豆ai换脸 | 日韩伦理一区| 欧美精品一区二区免费| www成人在线| 麻豆传媒一区二区三区| 国产精品传媒毛片三区| 黄色片在线看| 一区二区三区毛片| 每日在线观看av| 蜜桃视频动漫在线播放| 欧美日本精品一区二区三区| 国产污在线观看| 你懂的在线观看一区二区| 中文字幕亚洲综合| 精品成人久久久| 美女脱光内衣内裤视频久久影院| 91精品黄色| 成人午夜影视| 亚洲狠狠丁香婷婷综合久久久| 2021狠狠干| 全亚洲第一av番号网站| 日韩一区二区三区视频在线观看 | 一区三区在线欧| 精品自拍视频在线观看| 日韩精品人妻中文字幕| 久久er99精品| 欧美日韩精品免费观看视一区二区 | 日韩在线视频在线| 国产69精品久久久久9999人| 日韩一区二区精品在线观看| 永久免费av无码网站性色av| 在线日本高清免费不卡| 国产精品999999| 亚洲国产精品无码久久| 国产精品乱人伦| 那种视频在线观看| 成人在线视频你懂的| 中文字幕日本欧美| 亚洲区一区二区三| 日韩高清在线观看| 欧美日韩精品综合| 蜜桃视频在线网站| 精品盗摄一区二区三区| 动漫性做爰视频| 美国av一区二区| 日韩免费一区二区三区| av今日在线| 日韩精品影音先锋| 黄视频网站免费看| 美女视频黄 久久| 欧洲成人一区二区| 亚洲美女久久精品| 日韩精品免费在线视频观看| 久久精品人妻一区二区三区| 国产精品一区二区久久不卡| 91免费视频黄| 国产精一区二区| 久久久精品久久| 国产片在线播放| ●精品国产综合乱码久久久久| 国产精品一区二区羞羞答答| 精品一级毛片| 国产成人激情视频| 国产午夜在线观看| 91高清视频免费看| 最新中文字幕av| 免费观看成人鲁鲁鲁鲁鲁视频| 日韩一本精品| 国产欧美在线观看免费| 在线电影中文日韩| 伊人22222| 亚洲欧美日韩人成在线播放| 一二三av在线| 婷婷综合在线| 91夜夜揉人人捏人人添红杏| 亚洲wwwww| 亚洲国语精品自产拍在线观看| 好吊妞视频一区二区三区| 97久久久精品综合88久久| 日本中文字幕片| 亚洲影院天堂中文av色| 国产suv精品一区二区三区88区| youjizz在线播放| 欧美三日本三级三级在线播放| 久久成人小视频| 成人午夜碰碰视频| 91视频最新入口| 欧美色女视频| 成人国产亚洲精品a区天堂华泰| 影院在线观看全集免费观看| 亚洲国产成人在线视频| 国产一区二区视频免费| 亚洲欧洲成人自拍| 亚洲av无一区二区三区久久| 国产精品毛片一区二区三区| 亚洲精品一区二区三区蜜桃久| 国产一精品一av一免费爽爽| 91国内精品久久| 五月天婷婷在线视频| 日韩欧美一二区| 亚洲日本韩国在线| 中文字幕一区在线| 精品伦一区二区三区| 久久亚洲美女| 日韩精品伦理第一区| 啪啪av大全导航福利综合导航| 久久韩剧网电视剧| 无码精品在线观看| 色94色欧美sute亚洲线路一久| 羞羞在线观看视频| 国产成人欧美日韩在线电影| 大肉大捧一进一出好爽动态图| 亚洲色图88| 欧洲精品国产| gogo人体一区| 成人精品aaaa网站| 中文字幕在线直播| 欧美成人亚洲成人日韩成人| 精品亚洲成a人片在线观看| 日韩网站在线看片你懂的| 国产剧情在线视频| 一区二区三区在线播放| 欧美 日韩 成人| www.av精品| 国产sm在线观看| 三级欧美在线一区| 大伊香蕉精品视频在线| 久久久久久久久久久久久久久久久久| 久久99精品久久久久久久久久 | 日韩av在线播放中文字幕| 久久精品无码中文字幕| 欧美顶级大胆免费视频| 黑人中文字幕一区二区三区| 欧美天堂在线| 伊人青青综合网站| 欧洲天堂在线观看| 精品国产3级a| 国产黄色大片网站| 正在播放亚洲一区| 在线观看视频二区| 一区二区三区加勒比av| 最新一区二区三区| 国产精品国产成人国产三级| 日本一级免费视频| 久久亚洲二区三区| 中文字幕一区二区久久人妻网站 | xxxx日本黄色| 久久青草欧美一区二区三区| 国产精品第七页| 成人国产精品免费| 美女日批在线观看| 国产乱淫av一区二区三区| 最新天堂中文在线| 美国毛片一区二区| 欧美丝袜在线观看| 另类小说综合欧美亚洲| 精品久久久久久久无码| 久久综合导航| 91av俱乐部| 三级精品在线观看| 久久久免费视频网站| 噜噜噜91成人网| 狠狠操精品视频| 亚洲一区成人| 国产又黄又爽免费视频| 重囗味另类老妇506070| 国产一级片91| 国产精品a级| 在线视频亚洲自拍| 久久久久午夜电影| 嫩草影院中文字幕| 最新国产拍偷乱拍精品 | 久久精品久久99精品久久| 日本不卡一区在线| 亚洲专区免费| 女人喷潮完整视频| 一区二区三区福利| 男人透女人免费视频| 丝袜亚洲精品中文字幕一区| 91极品视频在线观看| 国产馆精品极品| 亚洲男人在线天堂| 久久久美女艺术照精彩视频福利播放| 人妻熟女aⅴ一区二区三区汇编| 久久一区二区三区四区| 亚洲av无码一区二区三区人| 国产精品国产三级国产aⅴ中文| 最新国产一区| 日韩在线免费电影| 精品国产区一区二区三区在线观看| 久草视频在线看| 久久精品成人动漫| 川上优av中文字幕一区二区| 久久人人爽人人爽人人片av高请| 性孕妇free特大另类| 国产精品人成电影| 国产成人福利av| 午夜一区二区三区| 欧美区亚洲区| 大j8黑人w巨大888a片| 免费久久99精品国产| 好吊操视频这里只有精品| 91在线视频网址| 男人天堂资源网| 亚洲成国产人片在线观看| 亚洲GV成人无码久久精品| 欧美一区二区在线观看| www.黄色一片| 日韩高清不卡av| 成人福利片网站| 国产91在线高潮白浆在线观看| 国产福利亚洲| 国产成人成网站在线播放青青| 欧美精选一区二区三区| 免费看欧美黑人毛片| 日本麻豆一区二区三区视频| 午夜激情视频网| 久久精品亚洲国产奇米99| 九九视频免费看| 欧美视频一区二区三区在线观看| 精品久久无码中文字幕| 国产亚洲aⅴaaaaaa毛片| 黄色免费在线观看| 日本91av在线播放| 91综合久久爱com| 亚洲激情一区二区三区| 亚洲制服av| 精品人妻一区二区三区日产| 日韩毛片在线免费观看| 无码人妻丰满熟妇区五十路| 精品乱码亚洲一区二区不卡| 色视频在线观看免费| 欧美激情免费在线| www欧美在线观看| 色吧亚洲视频| 麻豆精品91| 国产ts丝袜人妖系列视频| 一区二区三区免费网站| 国产一区二区麻豆| 一本色道久久88综合亚洲精品ⅰ | 久久久av电影| 国产精品高潮久久| 亚洲无线码在线一区观看| 久久久综合久久久| 6080亚洲精品一区二区| 91se在线| 国产精品一区=区| 欧美一区电影| 亚洲精品一二三四五区| 久久蜜桃av一区二区天堂| 精品成人久久久| 日韩成人激情在线| 在线欧美三级| 福利视频一区二区三区| 韩日精品视频| www.男人天堂| 欧美日韩一区二区在线播放| 外国精品视频在线观看 | 精品久久久网| 亚洲一区二区三区精品视频| 蜜桃久久久久久久| 欧美图片第一页| 在线看一区二区| 精品美女视频在线观看免费软件| 97久久精品人搡人人玩| 偷拍自拍一区| 免费看污污网站| 久久精品一区四区| 日本一级淫片免费放| 亚洲成人a**站| 在线精品亚洲欧美日韩国产| 任我爽在线视频精品一| 日本不卡一二三区黄网| 日本美女黄色一级片| 日韩一区和二区| 24小时免费看片在线观看| 久久一区二区三区av| 久久综合九色| 免费成人深夜夜行网站| 91麻豆精品国产综合久久久久久 | www.com操| 亚洲日本一区二区三区| 97人人爽人人爽人人爽| 欧美高清一级大片| 亚洲三级网页| 男人搞女人网站| 亚洲特级片在线| 欧美77777| 国产精品第一区| 亚洲成av人片乱码色午夜| zjzjzjzjzj亚洲女人| 亚洲国产视频在线| 你懂的视频在线免费| 国产精品爱啪在线线免费观看| 九一国产精品| 免费人成视频在线播放| 亚洲欧美日韩系列| 午夜福利一区二区三区| 欧美综合一区第一页| 日韩1区在线| 男人的天堂影院| 欧美日韩精品专区| www在线视频| www.成人av.com| 久久亚洲色图| 放荡的美妇在线播放| 亚洲国产97在线精品一区| 新版中文在线官网| 裸模一区二区三区免费| 韩国成人精品a∨在线观看| 中文字幕在线观看免费视频| 日韩一二三在线视频播| 色天下一区二区三区| 中文字幕资源在线观看| 欧美性xxxxx| 欧美xxx黑人xxx水蜜桃|