#include <sys/param.h>
#include <sys/systm.h>
#include <sys/device.h>
#include <sys/disklabel.h>
#include <sys/ioctl.h>
#include <sys/tty.h>
#include <sys/vnode.h>
#include <machine/conf.h>
#include "wd.h"
bdev_decl(wd);
#include "fd.h"
bdev_decl(fd);
#include "sd.h"
#include "st.h"
#include "cd.h"
#include "uk.h"
#include "vnd.h"
#include "rd.h"
struct bdevsw bdevsw[] =
{
bdev_disk_init(NWD,wd),
bdev_swap_init(1,sw),
bdev_disk_init(NFD,fd),
bdev_notdef(),
bdev_disk_init(NSD,sd),
bdev_notdef(),
bdev_disk_init(NCD,cd),
bdev_notdef(),
bdev_notdef(),
bdev_notdef(),
bdev_notdef(),
bdev_notdef(),
bdev_notdef(),
bdev_notdef(),
bdev_disk_init(NVND,vnd),
bdev_notdef(),
bdev_notdef(),
bdev_disk_init(NRD,rd),
bdev_notdef(),
bdev_notdef(),
};
int nblkdev = nitems(bdevsw);
#define cdev_ocis_init(c,n) { \
dev_init(c,n,open), dev_init(c,n,close), (dev_type_read((*))) enodev, \
(dev_type_write((*))) enodev, dev_init(c,n,ioctl), \
(dev_type_stop((*))) enodev, 0, \
(dev_type_mmap((*))) enodev, 0, 0, seltrue_kqfilter }
#define cdev_nvram_init(c,n) { \
dev_init(c,n,open), dev_init(c,n,close), dev_init(c,n,read), \
(dev_type_write((*))) enodev, (dev_type_ioctl((*))) enodev, \
(dev_type_stop((*))) enodev, 0, \
(dev_type_mmap((*))) enodev, 0, 0, seltrue_kqfilter }
#define cdev_vmm_init(c,n) { \
dev_init(c,n,open), dev_init(c,n,close), \
(dev_type_read((*))) enodev, \
(dev_type_write((*))) enodev, \
dev_init(c,n,ioctl), \
(dev_type_stop((*))) enodev, 0, \
(dev_type_mmap((*))) enodev, 0, 0, seltrue_kqfilter }
#define cdev_psp_init(c,n) { \
dev_init(c,n,open), dev_init(c,n,close), \
(dev_type_read((*))) enodev, \
(dev_type_write((*))) enodev, \
dev_init(c,n,ioctl), \
(dev_type_stop((*))) enodev, 0, \
(dev_type_mmap((*))) enodev, 0, 0, seltrue_kqfilter }
#define mmread mmrw
#define mmwrite mmrw
cdev_decl(mm);
cdev_decl(wd);
#include "bio.h"
#include "pty.h"
#include "com.h"
cdev_decl(com);
cdev_decl(fd);
#include "lpt.h"
cdev_decl(lpt);
#include "ch.h"
#include "bpfilter.h"
#include "spkr.h"
cdev_decl(spkr);
#include "cy.h"
cdev_decl(cy);
#include "tun.h"
#include "audio.h"
#include "video.h"
#include "midi.h"
#include "acpi.h"
#include "pctr.h"
#include "bktr.h"
#include "ksyms.h"
#include "kstat.h"
#include "usb.h"
#include "uhid.h"
#include "fido.h"
#include "ujoy.h"
#include "ugen.h"
#include "ulpt.h"
#include "ucom.h"
#include "cz.h"
cdev_decl(cztty);
#include "radio.h"
#include "nvram.h"
cdev_decl(nvram);
#include "drm.h"
#include "viocon.h"
cdev_decl(viocon);
#include "wsdisplay.h"
#include "wskbd.h"
#include "wsmouse.h"
#include "wsmux.h"
#include "kexec.h"
#include "kcov.h"
#ifdef USER_PCICONF
#include "pci.h"
cdev_decl(pci);
#endif
#include "dt.h"
#include "pf.h"
#include "hotplug.h"
#include "gpio.h"
#include "vscsi.h"
#include "pppx.h"
#include "fuse.h"
#include "pvbus.h"
#include "ipmi.h"
#include "efi.h"
struct cdevsw cdevsw[] =
{
cdev_cn_init(1,cn),
cdev_ctty_init(1,ctty),
cdev_mm_init(1,mm),
cdev_disk_init(NWD,wd),
cdev_notdef(),
cdev_tty_init(NPTY,pts),
cdev_ptc_init(NPTY,ptc),
cdev_log_init(1,log),
cdev_tty_init(NCOM,com),
cdev_disk_init(NFD,fd),
cdev_vmm_init(NVMM,vmm),
cdev_notdef(),
cdev_wsdisplay_init(NWSDISPLAY,
wsdisplay),
cdev_disk_init(NSD,sd),
cdev_tape_init(NST,st),
cdev_disk_init(NCD,cd),
cdev_lpt_init(NLPT,lpt),
cdev_ch_init(NCH,ch),
cdev_kexec_init(NKEXEC,kexec),
cdev_kcov_init(NKCOV,kcov),
cdev_uk_init(NUK,uk),
cdev_notdef(),
cdev_fd_init(1,filedesc),
cdev_bpf_init(NBPFILTER,bpf),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_spkr_init(NSPKR,spkr),
cdev_notdef(),
cdev_notdef(),
cdev_dt_init(NDT,dt),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_tty_init(NCY,cy),
cdev_notdef(),
cdev_tun_init(NTUN,tun),
cdev_disk_init(NVND,vnd),
cdev_audio_init(NAUDIO,audio),
cdev_notdef(),
cdev_video_init(NVIDEO,video),
cdev_random_init(1,random),
cdev_ocis_init(NPCTR,pctr),
cdev_disk_init(NRD,rd),
cdev_notdef(),
cdev_bktr_init(NBKTR,bktr),
cdev_ksyms_init(NKSYMS,ksyms),
cdev_kstat_init(NKSTAT,kstat),
cdev_midi_init(NMIDI,midi),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_notdef(),
cdev_usb_init(NUSB,usb),
cdev_usbdev_init(NUHID,uhid),
cdev_usbdev_init(NUGEN,ugen),
cdev_ulpt_init(NULPT,ulpt),
cdev_notdef(),
cdev_tty_init(NUCOM,ucom),
cdev_mouse_init(NWSKBD, wskbd),
cdev_mouse_init(NWSMOUSE,
wsmouse),
cdev_mouse_init(NWSMUX, wsmux),
cdev_notdef(),
cdev_tty_init(NCZ,cztty),
#ifdef USER_PCICONF
cdev_pci_init(NPCI,pci),
#else
cdev_notdef(),
#endif
cdev_pf_init(NPF,pf),
cdev_notdef(),
cdev_notdef(),
cdev_radio_init(NRADIO, radio),
cdev_notdef(),
cdev_notdef(),
cdev_bio_init(NBIO,bio),
cdev_notdef(),
cdev_ptm_init(NPTY,ptm),
cdev_hotplug_init(NHOTPLUG,hotplug),
cdev_acpi_init(NACPI,acpi),
cdev_efi_init(NEFI,efi),
cdev_nvram_init(NNVRAM,nvram),
cdev_notdef(),
cdev_drm_init(NDRM,drm),
cdev_gpio_init(NGPIO,gpio),
cdev_vscsi_init(NVSCSI,vscsi),
cdev_disk_init(1,diskmap),
cdev_pppx_init(NPPPX,pppx),
cdev_fuse_init(NFUSE,fuse),
cdev_tun_init(NTUN,tap),
cdev_tty_init(NVIOCON,viocon),
cdev_pvbus_init(NPVBUS,pvbus),
cdev_ipmi_init(NIPMI,ipmi),
cdev_notdef(),
cdev_fido_init(NFIDO,fido),
cdev_pppx_init(NPPPX,pppac),
cdev_ujoy_init(NUJOY,ujoy),
cdev_psp_init(NPSP,psp),
};
int nchrdev = nitems(cdevsw);
int mem_no = 2;
dev_t swapdev = makedev(1, 0);
int
iskmemdev(dev_t dev)
{
return (major(dev) == mem_no && minor(dev) < 2);
}
int
iszerodev(dev_t dev)
{
return (major(dev) == mem_no && minor(dev) == 12);
}
dev_t
getnulldev(void)
{
return makedev(mem_no, 2);
}
const int chrtoblktbl[] = {
NODEV,
NODEV,
NODEV,
0,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
2,
NODEV,
NODEV,
NODEV,
4,
NODEV,
6,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
14,
NODEV,
NODEV,
NODEV,
NODEV,
NODEV,
17,
};
const int nchrtoblktbl = nitems(chrtoblktbl);
int findblkmajor(struct device *dv);
dev_t dev_rawpart(struct device *);
dev_t
dev_rawpart(struct device *dv)
{
int majdev;
majdev = findblkmajor(dv);
switch (majdev) {
case 0:
case 4:
return (MAKEDISKDEV(majdev, dv->dv_unit, RAW_PART));
break;
default:
;
}
return (NODEV);
}
#include <dev/cons.h>
cons_decl(com);
cons_decl(ws);
struct consdev constab[] = {
#if NWSDISPLAY > 0
cons_init(ws),
#endif
#if NCOM > 0
cons_init(com),
#endif
{ 0 },
};