Filter:   InfoImg
download cd1400.h
Language: C
License: GPL
Copyright: (C) 1994-1996 Greg Ungerer. (C) 1996-1998 Stallion Technologies
LOC: 158
Project Info
linux kernel
Server: Kernel.org
Type: zip
...linux kernel\include\linux\
   8250_pci.h
   a.out.h
   ac97_codec.h
   acct.h
   acpi.h
   adb.h
   adfs_fs.h
   adfs_fs_i.h
   adfs_fs_sb.h
   aer.h
   affs_hardblocks.h
   agp_backend.h
   agpgart.h
   aio.h
   aio_abi.h
   amifd.h
   amifdreg.h
   amigaffs.h
   apm_bios.h
   arcdevice.h
   arcfb.h
   ata.h
   atalk.h
   atm.h
   atm_eni.h
   atm_he.h
   atm_idt77105.h
   atm_nicstar.h
   atm_suni.h
   atm_tcp.h
   atm_zatm.h
   atmapi.h
   atmarp.h
   atmbr2684.h
   atmclip.h
   atmdev.h
   atmioc.h
   atmlec.h
   atmmpc.h
   atmppp.h
   atmsap.h
   atmsvc.h
   attribute_container.h
   audit.h
   auto_fs.h
   auto_fs4.h
   auxvec.h
   awe_voice.h
   ax25.h
   b1lli.h
   b1pcmcia.h
   backing-dev.h
   backlight.h
   baycom.h
   bcd.h
   bfs_fs.h
   binfmts.h
   bio.h
   bit_spinlock.h
   bitmap.h
   bitops.h
   blkdev.h
   blkpg.h
   blktrace_api.h
   blockgroup_lock.h
   bootmem.h
   bpqether.h
   buffer_head.h
   cache.h
   calc64.h
   capability.h
   capi.h
   carta_random32.h
   cciss_ioctl.h
   cd1400.h
   cdev.h
   cdk.h
   cdrom.h
   chio.h
   circ_buf.h
   clk.h
   clocksource.h
   cm4000_cs.h
   cn_proc.h
   cobalt-nvram.h
   coda.h
   coda_cache.h
   coda_fs_i.h
   coda_linux.h
   coda_proc.h
   coda_psdev.h
   coff.h
   com20020.h
   compat.h
   compat_ioctl.h
   compiler-gcc.h
   compiler-gcc3.h
   compiler-gcc4.h
   compiler-intel.h
   compiler.h
   completion.h
   comstats.h
   concap.h
   configfs.h
   connector.h
   console.h
   console_struct.h
   consolemap.h
   cpu.h
   cpufreq.h
   cpumask.h
   cpuset.h
   cramfs_fs.h
   cramfs_fs_sb.h
   crash_dump.h
   crc-ccitt.h
   crc16.h
   crc32.h
   crc32c.h
   crypto.h
   cryptohash.h
   ctype.h
   cuda.h
   cyclades.h
   cyclomx.h
   cycx_cfm.h
   cycx_drv.h
   cycx_x25.h
   dcache.h
   dccp.h
   dcookies.h
   debug_locks.h
   debugfs.h
   delay.h
   delayacct.h
   device-mapper.h
   device.h
   devpts_fs.h
   dio.h
   dirent.h
   divert.h
   dlm.h
   dlm_device.h
   dm-ioctl.h
   dm9000.h
   dma-mapping.h
   dmaengine.h
   dmapool.h
   dmi.h
   dn.h
   dnotify.h
   dqblk_v1.h
   dqblk_v2.h
   dqblk_xfs.h
   ds1286.h
   ds17287rtc.h
   ds1742rtc.h
   dtlk.h
   edd.h
   efi.h
   efs_dir.h
   efs_fs.h
   efs_fs_i.h
   efs_fs_sb.h
   efs_vh.h
   eisa.h
   elevator.h
   elf-em.h
   elf-fdpic.h
   elf.h
   elfcore.h
   elfnote.h
   err.h
   errno.h
   errqueue.h
   etherdevice.h
   ethtool.h
   eventpoll.h
   ext2_fs.h
   ext2_fs_sb.h
   ext3_fs.h
   ext3_fs_i.h
   ext3_fs_sb.h
   ext3_jbd.h
   ext4_fs.h
   ext4_fs_extents.h
   ext4_fs_i.h
   ext4_fs_sb.h
   ext4_jbd2.h
   fadvise.h
   fb.h
   fcdevice.h
   fcntl.h
   fd.h
   fd1772.h
   fddidevice.h
   fdreg.h
   fib_rules.h
   file.h
   filter.h
   firmware.h
   flat.h
   font.h
   fs.h
   fs_enet_pd.h
   fs_struct.h
   fs_uart_pd.h
   fsl_devices.h
   fsnotify.h
   ftape-header-segment.h
   ftape-vendors.h
   ftape.h
   fuse.h
   futex.h
   gameport.h
   gen_stats.h
   genalloc.h
   generic_acl.h
   generic_serial.h
   genetlink.h
   genhd.h
   getcpu.h
   gfp.h
   gfs2_ondisk.h
   gigaset_dev.h
   hardirq.h
   harrier_defs.h
   hash.h
   hayesesp.h
   hdlc.h
   hdlcdrv.h
   hdpu_features.h
   hdreg.h
   hdsmart.h
   hiddev.h
   highmem.h
   highuid.h
   hil.h
   hil_mlc.h
   hippidevice.h
   hp_sdc.h
   hpet.h
   hrtimer.h
   htirq.h
   hugetlb.h
   hw_random.h
   hwmon-sysfs.h
   hwmon-vid.h
   hwmon.h
   hysdn_if.h
   i2c-algo-bit.h
   i2c-algo-ite.h
   i2c-algo-pca.h
   i2c-algo-pcf.h
   i2c-algo-sgi.h
   i2c-dev.h
   i2c-id.h
   i2c-isa.h
   i2c-ocores.h
   i2c-pxa.h
   i2c.h
   i2o-dev.h
   i2o.h
   i8k.h
   ibmtr.h
   icmp.h
   icmpv6.h
   ide.h
   idr.h
   if.h
   if_addr.h
   if_arcnet.h
   if_arp.h
   if_bonding.h
   if_bridge.h
   if_cablemodem.h
   if_ec.h
   if_eql.h
   if_ether.h
   if_fc.h
   if_fddi.h
   if_frad.h
   if_hippi.h
   if_infiniband.h
   if_link.h
   if_ltalk.h
   if_packet.h
   if_plip.h
   if_ppp.h
   if_pppox.h
   if_shaper.h
   if_slip.h
   if_strip.h
   if_tr.h
   if_tun.h
   if_tunnel.h
   if_vlan.h
   if_wanpipe.h
   if_wanpipe_common.h
   igmp.h
   in.h
   in_route.h
   in6.h
   inet.h
   inet_diag.h
   inetdevice.h
   init.h
   init_task.h
   initrd.h
   inotify.h
   input.h
   interrupt.h
   io.h
   ioc3.h
   ioc4.h
   ioctl.h
   ioctl32.h
   ioport.h
   ioprio.h
   ip.h
   ip_mp_alg.h
   ip6_tunnel.h
   ipc.h
   ipmi.h
   ipmi_msgdefs.h
   ipmi_smi.h
   ipsec.h
   ipv6.h
   ipv6_route.h
   ipx.h
   irda.h
   irq.h
   irq_cpustat.h
   irqflags.h
   irqreturn.h
   isa.h
   isapnp.h
   isdn.h
   isdn_divertif.h
   isdn_ppp.h
   isdnif.h
   isicom.h
   iso_fs.h
   istallion.h
   ixjuser.h
   jbd.h
   jbd2.h
   jffs.h
   jffs2.h
   jhash.h
   jiffies.h
   journal-head.h
   joystick.h
   kallsyms.h
   kbd_diacr.h
   kbd_kern.h
   kd.h
   kdev_t.h
   kernel.h
   kernel_stat.h
   kernelcapi.h
   kexec.h
   key-ui.h
   key.h
   keyboard.h
   keyctl.h
   kfifo.h
   klist.h
   kmalloc_sizes.h
   kmod.h
   kobj_map.h
   kobject.h
   kprobes.h
   kref.h
   kthread.h
   ktime.h
   lapb.h
   latency.h
   lcd.h
   leds.h
   libata.h
   libps2.h
   license.h
   limits.h
   linkage.h
   linux_logo.h
   list.h
   llc.h
   lm_interface.h
   lock_dlm_plock.h
   lockdep.h
   loop.h
   lp.h
   m41t00.h
   m48t86.h
   magic.h
   major.h
   matroxfb.h
   mbcache.h
   mc146818rtc.h
   mc6821.h
   mca-legacy.h
   mca.h
   memory.h
   memory_hotplug.h
   mempolicy.h
   mempool.h
   meye.h
   migrate.h
   mii.h
   minix_fs.h
   miscdevice.h
   mm.h
   mm_inline.h
   mm_types.h
   mman.h
   mmtimer.h
   mmzone.h
   mod_devicetable.h
   module.h
   moduleloader.h
   moduleparam.h
   mount.h
   mpage.h
   mqueue.h
   mroute.h
   msdos_fs.h
   msg.h
   msi.h
   mtio.h
   mutex-debug.h
   mutex.h
   mv643xx.h
   n_r3964.h
   namei.h
   namespace.h
   nbd.h
   ncp.h
   ncp_fs.h
   ncp_fs_i.h
   ncp_fs_sb.h
   ncp_mount.h
   ncp_no.h
   neighbour.h
   net.h
   netdevice.h
   netfilter.h
   netfilter_arp.h
   netfilter_bridge.h
   netfilter_decnet.h
   netfilter_ipv4.h
   netfilter_ipv6.h
   netlink.h
   netpoll.h
   netrom.h
   nfs.h
   nfs_fs.h
   nfs_fs_i.h
   nfs_fs_sb.h
   nfs_idmap.h
   nfs_mount.h
   nfs_page.h
   nfs_xdr.h
   nfs2.h
   nfs3.h
   nfs4.h
   nfs4_acl.h
   nfs4_mount.h
   nfsacl.h
   nfsd_idmap.h
   nls.h
   nmi.h
   node.h
   nodemask.h
   notifier.h
   nsc_gpio.h
   nsproxy.h
   nubus.h
   numa.h
   nvram.h
   oom.h
   oprofile.h
   page-flags.h
   pagemap.h
   pagevec.h
   param.h
   parport.h
   parport_pc.h
   parser.h
   patchkey.h
   pci-acpi.h
   pci.h
   pci_hotplug.h
   pci_ids.h
   pci_regs.h
   pcieport_if.h
   percpu.h
   percpu_counter.h
   personality.h
   pfkeyv2.h
   pfn.h
   pg.h
   phonedev.h
   phy.h
   pid.h
   pipe_fs_i.h
   pkt_cls.h
   pkt_sched.h
   pktcdvd.h
   platform_device.h
   plist.h
   pm.h
   pm_legacy.h
   pmu.h
   pnp.h
   pnpbios.h
   poison.h
   poll.h
   posix-timers.h
   posix_acl.h
   posix_acl_xattr.h
   posix_types.h
   ppdev.h
   ppp-comp.h
   ppp_channel.h
   ppp_defs.h
   prctl.h
   preempt.h
   prefetch.h
   prio_tree.h
   proc_fs.h
   profile.h
   ps2esdi.h
   pspace.h
   ptrace.h
   qic117.h
   qnx4_fs.h
   qnxtypes.h
   quota.h
   quotaio_v1.h
   quotaio_v2.h
   quotaops.h
   radeonfb.h
   radix-tree.h
   raid_class.h
   ramfs.h
   random.h
   raw.h
   rbtree.h
   rcupdate.h
   reboot.h
   reboot_fixups.h
   reiserfs_acl.h
   reiserfs_fs.h
   reiserfs_fs_i.h
   reiserfs_fs_sb.h
   reiserfs_xattr.h
   relay.h
   resource.h
   resume-trace.h
   rio.h
   rio_drv.h
   rio_ids.h
   rio_regs.h
   rmap.h
   romfs_fs.h
   root_dev.h
   rose.h
   route.h
   rslib.h
   rtc-v3020.h
   rtc.h
   rtmutex.h
   rtnetlink.h
   rwsem-spinlock.h
   rwsem.h
   sc26198.h
   scatterlist.h
   scc.h
   sched.h
   screen_info.h
   sctp.h
   scx200.h
   scx200_gpio.h
   sdla.h
   sdla_fr.h
   seccomp.h
   securebits.h
   security.h
   selection.h
   selinux.h
   selinux_netlink.h
   sem.h
   seq_file.h
   seqlock.h
   serial.h
   serial_8250.h
   serial_core.h
   serial_ip3106.h
   serial_reg.h
   serial167.h
   serialP.h
   serio.h
   shm.h
   shmem_fs.h
   signal.h
   skbuff.h
   slab.h
   smb.h
   smb_fs.h
   smb_fs_i.h
   smb_fs_sb.h
   smb_mount.h
   smbno.h
   smp.h
   smp_lock.h
   snmp.h
   socket.h
   sockios.h
   som.h
   sonet.h
   sonypi.h
   sort.h
   sound.h
   soundcard.h
   spinlock.h
   spinlock_api_smp.h
   spinlock_api_up.h
   spinlock_types.h
   spinlock_types_up.h
   spinlock_up.h
   srcu.h
   stacktrace.h
   stallion.h
   stat.h
   statfs.h
   stddef.h
   stop_machine.h
   string.h
   stringify.h
   superhyway.h
   suspend.h
   swap.h
   swapops.h
   synclink.h
   sys.h
   syscalls.h
   sysctl.h
   sysdev.h
   sysfs.h
   sysrq.h
   sysv_fs.h
   taskstats.h
   taskstats_kern.h
   tcp.h
   telephony.h
   termios.h
   textsearch.h
   textsearch_fsm.h
   tfrc.h
   thread_info.h
   threads.h
   ticable.h
   tifm.h
   time.h
   timer.h
   times.h
   timex.h
   tiocl.h
   tipc.h
   tipc_config.h
   topology.h
   toshiba.h
   transport_class.h
   trdevice.h
   tsacct_kern.h
   tty.h
   tty_driver.h
   tty_flip.h
   tty_ldisc.h
   types.h
   uaccess.h
   udf_fs.h
   udf_fs_i.h
   udf_fs_sb.h
   udp.h
   ufs_fs.h
   ufs_fs_i.h
   ufs_fs_sb.h
   uinput.h
   uio.h
   ultrasound.h
   umem.h
   un.h
   unistd.h
   unwind.h
   usb.h
   usb_ch9.h
   usb_gadget.h
   usb_gadgetfs.h
   usb_usual.h
   usbdevice_fs.h
   user.h
   utime.h
   uts.h
   utsname.h
   vermagic.h
   vfs.h
   via.h
   video_decoder.h
   video_encoder.h
   videodev.h
   videodev2.h
   videotext.h
   vmalloc.h
   vmstat.h
   vt.h
   vt_buffer.h
   vt_kern.h
   wait.h
   wanrouter.h
   watchdog.h
   wireless.h
   workqueue.h
   writeback.h
   x25.h
   xattr.h
   xfrm.h
   yam.h
   zconf.h
   zftape.h
   zlib.h
   zorro.h
   zorro_ids.h
   zutil.h

/*****************************************************************************/

/*
 *	cd1400.h  -- cd1400 UART hardware info.
 *
 *	Copyright (C) 1996-1998  Stallion Technologies
 *	Copyright (C) 1994-1996  Greg Ungerer.
 *
 *	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	_CD1400_H
#define	_CD1400_H
/*****************************************************************************/

/*
 *	Define the number of async ports per cd1400 uart chip.
 */
#define	CD1400_PORTS		4

/*
 *	Define the cd1400 uarts internal FIFO sizes.
 */
#define	CD1400_TXFIFOSIZE	12
#define	CD1400_RXFIFOSIZE	12

/*
 *	Local RX FIFO thresh hold level. Also define the RTS thresh hold
 *	based on the RX thresh hold.
 */
#define	FIFO_RXTHRESHOLD	6
#define	FIFO_RTSTHRESHOLD	7

/*****************************************************************************/

/*
 *	Define the cd1400 register addresses. These are all the valid
 *	registers with the cd1400. Some are global, some virtual, some
 *	per port.
 */
#define	GFRCR		0x40
#define	CAR		0x68
#define	GCR		0x4b
#define	SVRR		0x67
#define	RICR		0x44
#define	TICR		0x45
#define	MICR		0x46
#define	RIR		0x6b
#define	TIR		0x6a
#define	MIR		0x69
#define	PPR		0x7e

#define	RIVR		0x43
#define	TIVR		0x42
#define	MIVR		0x41
#define	TDR		0x63
#define	RDSR		0x62
#define	MISR		0x4c
#define	EOSRR		0x60

#define	LIVR		0x18
#define	CCR		0x05
#define	SRER		0x06
#define	COR1		0x08
#define	COR2		0x09
#define	COR3		0x0a
#define	COR4		0x1e
#define	COR5		0x1f
#define	CCSR		0x0b
#define	RDCR		0x0e
#define	SCHR1		0x1a
#define	SCHR2		0x1b
#define	SCHR3		0x1c
#define	SCHR4		0x1d
#define	SCRL		0x22
#define	SCRH		0x23
#define	LNC		0x24
#define	MCOR1		0x15
#define	MCOR2		0x16
#define	RTPR		0x21
#define	MSVR1		0x6c
#define	MSVR2		0x6d
#define	PSVR		0x6f
#define	RBPR		0x78
#define	RCOR		0x7c
#define	TBPR		0x72
#define	TCOR		0x76

/*****************************************************************************/

/*
 *	Define the set of baud rate clock divisors.
 */
#define	CD1400_CLK0	8
#define	CD1400_CLK1	32
#define	CD1400_CLK2	128
#define	CD1400_CLK3	512
#define	CD1400_CLK4	2048

#define	CD1400_NUMCLKS	5

/*****************************************************************************/

/*
 *	Define the clock pre-scalar value to be a 5 ms clock. This should be
 *	OK for now. It would probably be better to make it 10 ms, but we
 *	can't fit that divisor into 8 bits!
 */
#define	PPR_SCALAR	244

/*****************************************************************************/

/*
 *	Define values used to set character size options.
 */
#define	COR1_CHL5	0x00
#define	COR1_CHL6	0x01
#define	COR1_CHL7	0x02
#define	COR1_CHL8	0x03

/*
 *	Define values used to set the number of stop bits.
 */
#define	COR1_STOP1	0x00
#define	COR1_STOP15	0x04
#define	COR1_STOP2	0x08

/*
 *	Define values used to set the parity scheme in use.
 */
#define	COR1_PARNONE	0x00
#define	COR1_PARFORCE	0x20
#define	COR1_PARENB	0x40
#define	COR1_PARIGNORE	0x10

#define	COR1_PARODD	0x80
#define	COR1_PAREVEN	0x00

#define	COR2_IXM	0x80
#define	COR2_TXIBE	0x40
#define	COR2_ETC	0x20
#define	COR2_LLM	0x10
#define	COR2_RLM	0x08
#define	COR2_RTSAO	0x04
#define	COR2_CTSAE	0x02

#define	COR3_SCDRNG	0x80
#define	COR3_SCD34	0x40
#define	COR3_FCT	0x20
#define	COR3_SCD12	0x10

/*
 *	Define values used by COR4.
 */
#define	COR4_BRKINT	0x08
#define	COR4_IGNBRK	0x18

/*****************************************************************************/

/*
 *	Define the modem control register values.
 *	Note that the actual hardware is a little different to the conventional
 *	pin names on the cd1400.
 */
#define	MSVR1_DTR	0x01
#define	MSVR1_DSR	0x10
#define	MSVR1_RI	0x20
#define	MSVR1_CTS	0x40
#define	MSVR1_DCD	0x80

#define	MSVR2_RTS	0x02
#define	MSVR2_DSR	0x10
#define	MSVR2_RI	0x20
#define	MSVR2_CTS	0x40
#define	MSVR2_DCD	0x80

#define	MCOR1_DCD	0x80
#define	MCOR1_CTS	0x40
#define	MCOR1_RI	0x20
#define	MCOR1_DSR	0x10

#define	MCOR2_DCD	0x80
#define	MCOR2_CTS	0x40
#define	MCOR2_RI	0x20
#define	MCOR2_DSR	0x10

/*****************************************************************************/

/*
 *	Define the bits used with the service (interrupt) enable register.
 */
#define	SRER_NNDT	0x01
#define	SRER_TXEMPTY	0x02
#define	SRER_TXDATA	0x04
#define	SRER_RXDATA	0x10
#define	SRER_MODEM	0x80

/*****************************************************************************/

/*
 *	Define operational commands for the command register.
 */
#define	CCR_RESET	0x80
#define	CCR_CORCHANGE	0x4e
#define	CCR_SENDCH	0x20
#define	CCR_CHANCTRL	0x