????JFIF??x?x????'
Server IP : 79.136.114.73 / Your IP : 3.138.140.5 Web Server : Apache/2.4.7 (Ubuntu) PHP/5.5.9-1ubuntu4.29 OpenSSL/1.0.1f System : Linux b8009 3.13.0-170-generic #220-Ubuntu SMP Thu May 9 12:40:49 UTC 2019 x86_64 User : www-data ( 33) PHP Version : 5.5.9-1ubuntu4.29 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority, MySQL : ON | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /lib/modules/3.13.0-35-generic/build/include/media/blackfin/ |
Upload File : |
/* * Analog Devices PPI header file * * Copyright (c) 2011 Analog Devices Inc. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #ifndef _PPI_H_ #define _PPI_H_ #include <linux/interrupt.h> #include <asm/blackfin.h> #include <asm/bfin_ppi.h> /* EPPI */ #ifdef EPPI_EN #define PORT_EN EPPI_EN #define PORT_DIR EPPI_DIR #define DMA32 0 #define PACK_EN PACKEN #endif /* EPPI3 */ #ifdef EPPI0_CTL2 #define PORT_EN EPPI_CTL_EN #define PORT_DIR EPPI_CTL_DIR #define PACK_EN EPPI_CTL_PACKEN #define DMA32 0 #define DLEN_8 EPPI_CTL_DLEN08 #define DLEN_16 EPPI_CTL_DLEN16 #endif struct ppi_if; struct ppi_params { u32 width; /* width in pixels */ u32 height; /* height in lines */ u32 hdelay; /* delay after the HSYNC in pixels */ u32 vdelay; /* delay after the VSYNC in lines */ u32 line; /* total pixels per line */ u32 frame; /* total lines per frame */ u32 hsync; /* HSYNC length in pixels */ u32 vsync; /* VSYNC length in lines */ int bpp; /* bits per pixel */ int dlen; /* data length for ppi in bits */ u32 ppi_control; /* ppi configuration */ u32 int_mask; /* interrupt mask */ }; struct ppi_ops { int (*attach_irq)(struct ppi_if *ppi, irq_handler_t handler); void (*detach_irq)(struct ppi_if *ppi); int (*start)(struct ppi_if *ppi); int (*stop)(struct ppi_if *ppi); int (*set_params)(struct ppi_if *ppi, struct ppi_params *params); void (*update_addr)(struct ppi_if *ppi, unsigned long addr); }; enum ppi_type { PPI_TYPE_PPI, PPI_TYPE_EPPI, PPI_TYPE_EPPI3, }; struct ppi_info { enum ppi_type type; int dma_ch; int irq_err; void __iomem *base; const unsigned short *pin_req; }; struct ppi_if { unsigned long ppi_control; const struct ppi_ops *ops; const struct ppi_info *info; bool err_int; /* if we need request error interrupt */ bool err; /* if ppi has fifo error */ void *priv; }; struct ppi_if *ppi_create_instance(const struct ppi_info *info); void ppi_delete_instance(struct ppi_if *ppi); #endif