/* * Zoran zr36057/zr36067 PCI controller driver, for the * Pinnacle/Miro DC10/DC10+/DC30/DC30+, Iomega Buz, Linux * Media Labs LML33/LML33R10. * * This part handles card-specific data and detection * * Copyright (C) 2000 Serguei Miridonov * * Currently maintained by: * Ronald Bultje * Laurent Pinchart * Mailinglist * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * 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 __ZORAN_DEVICE_H__ #define __ZORAN_DEVICE_H__ /* general purpose I/O */ extern void GPIO(struct zoran *zr, int bit, unsigned int value); /* codec (or actually: guest bus) access */ extern int post_office_wait(struct zoran *zr); extern int post_office_write(struct zoran *zr, unsigned guest, unsigned reg, unsigned value); extern int post_office_read(struct zoran *zr, unsigned guest, unsigned reg); extern void detect_guest_activity(struct zoran *zr); extern void jpeg_codec_sleep(struct zoran *zr, int sleep); extern int jpeg_codec_reset(struct zoran *zr); /* zr360x7 access to raw capture */ extern void zr36057_overlay(struct zoran *zr, int on); extern void write_overlay_mask(struct zoran_fh *fh, struct v4l2_clip *vp, int count); extern void zr36057_set_memgrab(struct zoran *zr, int mode); extern int wait_grab_pending(struct zoran *zr); /* interrupts */ extern void print_interrupts(struct zoran *zr); extern void clear_interrupt_counters(struct zoran *zr); #if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,19) extern irqreturn_t zoran_irq(int irq, void *dev_id, struct pt_regs *regs); #else extern irqreturn_t zoran_irq(int irq, void *dev_id); #endif /* JPEG codec access */ extern void jpeg_start(struct zoran *zr); extern void zr36057_enable_jpg(struct zoran *zr, enum zoran_codec_mode mode); extern void zoran_feed_stat_com(struct zoran *zr); /* general */ extern void zoran_set_pci_master(struct zoran *zr, int set_master); extern void zoran_init_hardware(struct zoran *zr); extern void zr36057_restart(struct zoran *zr); extern const struct zoran_format zoran_formats[]; extern int v4l_nbufs; extern int v4l_bufsize; extern int jpg_nbufs; extern int jpg_bufsize; extern int pass_through; /* i2c */ #define decoder_call(zr, o, f, args...) \ v4l2_subdev_call(zr->decoder, o, f, ##args) #define encoder_call(zr, o, f, args...) \ v4l2_subdev_call(zr->encoder, o, f, ##args) int decoder_s_std(struct zoran *zr, v4l2_std_id std); int decoder_s_routing(struct zoran *zr, struct v4l2_routing *route); #endif /* __ZORAN_DEVICE_H__ */