Commit aca21de2 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'm68k-for-v4.16-tag1' of git://git.kernel.org/pub/scm/linux/kernel/git/geert/linux-m68k

Pull m68k updates from Geert Uytterhoeven:

  - first part of an overhaul of the NuBus subsystem, to bring it up to
    modern driver model standards

  - a race condition fix for Mac

  - defconfig updates

* tag 'm68k-for-v4.16-tag1' of git://git.kernel.org/pub/scm/linux/kernel/git/geert/linux-m68k:
  MAINTAINERS: Add NuBus subsystem entry
  m68k/mac: Fix race conditions in OSS interrupt dispatch
  nubus: Add support for the driver model
  nubus: Add expansion_type values for various Mac models
  nubus: Adopt standard linked list implementation
  nubus: Rename struct nubus_dev
  nubus: Rework /proc/bus/nubus/s/ implementation
  nubus: Generalize block resource handling
  nubus: Clean up whitespace
  nubus: Remove redundant code
  nubus: Call proc_mkdir() not more than once per slot directory
  nubus: Validate slot resource IDs
  nubus: Fix log spam
  nubus: Use static functions where possible
  nubus: Fix up header split
  nubus: Avoid array underflow and overflow
  m68k/defconfig: Update defconfigs for v4.15-rc1
parents 31466f3e 2334b1ac
...@@ -9757,6 +9757,15 @@ S: Supported ...@@ -9757,6 +9757,15 @@ S: Supported
F: Documentation/filesystems/ntfs.txt F: Documentation/filesystems/ntfs.txt
F: fs/ntfs/ F: fs/ntfs/
NUBUS SUBSYSTEM
M: Finn Thain <fthain@telegraphics.com.au>
L: linux-m68k@lists.linux-m68k.org
S: Maintained
F: arch/*/include/asm/nubus.h
F: drivers/nubus/
F: include/linux/nubus.h
F: include/uapi/linux/nubus.h
NVIDIA (rivafb and nvidiafb) FRAMEBUFFER DRIVER NVIDIA (rivafb and nvidiafb) FRAMEBUFFER DRIVER
M: Antonino Daplas <adaplas@gmail.com> M: Antonino Daplas <adaplas@gmail.com>
L: linux-fbdev@vger.kernel.org L: linux-fbdev@vger.kernel.org
......
...@@ -454,7 +454,6 @@ CONFIG_PPS_CLIENT_LDISC=m ...@@ -454,7 +454,6 @@ CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PPS_CLIENT_PARPORT=m CONFIG_PPS_CLIENT_PARPORT=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_FB=y CONFIG_FB=y
CONFIG_FB_CIRRUS=y CONFIG_FB_CIRRUS=y
CONFIG_FB_AMIGA=y CONFIG_FB_AMIGA=y
...@@ -595,6 +594,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -595,6 +594,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -624,6 +624,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -624,6 +624,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -653,3 +654,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -653,3 +654,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -422,7 +422,6 @@ CONFIG_NTP_PPS=y ...@@ -422,7 +422,6 @@ CONFIG_NTP_PPS=y
CONFIG_PPS_CLIENT_LDISC=m CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_FB=y CONFIG_FB=y
CONFIG_FRAMEBUFFER_CONSOLE=y CONFIG_FRAMEBUFFER_CONSOLE=y
CONFIG_LOGO=y CONFIG_LOGO=y
...@@ -554,6 +553,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -554,6 +553,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -583,6 +583,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -583,6 +583,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -612,3 +613,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -612,3 +613,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -437,7 +437,6 @@ CONFIG_PPS_CLIENT_LDISC=m ...@@ -437,7 +437,6 @@ CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PPS_CLIENT_PARPORT=m CONFIG_PPS_CLIENT_PARPORT=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_FB=y CONFIG_FB=y
CONFIG_FB_ATARI=y CONFIG_FB_ATARI=y
CONFIG_FRAMEBUFFER_CONSOLE=y CONFIG_FRAMEBUFFER_CONSOLE=y
...@@ -576,6 +575,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -576,6 +575,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -605,6 +605,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -605,6 +605,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -634,3 +635,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -634,3 +635,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -420,7 +420,6 @@ CONFIG_NTP_PPS=y ...@@ -420,7 +420,6 @@ CONFIG_NTP_PPS=y
CONFIG_PPS_CLIENT_LDISC=m CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_HID=m CONFIG_HID=m
CONFIG_HIDRAW=y CONFIG_HIDRAW=y
CONFIG_UHID=m CONFIG_UHID=m
...@@ -546,6 +545,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -546,6 +545,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -575,6 +575,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -575,6 +575,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -604,3 +605,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -604,3 +605,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -425,7 +425,6 @@ CONFIG_NTP_PPS=y ...@@ -425,7 +425,6 @@ CONFIG_NTP_PPS=y
CONFIG_PPS_CLIENT_LDISC=m CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_FB=y CONFIG_FB=y
CONFIG_FRAMEBUFFER_CONSOLE=y CONFIG_FRAMEBUFFER_CONSOLE=y
CONFIG_LOGO=y CONFIG_LOGO=y
...@@ -556,6 +555,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -556,6 +555,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -585,6 +585,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -585,6 +585,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -614,3 +615,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -614,3 +615,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -447,7 +447,6 @@ CONFIG_NTP_PPS=y ...@@ -447,7 +447,6 @@ CONFIG_NTP_PPS=y
CONFIG_PPS_CLIENT_LDISC=m CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_FB=y CONFIG_FB=y
CONFIG_FB_VALKYRIE=y CONFIG_FB_VALKYRIE=y
CONFIG_FB_MAC=y CONFIG_FB_MAC=y
...@@ -578,6 +577,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -578,6 +577,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -607,6 +607,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -607,6 +607,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -636,3 +637,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -636,3 +637,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -504,7 +504,6 @@ CONFIG_PPS_CLIENT_LDISC=m ...@@ -504,7 +504,6 @@ CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PPS_CLIENT_PARPORT=m CONFIG_PPS_CLIENT_PARPORT=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_FB=y CONFIG_FB=y
CONFIG_FB_CIRRUS=y CONFIG_FB_CIRRUS=y
CONFIG_FB_AMIGA=y CONFIG_FB_AMIGA=y
...@@ -658,6 +657,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -658,6 +657,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -687,6 +687,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -687,6 +687,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -716,3 +717,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -716,3 +717,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -420,7 +420,6 @@ CONFIG_NTP_PPS=y ...@@ -420,7 +420,6 @@ CONFIG_NTP_PPS=y
CONFIG_PPS_CLIENT_LDISC=m CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_HID=m CONFIG_HID=m
CONFIG_HIDRAW=y CONFIG_HIDRAW=y
CONFIG_UHID=m CONFIG_UHID=m
...@@ -546,6 +545,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -546,6 +545,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -575,6 +575,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -575,6 +575,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -604,3 +605,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -604,3 +605,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -420,7 +420,6 @@ CONFIG_NTP_PPS=y ...@@ -420,7 +420,6 @@ CONFIG_NTP_PPS=y
CONFIG_PPS_CLIENT_LDISC=m CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_HID=m CONFIG_HID=m
CONFIG_HIDRAW=y CONFIG_HIDRAW=y
CONFIG_UHID=m CONFIG_UHID=m
...@@ -546,6 +545,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -546,6 +545,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -575,6 +575,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -575,6 +575,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -604,3 +605,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -604,3 +605,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -437,7 +437,6 @@ CONFIG_PPS_CLIENT_LDISC=m ...@@ -437,7 +437,6 @@ CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PPS_CLIENT_PARPORT=m CONFIG_PPS_CLIENT_PARPORT=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_FB=y CONFIG_FB=y
CONFIG_FRAMEBUFFER_CONSOLE=y CONFIG_FRAMEBUFFER_CONSOLE=y
CONFIG_LOGO=y CONFIG_LOGO=y
...@@ -569,6 +568,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -569,6 +568,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -598,6 +598,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -598,6 +598,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -627,3 +628,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -627,3 +628,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -419,7 +419,6 @@ CONFIG_NTP_PPS=y ...@@ -419,7 +419,6 @@ CONFIG_NTP_PPS=y
CONFIG_PPS_CLIENT_LDISC=m CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_FB=y CONFIG_FB=y
CONFIG_FRAMEBUFFER_CONSOLE=y CONFIG_FRAMEBUFFER_CONSOLE=y
CONFIG_LOGO=y CONFIG_LOGO=y
...@@ -548,6 +547,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -548,6 +547,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -576,6 +576,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -576,6 +576,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -605,3 +606,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -605,3 +606,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -419,7 +419,6 @@ CONFIG_NTP_PPS=y ...@@ -419,7 +419,6 @@ CONFIG_NTP_PPS=y
CONFIG_PPS_CLIENT_LDISC=m CONFIG_PPS_CLIENT_LDISC=m
CONFIG_PTP_1588_CLOCK=m CONFIG_PTP_1588_CLOCK=m
# CONFIG_HWMON is not set # CONFIG_HWMON is not set
# CONFIG_RC_CORE is not set
CONFIG_FB=y CONFIG_FB=y
CONFIG_FRAMEBUFFER_CONSOLE=y CONFIG_FRAMEBUFFER_CONSOLE=y
CONFIG_LOGO=y CONFIG_LOGO=y
...@@ -548,6 +547,7 @@ CONFIG_TEST_RHASHTABLE=m ...@@ -548,6 +547,7 @@ CONFIG_TEST_RHASHTABLE=m
CONFIG_TEST_HASH=m CONFIG_TEST_HASH=m
CONFIG_TEST_USER_COPY=m CONFIG_TEST_USER_COPY=m
CONFIG_TEST_BPF=m CONFIG_TEST_BPF=m
CONFIG_TEST_FIND_BIT=m
CONFIG_TEST_FIRMWARE=m CONFIG_TEST_FIRMWARE=m
CONFIG_TEST_SYSCTL=m CONFIG_TEST_SYSCTL=m
CONFIG_TEST_UDELAY=m CONFIG_TEST_UDELAY=m
...@@ -577,6 +577,7 @@ CONFIG_CRYPTO_RMD256=m ...@@ -577,6 +577,7 @@ CONFIG_CRYPTO_RMD256=m
CONFIG_CRYPTO_RMD320=m CONFIG_CRYPTO_RMD320=m
CONFIG_CRYPTO_SHA512=m CONFIG_CRYPTO_SHA512=m
CONFIG_CRYPTO_SHA3=m CONFIG_CRYPTO_SHA3=m
CONFIG_CRYPTO_SM3=m
CONFIG_CRYPTO_TGR192=m CONFIG_CRYPTO_TGR192=m
CONFIG_CRYPTO_WP512=m CONFIG_CRYPTO_WP512=m
CONFIG_CRYPTO_AES_TI=m CONFIG_CRYPTO_AES_TI=m
...@@ -606,3 +607,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m ...@@ -606,3 +607,4 @@ CONFIG_CRYPTO_USER_API_AEAD=m
# CONFIG_CRYPTO_HW is not set # CONFIG_CRYPTO_HW is not set
CONFIG_CRC32_SELFTEST=m CONFIG_CRC32_SELFTEST=m
CONFIG_XZ_DEC_TEST=m CONFIG_XZ_DEC_TEST=m
CONFIG_STRING_SELFTEST=m
...@@ -33,7 +33,7 @@ struct mac_model ...@@ -33,7 +33,7 @@ struct mac_model
char ide_type; char ide_type;
char scc_type; char scc_type;
char ether_type; char ether_type;
char nubus_type; char expansion_type;
char floppy_type; char floppy_type;
}; };
...@@ -73,8 +73,11 @@ struct mac_model ...@@ -73,8 +73,11 @@ struct mac_model
#define MAC_ETHER_SONIC 1 #define MAC_ETHER_SONIC 1
#define MAC_ETHER_MACE 2 #define MAC_ETHER_MACE 2
#define MAC_NO_NUBUS 0 #define MAC_EXP_NONE 0
#define MAC_NUBUS 1 #define MAC_EXP_PDS 1 /* Accepts only a PDS card */
#define MAC_EXP_NUBUS 2 /* Accepts only NuBus card(s) */
#define MAC_EXP_PDS_NUBUS 3 /* Accepts PDS card and/or NuBus card(s) */
#define MAC_EXP_PDS_COMM 4 /* Accepts PDS card or Comm Slot card */
#define MAC_FLOPPY_IWM 0 #define MAC_FLOPPY_IWM 0
#define MAC_FLOPPY_SWIM_ADDR1 1 #define MAC_FLOPPY_SWIM_ADDR1 1
......
...@@ -212,7 +212,7 @@ static struct mac_model mac_data_table[] = { ...@@ -212,7 +212,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_II, .via_type = MAC_VIA_II,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_IWM, .floppy_type = MAC_FLOPPY_IWM,
}, },
...@@ -227,7 +227,7 @@ static struct mac_model mac_data_table[] = { ...@@ -227,7 +227,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_II, .via_type = MAC_VIA_II,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_IWM, .floppy_type = MAC_FLOPPY_IWM,
}, { }, {
.ident = MAC_MODEL_IIX, .ident = MAC_MODEL_IIX,
...@@ -236,7 +236,7 @@ static struct mac_model mac_data_table[] = { ...@@ -236,7 +236,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_II, .via_type = MAC_VIA_II,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_IICX, .ident = MAC_MODEL_IICX,
...@@ -245,7 +245,7 @@ static struct mac_model mac_data_table[] = { ...@@ -245,7 +245,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_II, .via_type = MAC_VIA_II,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_SE30, .ident = MAC_MODEL_SE30,
...@@ -254,7 +254,7 @@ static struct mac_model mac_data_table[] = { ...@@ -254,7 +254,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_II, .via_type = MAC_VIA_II,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, },
...@@ -272,7 +272,7 @@ static struct mac_model mac_data_table[] = { ...@@ -272,7 +272,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_IIFX, .ident = MAC_MODEL_IIFX,
...@@ -281,7 +281,7 @@ static struct mac_model mac_data_table[] = { ...@@ -281,7 +281,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_IIFX, .scsi_type = MAC_SCSI_IIFX,
.scc_type = MAC_SCC_IOP, .scc_type = MAC_SCC_IOP,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_IOP, .floppy_type = MAC_FLOPPY_SWIM_IOP,
}, { }, {
.ident = MAC_MODEL_IISI, .ident = MAC_MODEL_IISI,
...@@ -290,7 +290,7 @@ static struct mac_model mac_data_table[] = { ...@@ -290,7 +290,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_IIVI, .ident = MAC_MODEL_IIVI,
...@@ -299,7 +299,7 @@ static struct mac_model mac_data_table[] = { ...@@ -299,7 +299,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_IIVX, .ident = MAC_MODEL_IIVX,
...@@ -308,7 +308,7 @@ static struct mac_model mac_data_table[] = { ...@@ -308,7 +308,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, },
...@@ -323,7 +323,6 @@ static struct mac_model mac_data_table[] = { ...@@ -323,7 +323,6 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_CCL, .ident = MAC_MODEL_CCL,
...@@ -332,7 +331,7 @@ static struct mac_model mac_data_table[] = { ...@@ -332,7 +331,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_CCLII, .ident = MAC_MODEL_CCLII,
...@@ -341,7 +340,7 @@ static struct mac_model mac_data_table[] = { ...@@ -341,7 +340,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, },
...@@ -356,7 +355,7 @@ static struct mac_model mac_data_table[] = { ...@@ -356,7 +355,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_LCII, .ident = MAC_MODEL_LCII,
...@@ -365,7 +364,7 @@ static struct mac_model mac_data_table[] = { ...@@ -365,7 +364,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_LCIII, .ident = MAC_MODEL_LCIII,
...@@ -374,7 +373,7 @@ static struct mac_model mac_data_table[] = { ...@@ -374,7 +373,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, },
...@@ -395,7 +394,7 @@ static struct mac_model mac_data_table[] = { ...@@ -395,7 +394,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_Q605_ACC, .ident = MAC_MODEL_Q605_ACC,
...@@ -404,7 +403,7 @@ static struct mac_model mac_data_table[] = { ...@@ -404,7 +403,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_Q610, .ident = MAC_MODEL_Q610,
...@@ -414,7 +413,7 @@ static struct mac_model mac_data_table[] = { ...@@ -414,7 +413,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.ether_type = MAC_ETHER_SONIC, .ether_type = MAC_ETHER_SONIC,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_Q630, .ident = MAC_MODEL_Q630,
...@@ -424,8 +423,7 @@ static struct mac_model mac_data_table[] = { ...@@ -424,8 +423,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.ide_type = MAC_IDE_QUADRA, .ide_type = MAC_IDE_QUADRA,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.ether_type = MAC_ETHER_SONIC, .expansion_type = MAC_EXP_PDS_COMM,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_Q650, .ident = MAC_MODEL_Q650,
...@@ -435,7 +433,7 @@ static struct mac_model mac_data_table[] = { ...@@ -435,7 +433,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.ether_type = MAC_ETHER_SONIC, .ether_type = MAC_ETHER_SONIC,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, },
/* The Q700 does have a NS Sonic */ /* The Q700 does have a NS Sonic */
...@@ -447,7 +445,7 @@ static struct mac_model mac_data_table[] = { ...@@ -447,7 +445,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA2, .scsi_type = MAC_SCSI_QUADRA2,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.ether_type = MAC_ETHER_SONIC, .ether_type = MAC_ETHER_SONIC,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_Q800, .ident = MAC_MODEL_Q800,
...@@ -457,7 +455,7 @@ static struct mac_model mac_data_table[] = { ...@@ -457,7 +455,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.ether_type = MAC_ETHER_SONIC, .ether_type = MAC_ETHER_SONIC,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_Q840, .ident = MAC_MODEL_Q840,
...@@ -467,7 +465,7 @@ static struct mac_model mac_data_table[] = { ...@@ -467,7 +465,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA3, .scsi_type = MAC_SCSI_QUADRA3,
.scc_type = MAC_SCC_PSC, .scc_type = MAC_SCC_PSC,
.ether_type = MAC_ETHER_MACE, .ether_type = MAC_ETHER_MACE,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_AV, .floppy_type = MAC_FLOPPY_AV,
}, { }, {
.ident = MAC_MODEL_Q900, .ident = MAC_MODEL_Q900,
...@@ -477,7 +475,7 @@ static struct mac_model mac_data_table[] = { ...@@ -477,7 +475,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA2, .scsi_type = MAC_SCSI_QUADRA2,
.scc_type = MAC_SCC_IOP, .scc_type = MAC_SCC_IOP,
.ether_type = MAC_ETHER_SONIC, .ether_type = MAC_ETHER_SONIC,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_IOP, .floppy_type = MAC_FLOPPY_SWIM_IOP,
}, { }, {
.ident = MAC_MODEL_Q950, .ident = MAC_MODEL_Q950,
...@@ -487,7 +485,7 @@ static struct mac_model mac_data_table[] = { ...@@ -487,7 +485,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA2, .scsi_type = MAC_SCSI_QUADRA2,
.scc_type = MAC_SCC_IOP, .scc_type = MAC_SCC_IOP,
.ether_type = MAC_ETHER_SONIC, .ether_type = MAC_ETHER_SONIC,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_IOP, .floppy_type = MAC_FLOPPY_SWIM_IOP,
}, },
...@@ -502,7 +500,7 @@ static struct mac_model mac_data_table[] = { ...@@ -502,7 +500,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_P475, .ident = MAC_MODEL_P475,
...@@ -511,7 +509,7 @@ static struct mac_model mac_data_table[] = { ...@@ -511,7 +509,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_P475F, .ident = MAC_MODEL_P475F,
...@@ -520,7 +518,7 @@ static struct mac_model mac_data_table[] = { ...@@ -520,7 +518,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_P520, .ident = MAC_MODEL_P520,
...@@ -529,7 +527,7 @@ static struct mac_model mac_data_table[] = { ...@@ -529,7 +527,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_P550, .ident = MAC_MODEL_P550,
...@@ -538,7 +536,7 @@ static struct mac_model mac_data_table[] = { ...@@ -538,7 +536,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, },
/* These have the comm slot, and therefore possibly SONIC ethernet */ /* These have the comm slot, and therefore possibly SONIC ethernet */
...@@ -549,8 +547,7 @@ static struct mac_model mac_data_table[] = { ...@@ -549,8 +547,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.ether_type = MAC_ETHER_SONIC, .expansion_type = MAC_EXP_PDS_COMM,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_P588, .ident = MAC_MODEL_P588,
...@@ -560,8 +557,7 @@ static struct mac_model mac_data_table[] = { ...@@ -560,8 +557,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.ide_type = MAC_IDE_QUADRA, .ide_type = MAC_IDE_QUADRA,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.ether_type = MAC_ETHER_SONIC, .expansion_type = MAC_EXP_PDS_COMM,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_TV, .ident = MAC_MODEL_TV,
...@@ -570,7 +566,6 @@ static struct mac_model mac_data_table[] = { ...@@ -570,7 +566,6 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_P600, .ident = MAC_MODEL_P600,
...@@ -579,7 +574,7 @@ static struct mac_model mac_data_table[] = { ...@@ -579,7 +574,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_LC, .scsi_type = MAC_SCSI_LC,
.scc_type = MAC_SCC_II, .scc_type = MAC_SCC_II,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, },
...@@ -596,7 +591,7 @@ static struct mac_model mac_data_table[] = { ...@@ -596,7 +591,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.ether_type = MAC_ETHER_SONIC, .ether_type = MAC_ETHER_SONIC,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_C650, .ident = MAC_MODEL_C650,
...@@ -606,7 +601,7 @@ static struct mac_model mac_data_table[] = { ...@@ -606,7 +601,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA, .scsi_type = MAC_SCSI_QUADRA,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.ether_type = MAC_ETHER_SONIC, .ether_type = MAC_ETHER_SONIC,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR1, .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
}, { }, {
.ident = MAC_MODEL_C660, .ident = MAC_MODEL_C660,
...@@ -616,7 +611,7 @@ static struct mac_model mac_data_table[] = { ...@@ -616,7 +611,7 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_QUADRA3, .scsi_type = MAC_SCSI_QUADRA3,
.scc_type = MAC_SCC_PSC, .scc_type = MAC_SCC_PSC,
.ether_type = MAC_ETHER_MACE, .ether_type = MAC_ETHER_MACE,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_PDS_NUBUS,
.floppy_type = MAC_FLOPPY_AV, .floppy_type = MAC_FLOPPY_AV,
}, },
...@@ -633,7 +628,6 @@ static struct mac_model mac_data_table[] = { ...@@ -633,7 +628,6 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB145, .ident = MAC_MODEL_PB145,
...@@ -642,7 +636,6 @@ static struct mac_model mac_data_table[] = { ...@@ -642,7 +636,6 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB150, .ident = MAC_MODEL_PB150,
...@@ -652,7 +645,6 @@ static struct mac_model mac_data_table[] = { ...@@ -652,7 +645,6 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.ide_type = MAC_IDE_PB, .ide_type = MAC_IDE_PB,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB160, .ident = MAC_MODEL_PB160,
...@@ -661,7 +653,6 @@ static struct mac_model mac_data_table[] = { ...@@ -661,7 +653,6 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB165, .ident = MAC_MODEL_PB165,
...@@ -670,7 +661,6 @@ static struct mac_model mac_data_table[] = { ...@@ -670,7 +661,6 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB165C, .ident = MAC_MODEL_PB165C,
...@@ -679,7 +669,6 @@ static struct mac_model mac_data_table[] = { ...@@ -679,7 +669,6 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB170, .ident = MAC_MODEL_PB170,
...@@ -688,7 +677,6 @@ static struct mac_model mac_data_table[] = { ...@@ -688,7 +677,6 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB180, .ident = MAC_MODEL_PB180,
...@@ -697,7 +685,6 @@ static struct mac_model mac_data_table[] = { ...@@ -697,7 +685,6 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB180C, .ident = MAC_MODEL_PB180C,
...@@ -706,7 +693,6 @@ static struct mac_model mac_data_table[] = { ...@@ -706,7 +693,6 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_QUADRA, .via_type = MAC_VIA_QUADRA,
.scsi_type = MAC_SCSI_OLD, .scsi_type = MAC_SCSI_OLD,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB190, .ident = MAC_MODEL_PB190,
...@@ -716,7 +702,6 @@ static struct mac_model mac_data_table[] = { ...@@ -716,7 +702,6 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_LATE, .scsi_type = MAC_SCSI_LATE,
.ide_type = MAC_IDE_BABOON, .ide_type = MAC_IDE_BABOON,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB520, .ident = MAC_MODEL_PB520,
...@@ -726,7 +711,6 @@ static struct mac_model mac_data_table[] = { ...@@ -726,7 +711,6 @@ static struct mac_model mac_data_table[] = {
.scsi_type = MAC_SCSI_LATE, .scsi_type = MAC_SCSI_LATE,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.ether_type = MAC_ETHER_SONIC, .ether_type = MAC_ETHER_SONIC,
.nubus_type = MAC_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, },
...@@ -743,7 +727,7 @@ static struct mac_model mac_data_table[] = { ...@@ -743,7 +727,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_DUO, .scsi_type = MAC_SCSI_DUO,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB230, .ident = MAC_MODEL_PB230,
...@@ -752,7 +736,7 @@ static struct mac_model mac_data_table[] = { ...@@ -752,7 +736,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_DUO, .scsi_type = MAC_SCSI_DUO,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB250, .ident = MAC_MODEL_PB250,
...@@ -761,7 +745,7 @@ static struct mac_model mac_data_table[] = { ...@@ -761,7 +745,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_DUO, .scsi_type = MAC_SCSI_DUO,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB270C, .ident = MAC_MODEL_PB270C,
...@@ -770,7 +754,7 @@ static struct mac_model mac_data_table[] = { ...@@ -770,7 +754,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_DUO, .scsi_type = MAC_SCSI_DUO,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB280, .ident = MAC_MODEL_PB280,
...@@ -779,7 +763,7 @@ static struct mac_model mac_data_table[] = { ...@@ -779,7 +763,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_DUO, .scsi_type = MAC_SCSI_DUO,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, { }, {
.ident = MAC_MODEL_PB280C, .ident = MAC_MODEL_PB280C,
...@@ -788,7 +772,7 @@ static struct mac_model mac_data_table[] = { ...@@ -788,7 +772,7 @@ static struct mac_model mac_data_table[] = {
.via_type = MAC_VIA_IICI, .via_type = MAC_VIA_IICI,
.scsi_type = MAC_SCSI_DUO, .scsi_type = MAC_SCSI_DUO,
.scc_type = MAC_SCC_QUADRA, .scc_type = MAC_SCC_QUADRA,
.nubus_type = MAC_NUBUS, .expansion_type = MAC_EXP_NUBUS,
.floppy_type = MAC_FLOPPY_SWIM_ADDR2, .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
}, },
...@@ -1100,14 +1084,12 @@ int __init mac_platform_init(void) ...@@ -1100,14 +1084,12 @@ int __init mac_platform_init(void)
* Ethernet device * Ethernet device
*/ */
switch (macintosh_config->ether_type) { if (macintosh_config->ether_type == MAC_ETHER_SONIC ||
case MAC_ETHER_SONIC: macintosh_config->expansion_type == MAC_EXP_PDS_COMM)
platform_device_register_simple("macsonic", -1, NULL, 0); platform_device_register_simple("macsonic", -1, NULL, 0);
break;
case MAC_ETHER_MACE: if (macintosh_config->ether_type == MAC_ETHER_MACE)
platform_device_register_simple("macmace", -1, NULL, 0); platform_device_register_simple("macmace", -1, NULL, 0);
break;
}
return 0; return 0;
} }
......
...@@ -53,56 +53,41 @@ void __init oss_init(void) ...@@ -53,56 +53,41 @@ void __init oss_init(void)
} }
/* /*
* Handle miscellaneous OSS interrupts. * Handle OSS interrupts.
* XXX how do you clear a pending IRQ? is it even necessary?
*/ */
static void oss_irq(struct irq_desc *desc) static void oss_iopism_irq(struct irq_desc *desc)
{ {
int events = oss->irq_pending & generic_handle_irq(IRQ_MAC_ADB);
(OSS_IP_IOPSCC | OSS_IP_SCSI | OSS_IP_IOPISM);
if (events & OSS_IP_IOPSCC) {
oss->irq_pending &= ~OSS_IP_IOPSCC;
generic_handle_irq(IRQ_MAC_SCC);
}
if (events & OSS_IP_SCSI) {
oss->irq_pending &= ~OSS_IP_SCSI;
generic_handle_irq(IRQ_MAC_SCSI);
}
if (events & OSS_IP_IOPISM) {
oss->irq_pending &= ~OSS_IP_IOPISM;
generic_handle_irq(IRQ_MAC_ADB);
}
} }
/* static void oss_scsi_irq(struct irq_desc *desc)
* Nubus IRQ handler, OSS style {
* generic_handle_irq(IRQ_MAC_SCSI);
* Unlike the VIA/RBV this is on its own autovector interrupt level. }
*/
static void oss_nubus_irq(struct irq_desc *desc) static void oss_nubus_irq(struct irq_desc *desc)
{ {
int events, irq_bit, i; u16 events, irq_bit;
int irq_num;
events = oss->irq_pending & OSS_IP_NUBUS; events = oss->irq_pending & OSS_IP_NUBUS;
if (!events) irq_num = NUBUS_SOURCE_BASE + 5;
return; irq_bit = OSS_IP_NUBUS5;
/* There are only six slots on the OSS, not seven */
i = 6;
irq_bit = 0x40;
do { do {
--i;
irq_bit >>= 1;
if (events & irq_bit) { if (events & irq_bit) {
oss->irq_pending &= ~irq_bit; events &= ~irq_bit;
generic_handle_irq(NUBUS_SOURCE_BASE + i); generic_handle_irq(irq_num);
} }
} while(events & (irq_bit - 1)); --irq_num;
irq_bit >>= 1;
} while (events);
}
static void oss_iopscc_irq(struct irq_desc *desc)
{
generic_handle_irq(IRQ_MAC_SCC);
} }
/* /*
...@@ -122,14 +107,14 @@ static void oss_nubus_irq(struct irq_desc *desc) ...@@ -122,14 +107,14 @@ static void oss_nubus_irq(struct irq_desc *desc)
void __init oss_register_interrupts(void) void __init oss_register_interrupts(void)
{ {
irq_set_chained_handler(OSS_IRQLEV_IOPISM, oss_irq); irq_set_chained_handler(OSS_IRQLEV_IOPISM, oss_iopism_irq);
irq_set_chained_handler(OSS_IRQLEV_SCSI, oss_irq); irq_set_chained_handler(OSS_IRQLEV_SCSI, oss_scsi_irq);
irq_set_chained_handler(OSS_IRQLEV_NUBUS, oss_nubus_irq); irq_set_chained_handler(OSS_IRQLEV_NUBUS, oss_nubus_irq);
irq_set_chained_handler(OSS_IRQLEV_IOPSCC, oss_irq); irq_set_chained_handler(OSS_IRQLEV_IOPSCC, oss_iopscc_irq);
irq_set_chained_handler(OSS_IRQLEV_VIA1, via1_irq); irq_set_chained_handler(OSS_IRQLEV_VIA1, via1_irq);
/* OSS_VIA1 gets enabled here because it has no machspec interrupt. */ /* OSS_VIA1 gets enabled here because it has no machspec interrupt. */
oss->irq_level[OSS_VIA1] = IRQ_AUTO_6; oss->irq_level[OSS_VIA1] = OSS_IRQLEV_VIA1;
} }
/* /*
......
...@@ -123,7 +123,8 @@ enum mac8390_access { ...@@ -123,7 +123,8 @@ enum mac8390_access {
}; };
extern int mac8390_memtest(struct net_device *dev); extern int mac8390_memtest(struct net_device *dev);
static int mac8390_initdev(struct net_device *dev, struct nubus_dev *ndev, static int mac8390_initdev(struct net_device *dev,
struct nubus_rsrc *ndev,
enum mac8390_type type); enum mac8390_type type);
static int mac8390_open(struct net_device *dev); static int mac8390_open(struct net_device *dev);
...@@ -169,11 +170,11 @@ static void word_memcpy_tocard(unsigned long tp, const void *fp, int count); ...@@ -169,11 +170,11 @@ static void word_memcpy_tocard(unsigned long tp, const void *fp, int count);
static void word_memcpy_fromcard(void *tp, unsigned long fp, int count); static void word_memcpy_fromcard(void *tp, unsigned long fp, int count);
static u32 mac8390_msg_enable; static u32 mac8390_msg_enable;
static enum mac8390_type __init mac8390_ident(struct nubus_dev *dev) static enum mac8390_type __init mac8390_ident(struct nubus_rsrc *fres)
{ {
switch (dev->dr_sw) { switch (fres->dr_sw) {
case NUBUS_DRSW_3COM: case NUBUS_DRSW_3COM:
switch (dev->dr_hw) { switch (fres->dr_hw) {
case NUBUS_DRHW_APPLE_SONIC_NB: case NUBUS_DRHW_APPLE_SONIC_NB:
case NUBUS_DRHW_APPLE_SONIC_LC: case NUBUS_DRHW_APPLE_SONIC_LC:
case NUBUS_DRHW_SONNET: case NUBUS_DRHW_SONNET:
...@@ -184,7 +185,7 @@ static enum mac8390_type __init mac8390_ident(struct nubus_dev *dev) ...@@ -184,7 +185,7 @@ static enum mac8390_type __init mac8390_ident(struct nubus_dev *dev)
break; break;
case NUBUS_DRSW_APPLE: case NUBUS_DRSW_APPLE:
switch (dev->dr_hw) { switch (fres->dr_hw) {
case NUBUS_DRHW_ASANTE_LC: case NUBUS_DRHW_ASANTE_LC:
return MAC8390_NONE; return MAC8390_NONE;
case NUBUS_DRHW_CABLETRON: case NUBUS_DRHW_CABLETRON:
...@@ -201,7 +202,7 @@ static enum mac8390_type __init mac8390_ident(struct nubus_dev *dev) ...@@ -201,7 +202,7 @@ static enum mac8390_type __init mac8390_ident(struct nubus_dev *dev)
case NUBUS_DRSW_TECHWORKS: case NUBUS_DRSW_TECHWORKS:
case NUBUS_DRSW_DAYNA2: case NUBUS_DRSW_DAYNA2:
case NUBUS_DRSW_DAYNA_LC: case NUBUS_DRSW_DAYNA_LC:
if (dev->dr_hw == NUBUS_DRHW_CABLETRON) if (fres->dr_hw == NUBUS_DRHW_CABLETRON)
return MAC8390_CABLETRON; return MAC8390_CABLETRON;
else else
return MAC8390_APPLE; return MAC8390_APPLE;
...@@ -212,7 +213,7 @@ static enum mac8390_type __init mac8390_ident(struct nubus_dev *dev) ...@@ -212,7 +213,7 @@ static enum mac8390_type __init mac8390_ident(struct nubus_dev *dev)
break; break;
case NUBUS_DRSW_KINETICS: case NUBUS_DRSW_KINETICS:
switch (dev->dr_hw) { switch (fres->dr_hw) {
case NUBUS_DRHW_INTERLAN: case NUBUS_DRHW_INTERLAN:
return MAC8390_INTERLAN; return MAC8390_INTERLAN;
default: default:
...@@ -225,8 +226,8 @@ static enum mac8390_type __init mac8390_ident(struct nubus_dev *dev) ...@@ -225,8 +226,8 @@ static enum mac8390_type __init mac8390_ident(struct nubus_dev *dev)
* These correspond to Dayna Sonic cards * These correspond to Dayna Sonic cards
* which use the macsonic driver * which use the macsonic driver
*/ */
if (dev->dr_hw == NUBUS_DRHW_SMC9194 || if (fres->dr_hw == NUBUS_DRHW_SMC9194 ||
dev->dr_hw == NUBUS_DRHW_INTERLAN) fres->dr_hw == NUBUS_DRHW_INTERLAN)
return MAC8390_NONE; return MAC8390_NONE;
else else
return MAC8390_DAYNA; return MAC8390_DAYNA;
...@@ -289,7 +290,8 @@ static int __init mac8390_memsize(unsigned long membase) ...@@ -289,7 +290,8 @@ static int __init mac8390_memsize(unsigned long membase)
return i * 0x1000; return i * 0x1000;
} }
static bool __init mac8390_init(struct net_device *dev, struct nubus_dev *ndev, static bool __init mac8390_init(struct net_device *dev,
struct nubus_rsrc *ndev,
enum mac8390_type cardtype) enum mac8390_type cardtype)
{ {
struct nubus_dir dir; struct nubus_dir dir;
...@@ -394,7 +396,7 @@ static bool __init mac8390_init(struct net_device *dev, struct nubus_dev *ndev, ...@@ -394,7 +396,7 @@ static bool __init mac8390_init(struct net_device *dev, struct nubus_dev *ndev,
struct net_device * __init mac8390_probe(int unit) struct net_device * __init mac8390_probe(int unit)
{ {
struct net_device *dev; struct net_device *dev;
struct nubus_dev *ndev = NULL; struct nubus_rsrc *ndev = NULL;
int err = -ENODEV; int err = -ENODEV;
struct ei_device *ei_local; struct ei_device *ei_local;
...@@ -414,8 +416,11 @@ struct net_device * __init mac8390_probe(int unit) ...@@ -414,8 +416,11 @@ struct net_device * __init mac8390_probe(int unit)
if (unit >= 0) if (unit >= 0)
sprintf(dev->name, "eth%d", unit); sprintf(dev->name, "eth%d", unit);
while ((ndev = nubus_find_type(NUBUS_CAT_NETWORK, NUBUS_TYPE_ETHERNET, for_each_func_rsrc(ndev) {
ndev))) { if (ndev->category != NUBUS_CAT_NETWORK ||
ndev->type != NUBUS_TYPE_ETHERNET)
continue;
/* Have we seen it already? */ /* Have we seen it already? */
if (slots & (1 << ndev->board->slot)) if (slots & (1 << ndev->board->slot))
continue; continue;
...@@ -489,7 +494,7 @@ static const struct net_device_ops mac8390_netdev_ops = { ...@@ -489,7 +494,7 @@ static const struct net_device_ops mac8390_netdev_ops = {
}; };
static int __init mac8390_initdev(struct net_device *dev, static int __init mac8390_initdev(struct net_device *dev,
struct nubus_dev *ndev, struct nubus_rsrc *ndev,
enum mac8390_type type) enum mac8390_type type)
{ {
static u32 fwrd4_offsets[16] = { static u32 fwrd4_offsets[16] = {
......
...@@ -187,6 +187,7 @@ struct net_device * __init mac89x0_probe(int unit) ...@@ -187,6 +187,7 @@ struct net_device * __init mac89x0_probe(int unit)
unsigned long ioaddr; unsigned long ioaddr;
unsigned short sig; unsigned short sig;
int err = -ENODEV; int err = -ENODEV;
struct nubus_rsrc *fres;
if (!MACH_IS_MAC) if (!MACH_IS_MAC)
return ERR_PTR(-ENODEV); return ERR_PTR(-ENODEV);
...@@ -207,8 +208,9 @@ struct net_device * __init mac89x0_probe(int unit) ...@@ -207,8 +208,9 @@ struct net_device * __init mac89x0_probe(int unit)
/* We might have to parameterize this later */ /* We might have to parameterize this later */
slot = 0xE; slot = 0xE;
/* Get out now if there's a real NuBus card in slot E */ /* Get out now if there's a real NuBus card in slot E */
if (nubus_find_slot(slot, NULL) != NULL) for_each_func_rsrc(fres)
goto out; if (fres->board->slot == slot)
goto out;
/* The pseudo-ISA bits always live at offset 0x300 (gee, /* The pseudo-ISA bits always live at offset 0x300 (gee,
wonder why...) */ wonder why...) */
......
...@@ -311,7 +311,7 @@ static int mac_onboard_sonic_probe(struct net_device *dev) ...@@ -311,7 +311,7 @@ static int mac_onboard_sonic_probe(struct net_device *dev)
{ {
struct sonic_local* lp = netdev_priv(dev); struct sonic_local* lp = netdev_priv(dev);
int sr; int sr;
int commslot = 0; bool commslot = macintosh_config->expansion_type == MAC_EXP_PDS_COMM;
if (!MACH_IS_MAC) if (!MACH_IS_MAC)
return -ENODEV; return -ENODEV;
...@@ -322,10 +322,7 @@ static int mac_onboard_sonic_probe(struct net_device *dev) ...@@ -322,10 +322,7 @@ static int mac_onboard_sonic_probe(struct net_device *dev)
Ethernet (BTW, the Ethernet *is* always at the same Ethernet (BTW, the Ethernet *is* always at the same
address, and nothing else lives there, at least if Apple's address, and nothing else lives there, at least if Apple's
documentation is to be believed) */ documentation is to be believed) */
if (macintosh_config->ident == MAC_MODEL_Q630 || if (commslot || macintosh_config->ident == MAC_MODEL_C610) {
macintosh_config->ident == MAC_MODEL_P588 ||
macintosh_config->ident == MAC_MODEL_P575 ||
macintosh_config->ident == MAC_MODEL_C610) {
int card_present; int card_present;
card_present = hwreg_present((void*)ONBOARD_SONIC_REGISTERS); card_present = hwreg_present((void*)ONBOARD_SONIC_REGISTERS);
...@@ -333,7 +330,6 @@ static int mac_onboard_sonic_probe(struct net_device *dev) ...@@ -333,7 +330,6 @@ static int mac_onboard_sonic_probe(struct net_device *dev)
printk("none.\n"); printk("none.\n");
return -ENODEV; return -ENODEV;
} }
commslot = 1;
} }
printk("yes\n"); printk("yes\n");
...@@ -428,26 +424,26 @@ static int mac_nubus_sonic_ethernet_addr(struct net_device *dev, ...@@ -428,26 +424,26 @@ static int mac_nubus_sonic_ethernet_addr(struct net_device *dev,
return 0; return 0;
} }
static int macsonic_ident(struct nubus_dev *ndev) static int macsonic_ident(struct nubus_rsrc *fres)
{ {
if (ndev->dr_hw == NUBUS_DRHW_ASANTE_LC && if (fres->dr_hw == NUBUS_DRHW_ASANTE_LC &&
ndev->dr_sw == NUBUS_DRSW_SONIC_LC) fres->dr_sw == NUBUS_DRSW_SONIC_LC)
return MACSONIC_DAYNALINK; return MACSONIC_DAYNALINK;
if (ndev->dr_hw == NUBUS_DRHW_SONIC && if (fres->dr_hw == NUBUS_DRHW_SONIC &&
ndev->dr_sw == NUBUS_DRSW_APPLE) { fres->dr_sw == NUBUS_DRSW_APPLE) {
/* There has to be a better way to do this... */ /* There has to be a better way to do this... */
if (strstr(ndev->board->name, "DuoDock")) if (strstr(fres->board->name, "DuoDock"))
return MACSONIC_DUODOCK; return MACSONIC_DUODOCK;
else else
return MACSONIC_APPLE; return MACSONIC_APPLE;
} }
if (ndev->dr_hw == NUBUS_DRHW_SMC9194 && if (fres->dr_hw == NUBUS_DRHW_SMC9194 &&
ndev->dr_sw == NUBUS_DRSW_DAYNA) fres->dr_sw == NUBUS_DRSW_DAYNA)
return MACSONIC_DAYNA; return MACSONIC_DAYNA;
if (ndev->dr_hw == NUBUS_DRHW_APPLE_SONIC_LC && if (fres->dr_hw == NUBUS_DRHW_APPLE_SONIC_LC &&
ndev->dr_sw == 0) { /* huh? */ fres->dr_sw == 0) { /* huh? */
return MACSONIC_APPLE16; return MACSONIC_APPLE16;
} }
return -1; return -1;
...@@ -456,7 +452,7 @@ static int macsonic_ident(struct nubus_dev *ndev) ...@@ -456,7 +452,7 @@ static int macsonic_ident(struct nubus_dev *ndev)
static int mac_nubus_sonic_probe(struct net_device *dev) static int mac_nubus_sonic_probe(struct net_device *dev)
{ {
static int slots; static int slots;
struct nubus_dev* ndev = NULL; struct nubus_rsrc *ndev = NULL;
struct sonic_local* lp = netdev_priv(dev); struct sonic_local* lp = netdev_priv(dev);
unsigned long base_addr, prom_addr; unsigned long base_addr, prom_addr;
u16 sonic_dcr; u16 sonic_dcr;
...@@ -464,9 +460,11 @@ static int mac_nubus_sonic_probe(struct net_device *dev) ...@@ -464,9 +460,11 @@ static int mac_nubus_sonic_probe(struct net_device *dev)
int reg_offset, dma_bitmode; int reg_offset, dma_bitmode;
/* Find the first SONIC that hasn't been initialized already */ /* Find the first SONIC that hasn't been initialized already */
while ((ndev = nubus_find_type(NUBUS_CAT_NETWORK, for_each_func_rsrc(ndev) {
NUBUS_TYPE_ETHERNET, ndev)) != NULL) if (ndev->category != NUBUS_CAT_NETWORK ||
{ ndev->type != NUBUS_TYPE_ETHERNET)
continue;
/* Have we seen it already? */ /* Have we seen it already? */
if (slots & (1<<ndev->board->slot)) if (slots & (1<<ndev->board->slot))
continue; continue;
......
...@@ -2,6 +2,6 @@ ...@@ -2,6 +2,6 @@
# Makefile for the nubus specific drivers. # Makefile for the nubus specific drivers.
# #
obj-y := nubus.o obj-y := nubus.o bus.o
obj-$(CONFIG_PROC_FS) += proc.o obj-$(CONFIG_PROC_FS) += proc.o
// SPDX-License-Identifier: GPL-2.0
//
// Bus implementation for the NuBus subsystem.
//
// Copyright (C) 2017 Finn Thain
#include <linux/device.h>
#include <linux/list.h>
#include <linux/nubus.h>
#include <linux/seq_file.h>
#include <linux/slab.h>
#define to_nubus_board(d) container_of(d, struct nubus_board, dev)
#define to_nubus_driver(d) container_of(d, struct nubus_driver, driver)
static int nubus_bus_match(struct device *dev, struct device_driver *driver)
{
return 1;
}
static int nubus_device_probe(struct device *dev)
{
struct nubus_driver *ndrv = to_nubus_driver(dev->driver);
int err = -ENODEV;
if (ndrv->probe)
err = ndrv->probe(to_nubus_board(dev));
return err;
}
static int nubus_device_remove(struct device *dev)
{
struct nubus_driver *ndrv = to_nubus_driver(dev->driver);
int err = -ENODEV;
if (dev->driver && ndrv->remove)
err = ndrv->remove(to_nubus_board(dev));
return err;
}
struct bus_type nubus_bus_type = {
.name = "nubus",
.match = nubus_bus_match,
.probe = nubus_device_probe,
.remove = nubus_device_remove,
};
EXPORT_SYMBOL(nubus_bus_type);
int nubus_driver_register(struct nubus_driver *ndrv)
{
ndrv->driver.bus = &nubus_bus_type;
return driver_register(&ndrv->driver);
}
EXPORT_SYMBOL(nubus_driver_register);
void nubus_driver_unregister(struct nubus_driver *ndrv)
{
driver_unregister(&ndrv->driver);
}
EXPORT_SYMBOL(nubus_driver_unregister);
static struct device nubus_parent = {
.init_name = "nubus",
};
int __init nubus_bus_register(void)
{
int err;
err = device_register(&nubus_parent);
if (err)
return err;
err = bus_register(&nubus_bus_type);
if (!err)
return 0;
device_unregister(&nubus_parent);
return err;
}
static void nubus_device_release(struct device *dev)
{
struct nubus_board *board = to_nubus_board(dev);
struct nubus_rsrc *fres, *tmp;
list_for_each_entry_safe(fres, tmp, &nubus_func_rsrcs, list)
if (fres->board == board) {
list_del(&fres->list);
kfree(fres);
}
kfree(board);
}
int nubus_device_register(struct nubus_board *board)
{
board->dev.parent = &nubus_parent;
board->dev.release = nubus_device_release;
board->dev.bus = &nubus_bus_type;
dev_set_name(&board->dev, "slot.%X", board->slot);
return device_register(&board->dev);
}
static int nubus_print_device_name_fn(struct device *dev, void *data)
{
struct nubus_board *board = to_nubus_board(dev);
struct seq_file *m = data;
seq_printf(m, "Slot %X: %s\n", board->slot, board->name);
return 0;
}
int nubus_proc_show(struct seq_file *m, void *data)
{
return bus_for_each_dev(&nubus_bus_type, NULL, m,
nubus_print_device_name_fn);
}
...@@ -15,6 +15,7 @@ ...@@ -15,6 +15,7 @@
#include <linux/errno.h> #include <linux/errno.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/seq_file.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <asm/setup.h> #include <asm/setup.h>
#include <asm/page.h> #include <asm/page.h>
...@@ -31,8 +32,7 @@ ...@@ -31,8 +32,7 @@
/* Globals */ /* Globals */
struct nubus_dev *nubus_devices; LIST_HEAD(nubus_func_rsrcs);
struct nubus_board *nubus_boards;
/* Meaning of "bytelanes": /* Meaning of "bytelanes":
...@@ -146,7 +146,7 @@ static inline void *nubus_rom_addr(int slot) ...@@ -146,7 +146,7 @@ static inline void *nubus_rom_addr(int slot)
return (void *)(0xF1000000 + (slot << 24)); return (void *)(0xF1000000 + (slot << 24));
} }
static unsigned char *nubus_dirptr(const struct nubus_dirent *nd) unsigned char *nubus_dirptr(const struct nubus_dirent *nd)
{ {
unsigned char *p = nd->base; unsigned char *p = nd->base;
...@@ -161,7 +161,7 @@ static unsigned char *nubus_dirptr(const struct nubus_dirent *nd) ...@@ -161,7 +161,7 @@ static unsigned char *nubus_dirptr(const struct nubus_dirent *nd)
pointed to with offsets) out of the card ROM. */ pointed to with offsets) out of the card ROM. */
void nubus_get_rsrc_mem(void *dest, const struct nubus_dirent *dirent, void nubus_get_rsrc_mem(void *dest, const struct nubus_dirent *dirent,
int len) unsigned int len)
{ {
unsigned char *t = (unsigned char *)dest; unsigned char *t = (unsigned char *)dest;
unsigned char *p = nubus_dirptr(dirent); unsigned char *p = nubus_dirptr(dirent);
...@@ -173,21 +173,49 @@ void nubus_get_rsrc_mem(void *dest, const struct nubus_dirent *dirent, ...@@ -173,21 +173,49 @@ void nubus_get_rsrc_mem(void *dest, const struct nubus_dirent *dirent,
} }
EXPORT_SYMBOL(nubus_get_rsrc_mem); EXPORT_SYMBOL(nubus_get_rsrc_mem);
void nubus_get_rsrc_str(void *dest, const struct nubus_dirent *dirent, unsigned int nubus_get_rsrc_str(char *dest, const struct nubus_dirent *dirent,
int len) unsigned int len)
{ {
unsigned char *t = (unsigned char *)dest; char *t = dest;
unsigned char *p = nubus_dirptr(dirent); unsigned char *p = nubus_dirptr(dirent);
while (len) { while (len > 1) {
*t = nubus_get_rom(&p, 1, dirent->mask); unsigned char c = nubus_get_rom(&p, 1, dirent->mask);
if (!*t++)
if (!c)
break; break;
*t++ = c;
len--; len--;
} }
if (len > 0)
*t = '\0';
return t - dest;
} }
EXPORT_SYMBOL(nubus_get_rsrc_str); EXPORT_SYMBOL(nubus_get_rsrc_str);
void nubus_seq_write_rsrc_mem(struct seq_file *m,
const struct nubus_dirent *dirent,
unsigned int len)
{
unsigned long buf[32];
unsigned int buf_size = sizeof(buf);
unsigned char *p = nubus_dirptr(dirent);
/* If possible, write out full buffers */
while (len >= buf_size) {
unsigned int i;
for (i = 0; i < ARRAY_SIZE(buf); i++)
buf[i] = nubus_get_rom(&p, sizeof(buf[0]),
dirent->mask);
seq_write(m, buf, buf_size);
len -= buf_size;
}
/* If not, write out individual bytes */
while (len--)
seq_putc(m, nubus_get_rom(&p, 1, dirent->mask));
}
int nubus_get_root_dir(const struct nubus_board *board, int nubus_get_root_dir(const struct nubus_board *board,
struct nubus_dir *dir) struct nubus_dir *dir)
{ {
...@@ -199,12 +227,11 @@ int nubus_get_root_dir(const struct nubus_board *board, ...@@ -199,12 +227,11 @@ int nubus_get_root_dir(const struct nubus_board *board,
EXPORT_SYMBOL(nubus_get_root_dir); EXPORT_SYMBOL(nubus_get_root_dir);
/* This is a slyly renamed version of the above */ /* This is a slyly renamed version of the above */
int nubus_get_func_dir(const struct nubus_dev *dev, int nubus_get_func_dir(const struct nubus_rsrc *fres, struct nubus_dir *dir)
struct nubus_dir *dir)
{ {
dir->ptr = dir->base = dev->directory; dir->ptr = dir->base = fres->directory;
dir->done = 0; dir->done = 0;
dir->mask = dev->board->lanes; dir->mask = fres->board->lanes;
return 0; return 0;
} }
EXPORT_SYMBOL(nubus_get_func_dir); EXPORT_SYMBOL(nubus_get_func_dir);
...@@ -277,51 +304,20 @@ EXPORT_SYMBOL(nubus_rewinddir); ...@@ -277,51 +304,20 @@ EXPORT_SYMBOL(nubus_rewinddir);
/* Driver interface functions, more or less like in pci.c */ /* Driver interface functions, more or less like in pci.c */
struct nubus_dev* struct nubus_rsrc *nubus_first_rsrc_or_null(void)
nubus_find_device(unsigned short category, unsigned short type,
unsigned short dr_hw, unsigned short dr_sw,
const struct nubus_dev *from)
{
struct nubus_dev *itor = from ? from->next : nubus_devices;
while (itor) {
if (itor->category == category && itor->type == type &&
itor->dr_hw == dr_hw && itor->dr_sw == dr_sw)
return itor;
itor = itor->next;
}
return NULL;
}
EXPORT_SYMBOL(nubus_find_device);
struct nubus_dev*
nubus_find_type(unsigned short category, unsigned short type,
const struct nubus_dev *from)
{ {
struct nubus_dev *itor = from ? from->next : nubus_devices; return list_first_entry_or_null(&nubus_func_rsrcs, struct nubus_rsrc,
list);
while (itor) {
if (itor->category == category && itor->type == type)
return itor;
itor = itor->next;
}
return NULL;
} }
EXPORT_SYMBOL(nubus_find_type); EXPORT_SYMBOL(nubus_first_rsrc_or_null);
struct nubus_dev* struct nubus_rsrc *nubus_next_rsrc_or_null(struct nubus_rsrc *from)
nubus_find_slot(unsigned int slot, const struct nubus_dev *from)
{ {
struct nubus_dev *itor = from ? from->next : nubus_devices; if (list_is_last(&from->list, &nubus_func_rsrcs))
return NULL;
while (itor) { return list_next_entry(from, list);
if (itor->board->slot == slot)
return itor;
itor = itor->next;
}
return NULL;
} }
EXPORT_SYMBOL(nubus_find_slot); EXPORT_SYMBOL(nubus_next_rsrc_or_null);
int int
nubus_find_rsrc(struct nubus_dir *dir, unsigned char rsrc_type, nubus_find_rsrc(struct nubus_dir *dir, unsigned char rsrc_type,
...@@ -339,31 +335,83 @@ EXPORT_SYMBOL(nubus_find_rsrc); ...@@ -339,31 +335,83 @@ EXPORT_SYMBOL(nubus_find_rsrc);
looking at, and print out lots and lots of information from the looking at, and print out lots and lots of information from the
resource blocks. */ resource blocks. */
/* FIXME: A lot of this stuff will eventually be useful after static int __init nubus_get_block_rsrc_dir(struct nubus_board *board,
initialization, for intelligently probing Ethernet and video chips, struct proc_dir_entry *procdir,
among other things. The rest of it should go in the /proc code. const struct nubus_dirent *parent)
For now, we just use it to give verbose boot logs. */ {
struct nubus_dir dir;
struct nubus_dirent ent;
nubus_get_subdir(parent, &dir);
dir.procdir = nubus_proc_add_rsrc_dir(procdir, parent, board);
static int __init nubus_show_display_resource(struct nubus_dev *dev, while (nubus_readdir(&dir, &ent) != -1) {
const struct nubus_dirent *ent) u32 size;
nubus_get_rsrc_mem(&size, &ent, 4);
pr_debug(" block (0x%x), size %d\n", ent.type, size);
nubus_proc_add_rsrc_mem(dir.procdir, &ent, size);
}
return 0;
}
static int __init nubus_get_display_vidmode(struct nubus_board *board,
struct proc_dir_entry *procdir,
const struct nubus_dirent *parent)
{
struct nubus_dir dir;
struct nubus_dirent ent;
nubus_get_subdir(parent, &dir);
dir.procdir = nubus_proc_add_rsrc_dir(procdir, parent, board);
while (nubus_readdir(&dir, &ent) != -1) {
switch (ent.type) {
case 1: /* mVidParams */
case 2: /* mTable */
{
u32 size;
nubus_get_rsrc_mem(&size, &ent, 4);
pr_debug(" block (0x%x), size %d\n", ent.type,
size);
nubus_proc_add_rsrc_mem(dir.procdir, &ent, size);
break;
}
default:
pr_debug(" unknown resource 0x%02x, data 0x%06x\n",
ent.type, ent.data);
nubus_proc_add_rsrc_mem(dir.procdir, &ent, 0);
}
}
return 0;
}
static int __init nubus_get_display_resource(struct nubus_rsrc *fres,
struct proc_dir_entry *procdir,
const struct nubus_dirent *ent)
{ {
switch (ent->type) { switch (ent->type) {
case NUBUS_RESID_GAMMADIR: case NUBUS_RESID_GAMMADIR:
pr_info(" gamma directory offset: 0x%06x\n", ent->data); pr_debug(" gamma directory offset: 0x%06x\n", ent->data);
nubus_get_block_rsrc_dir(fres->board, procdir, ent);
break; break;
case 0x0080 ... 0x0085: case 0x0080 ... 0x0085:
pr_info(" mode %02X info offset: 0x%06x\n", pr_debug(" mode 0x%02x info offset: 0x%06x\n",
ent->type, ent->data); ent->type, ent->data);
nubus_get_display_vidmode(fres->board, procdir, ent);
break; break;
default: default:
pr_info(" unknown resource %02X, data 0x%06x\n", pr_debug(" unknown resource 0x%02x, data 0x%06x\n",
ent->type, ent->data); ent->type, ent->data);
nubus_proc_add_rsrc_mem(procdir, ent, 0);
} }
return 0; return 0;
} }
static int __init nubus_show_network_resource(struct nubus_dev *dev, static int __init nubus_get_network_resource(struct nubus_rsrc *fres,
const struct nubus_dirent *ent) struct proc_dir_entry *procdir,
const struct nubus_dirent *ent)
{ {
switch (ent->type) { switch (ent->type) {
case NUBUS_RESID_MAC_ADDRESS: case NUBUS_RESID_MAC_ADDRESS:
...@@ -371,18 +419,21 @@ static int __init nubus_show_network_resource(struct nubus_dev *dev, ...@@ -371,18 +419,21 @@ static int __init nubus_show_network_resource(struct nubus_dev *dev,
char addr[6]; char addr[6];
nubus_get_rsrc_mem(addr, ent, 6); nubus_get_rsrc_mem(addr, ent, 6);
pr_info(" MAC address: %pM\n", addr); pr_debug(" MAC address: %pM\n", addr);
nubus_proc_add_rsrc_mem(procdir, ent, 6);
break; break;
} }
default: default:
pr_info(" unknown resource %02X, data 0x%06x\n", pr_debug(" unknown resource 0x%02x, data 0x%06x\n",
ent->type, ent->data); ent->type, ent->data);
nubus_proc_add_rsrc_mem(procdir, ent, 0);
} }
return 0; return 0;
} }
static int __init nubus_show_cpu_resource(struct nubus_dev *dev, static int __init nubus_get_cpu_resource(struct nubus_rsrc *fres,
const struct nubus_dirent *ent) struct proc_dir_entry *procdir,
const struct nubus_dirent *ent)
{ {
switch (ent->type) { switch (ent->type) {
case NUBUS_RESID_MEMINFO: case NUBUS_RESID_MEMINFO:
...@@ -390,8 +441,9 @@ static int __init nubus_show_cpu_resource(struct nubus_dev *dev, ...@@ -390,8 +441,9 @@ static int __init nubus_show_cpu_resource(struct nubus_dev *dev,
unsigned long meminfo[2]; unsigned long meminfo[2];
nubus_get_rsrc_mem(&meminfo, ent, 8); nubus_get_rsrc_mem(&meminfo, ent, 8);
pr_info(" memory: [ 0x%08lx 0x%08lx ]\n", pr_debug(" memory: [ 0x%08lx 0x%08lx ]\n",
meminfo[0], meminfo[1]); meminfo[0], meminfo[1]);
nubus_proc_add_rsrc_mem(procdir, ent, 8);
break; break;
} }
case NUBUS_RESID_ROMINFO: case NUBUS_RESID_ROMINFO:
...@@ -399,57 +451,60 @@ static int __init nubus_show_cpu_resource(struct nubus_dev *dev, ...@@ -399,57 +451,60 @@ static int __init nubus_show_cpu_resource(struct nubus_dev *dev,
unsigned long rominfo[2]; unsigned long rominfo[2];
nubus_get_rsrc_mem(&rominfo, ent, 8); nubus_get_rsrc_mem(&rominfo, ent, 8);
pr_info(" ROM: [ 0x%08lx 0x%08lx ]\n", pr_debug(" ROM: [ 0x%08lx 0x%08lx ]\n",
rominfo[0], rominfo[1]); rominfo[0], rominfo[1]);
nubus_proc_add_rsrc_mem(procdir, ent, 8);
break; break;
} }
default: default:
pr_info(" unknown resource %02X, data 0x%06x\n", pr_debug(" unknown resource 0x%02x, data 0x%06x\n",
ent->type, ent->data); ent->type, ent->data);
nubus_proc_add_rsrc_mem(procdir, ent, 0);
} }
return 0; return 0;
} }
static int __init nubus_show_private_resource(struct nubus_dev *dev, static int __init nubus_get_private_resource(struct nubus_rsrc *fres,
const struct nubus_dirent *ent) struct proc_dir_entry *procdir,
const struct nubus_dirent *ent)
{ {
switch (dev->category) { switch (fres->category) {
case NUBUS_CAT_DISPLAY: case NUBUS_CAT_DISPLAY:
nubus_show_display_resource(dev, ent); nubus_get_display_resource(fres, procdir, ent);
break; break;
case NUBUS_CAT_NETWORK: case NUBUS_CAT_NETWORK:
nubus_show_network_resource(dev, ent); nubus_get_network_resource(fres, procdir, ent);
break; break;
case NUBUS_CAT_CPU: case NUBUS_CAT_CPU:
nubus_show_cpu_resource(dev, ent); nubus_get_cpu_resource(fres, procdir, ent);
break; break;
default: default:
pr_info(" unknown resource %02X, data 0x%06x\n", pr_debug(" unknown resource 0x%02x, data 0x%06x\n",
ent->type, ent->data); ent->type, ent->data);
nubus_proc_add_rsrc_mem(procdir, ent, 0);
} }
return 0; return 0;
} }
static struct nubus_dev * __init static struct nubus_rsrc * __init
nubus_get_functional_resource(struct nubus_board *board, int slot, nubus_get_functional_resource(struct nubus_board *board, int slot,
const struct nubus_dirent *parent) const struct nubus_dirent *parent)
{ {
struct nubus_dir dir; struct nubus_dir dir;
struct nubus_dirent ent; struct nubus_dirent ent;
struct nubus_dev *dev; struct nubus_rsrc *fres;
pr_info(" Function 0x%02x:\n", parent->type); pr_debug(" Functional resource 0x%02x:\n", parent->type);
nubus_get_subdir(parent, &dir); nubus_get_subdir(parent, &dir);
dir.procdir = nubus_proc_add_rsrc_dir(board->procdir, parent, board);
pr_debug("%s: parent is 0x%p, dir is 0x%p\n",
__func__, parent->base, dir.base);
/* Actually we should probably panic if this fails */ /* Actually we should probably panic if this fails */
if ((dev = kzalloc(sizeof(*dev), GFP_ATOMIC)) == NULL) fres = kzalloc(sizeof(*fres), GFP_ATOMIC);
if (!fres)
return NULL; return NULL;
dev->resid = parent->type; fres->resid = parent->type;
dev->directory = dir.base; fres->directory = dir.base;
dev->board = board; fres->board = board;
while (nubus_readdir(&dir, &ent) != -1) { while (nubus_readdir(&dir, &ent) != -1) {
switch (ent.type) { switch (ent.type) {
...@@ -458,130 +513,96 @@ nubus_get_functional_resource(struct nubus_board *board, int slot, ...@@ -458,130 +513,96 @@ nubus_get_functional_resource(struct nubus_board *board, int slot,
unsigned short nbtdata[4]; unsigned short nbtdata[4];
nubus_get_rsrc_mem(nbtdata, &ent, 8); nubus_get_rsrc_mem(nbtdata, &ent, 8);
dev->category = nbtdata[0]; fres->category = nbtdata[0];
dev->type = nbtdata[1]; fres->type = nbtdata[1];
dev->dr_sw = nbtdata[2]; fres->dr_sw = nbtdata[2];
dev->dr_hw = nbtdata[3]; fres->dr_hw = nbtdata[3];
pr_info(" type: [cat 0x%x type 0x%x sw 0x%x hw 0x%x]\n", pr_debug(" type: [cat 0x%x type 0x%x sw 0x%x hw 0x%x]\n",
nbtdata[0], nbtdata[1], nbtdata[2], nbtdata[3]); nbtdata[0], nbtdata[1], nbtdata[2], nbtdata[3]);
nubus_proc_add_rsrc_mem(dir.procdir, &ent, 8);
break; break;
} }
case NUBUS_RESID_NAME: case NUBUS_RESID_NAME:
{ {
nubus_get_rsrc_str(dev->name, &ent, 64); char name[64];
pr_info(" name: %s\n", dev->name); unsigned int len;
len = nubus_get_rsrc_str(name, &ent, sizeof(name));
pr_debug(" name: %s\n", name);
nubus_proc_add_rsrc_mem(dir.procdir, &ent, len + 1);
break; break;
} }
case NUBUS_RESID_DRVRDIR: case NUBUS_RESID_DRVRDIR:
{ {
/* MacOS driver. If we were NetBSD we might /* MacOS driver. If we were NetBSD we might
use this :-) */ use this :-) */
struct nubus_dir drvr_dir; pr_debug(" driver directory offset: 0x%06x\n",
struct nubus_dirent drvr_ent; ent.data);
nubus_get_block_rsrc_dir(board, dir.procdir, &ent);
nubus_get_subdir(&ent, &drvr_dir);
nubus_readdir(&drvr_dir, &drvr_ent);
dev->driver = nubus_dirptr(&drvr_ent);
pr_info(" driver at: 0x%p\n", dev->driver);
break; break;
} }
case NUBUS_RESID_MINOR_BASEOS: case NUBUS_RESID_MINOR_BASEOS:
{
/* We will need this in order to support /* We will need this in order to support
multiple framebuffers. It might be handy multiple framebuffers. It might be handy
for Ethernet as well */ for Ethernet as well */
nubus_get_rsrc_mem(&dev->iobase, &ent, 4); u32 base_offset;
pr_info(" memory offset: 0x%08lx\n", dev->iobase);
nubus_get_rsrc_mem(&base_offset, &ent, 4);
pr_debug(" memory offset: 0x%08x\n", base_offset);
nubus_proc_add_rsrc_mem(dir.procdir, &ent, 4);
break; break;
}
case NUBUS_RESID_MINOR_LENGTH: case NUBUS_RESID_MINOR_LENGTH:
{
/* Ditto */ /* Ditto */
nubus_get_rsrc_mem(&dev->iosize, &ent, 4); u32 length;
pr_info(" memory length: 0x%08lx\n", dev->iosize);
nubus_get_rsrc_mem(&length, &ent, 4);
pr_debug(" memory length: 0x%08x\n", length);
nubus_proc_add_rsrc_mem(dir.procdir, &ent, 4);
break; break;
}
case NUBUS_RESID_FLAGS: case NUBUS_RESID_FLAGS:
dev->flags = ent.data; pr_debug(" flags: 0x%06x\n", ent.data);
pr_info(" flags: 0x%06x\n", dev->flags); nubus_proc_add_rsrc(dir.procdir, &ent);
break; break;
case NUBUS_RESID_HWDEVID: case NUBUS_RESID_HWDEVID:
dev->hwdevid = ent.data; pr_debug(" hwdevid: 0x%06x\n", ent.data);
pr_info(" hwdevid: 0x%06x\n", dev->hwdevid); nubus_proc_add_rsrc(dir.procdir, &ent);
break; break;
default: default:
/* Local/Private resources have their own /* Local/Private resources have their own
function */ function */
nubus_show_private_resource(dev, &ent); nubus_get_private_resource(fres, dir.procdir, &ent);
} }
} }
return dev; return fres;
}
/* This is cool. */
static int __init nubus_get_vidnames(struct nubus_board *board,
const struct nubus_dirent *parent)
{
struct nubus_dir dir;
struct nubus_dirent ent;
/* FIXME: obviously we want to put this in a header file soon */
struct vidmode {
u32 size;
/* Don't know what this is yet */
u16 id;
/* Longest one I've seen so far is 26 characters */
char name[32];
};
pr_info(" video modes supported:\n");
nubus_get_subdir(parent, &dir);
pr_debug("%s: parent is 0x%p, dir is 0x%p\n",
__func__, parent->base, dir.base);
while (nubus_readdir(&dir, &ent) != -1) {
struct vidmode mode;
u32 size;
/* First get the length */
nubus_get_rsrc_mem(&size, &ent, 4);
/* Now clobber the whole thing */
if (size > sizeof(mode) - 1)
size = sizeof(mode) - 1;
memset(&mode, 0, sizeof(mode));
nubus_get_rsrc_mem(&mode, &ent, size);
pr_info(" %02X: (%02X) %s\n", ent.type,
mode.id, mode.name);
}
return 0;
} }
/* This is *really* cool. */ /* This is *really* cool. */
static int __init nubus_get_icon(struct nubus_board *board, static int __init nubus_get_icon(struct nubus_board *board,
struct proc_dir_entry *procdir,
const struct nubus_dirent *ent) const struct nubus_dirent *ent)
{ {
/* Should be 32x32 if my memory serves me correctly */ /* Should be 32x32 if my memory serves me correctly */
unsigned char icon[128]; u32 icon[32];
int x, y; int i;
nubus_get_rsrc_mem(&icon, ent, 128); nubus_get_rsrc_mem(&icon, ent, 128);
pr_info(" icon:\n"); pr_debug(" icon:\n");
for (i = 0; i < 8; i++)
/* We should actually plot these somewhere in the framebuffer pr_debug(" %08x %08x %08x %08x\n",
init. This is just to demonstrate that they do, in fact, icon[i * 4 + 0], icon[i * 4 + 1],
exist */ icon[i * 4 + 2], icon[i * 4 + 3]);
for (y = 0; y < 32; y++) { nubus_proc_add_rsrc_mem(procdir, ent, 128);
pr_info(" ");
for (x = 0; x < 32; x++) {
if (icon[y * 4 + x / 8] & (0x80 >> (x % 8)))
pr_cont("*");
else
pr_cont(" ");
}
pr_cont("\n");
}
return 0; return 0;
} }
static int __init nubus_get_vendorinfo(struct nubus_board *board, static int __init nubus_get_vendorinfo(struct nubus_board *board,
struct proc_dir_entry *procdir,
const struct nubus_dirent *parent) const struct nubus_dirent *parent)
{ {
struct nubus_dir dir; struct nubus_dir dir;
...@@ -589,19 +610,20 @@ static int __init nubus_get_vendorinfo(struct nubus_board *board, ...@@ -589,19 +610,20 @@ static int __init nubus_get_vendorinfo(struct nubus_board *board,
static char *vendor_fields[6] = { "ID", "serial", "revision", static char *vendor_fields[6] = { "ID", "serial", "revision",
"part", "date", "unknown field" }; "part", "date", "unknown field" };
pr_info(" vendor info:\n"); pr_debug(" vendor info:\n");
nubus_get_subdir(parent, &dir); nubus_get_subdir(parent, &dir);
pr_debug("%s: parent is 0x%p, dir is 0x%p\n", dir.procdir = nubus_proc_add_rsrc_dir(procdir, parent, board);
__func__, parent->base, dir.base);
while (nubus_readdir(&dir, &ent) != -1) { while (nubus_readdir(&dir, &ent) != -1) {
char name[64]; char name[64];
unsigned int len;
/* These are all strings, we think */ /* These are all strings, we think */
nubus_get_rsrc_str(name, &ent, 64); len = nubus_get_rsrc_str(name, &ent, sizeof(name));
if (ent.type > 5) if (ent.type < 1 || ent.type > 5)
ent.type = 5; ent.type = 5;
pr_info(" %s: %s\n", vendor_fields[ent.type - 1], name); pr_debug(" %s: %s\n", vendor_fields[ent.type - 1], name);
nubus_proc_add_rsrc_mem(dir.procdir, &ent, len + 1);
} }
return 0; return 0;
} }
...@@ -612,9 +634,9 @@ static int __init nubus_get_board_resource(struct nubus_board *board, int slot, ...@@ -612,9 +634,9 @@ static int __init nubus_get_board_resource(struct nubus_board *board, int slot,
struct nubus_dir dir; struct nubus_dir dir;
struct nubus_dirent ent; struct nubus_dirent ent;
pr_debug(" Board resource 0x%02x:\n", parent->type);
nubus_get_subdir(parent, &dir); nubus_get_subdir(parent, &dir);
pr_debug("%s: parent is 0x%p, dir is 0x%p\n", dir.procdir = nubus_proc_add_rsrc_dir(board->procdir, parent, board);
__func__, parent->base, dir.base);
while (nubus_readdir(&dir, &ent) != -1) { while (nubus_readdir(&dir, &ent) != -1) {
switch (ent.type) { switch (ent.type) {
...@@ -625,64 +647,81 @@ static int __init nubus_get_board_resource(struct nubus_board *board, int slot, ...@@ -625,64 +647,81 @@ static int __init nubus_get_board_resource(struct nubus_board *board, int slot,
useful except insofar as it tells us that useful except insofar as it tells us that
we really are looking at a board resource. */ we really are looking at a board resource. */
nubus_get_rsrc_mem(nbtdata, &ent, 8); nubus_get_rsrc_mem(nbtdata, &ent, 8);
pr_info(" type: [cat 0x%x type 0x%x sw 0x%x hw 0x%x]\n", pr_debug(" type: [cat 0x%x type 0x%x sw 0x%x hw 0x%x]\n",
nbtdata[0], nbtdata[1], nbtdata[2], nbtdata[3]); nbtdata[0], nbtdata[1], nbtdata[2], nbtdata[3]);
if (nbtdata[0] != 1 || nbtdata[1] != 0 || if (nbtdata[0] != 1 || nbtdata[1] != 0 ||
nbtdata[2] != 0 || nbtdata[3] != 0) nbtdata[2] != 0 || nbtdata[3] != 0)
pr_err("this sResource is not a board resource!\n"); pr_err("Slot %X: sResource is not a board resource!\n",
slot);
nubus_proc_add_rsrc_mem(dir.procdir, &ent, 8);
break; break;
} }
case NUBUS_RESID_NAME: case NUBUS_RESID_NAME:
nubus_get_rsrc_str(board->name, &ent, 64); {
pr_info(" name: %s\n", board->name); unsigned int len;
len = nubus_get_rsrc_str(board->name, &ent,
sizeof(board->name));
pr_debug(" name: %s\n", board->name);
nubus_proc_add_rsrc_mem(dir.procdir, &ent, len + 1);
break; break;
}
case NUBUS_RESID_ICON: case NUBUS_RESID_ICON:
nubus_get_icon(board, &ent); nubus_get_icon(board, dir.procdir, &ent);
break; break;
case NUBUS_RESID_BOARDID: case NUBUS_RESID_BOARDID:
pr_info(" board id: 0x%x\n", ent.data); pr_debug(" board id: 0x%x\n", ent.data);
nubus_proc_add_rsrc(dir.procdir, &ent);
break; break;
case NUBUS_RESID_PRIMARYINIT: case NUBUS_RESID_PRIMARYINIT:
pr_info(" primary init offset: 0x%06x\n", ent.data); pr_debug(" primary init offset: 0x%06x\n", ent.data);
nubus_proc_add_rsrc(dir.procdir, &ent);
break; break;
case NUBUS_RESID_VENDORINFO: case NUBUS_RESID_VENDORINFO:
nubus_get_vendorinfo(board, &ent); nubus_get_vendorinfo(board, dir.procdir, &ent);
break; break;
case NUBUS_RESID_FLAGS: case NUBUS_RESID_FLAGS:
pr_info(" flags: 0x%06x\n", ent.data); pr_debug(" flags: 0x%06x\n", ent.data);
nubus_proc_add_rsrc(dir.procdir, &ent);
break; break;
case NUBUS_RESID_HWDEVID: case NUBUS_RESID_HWDEVID:
pr_info(" hwdevid: 0x%06x\n", ent.data); pr_debug(" hwdevid: 0x%06x\n", ent.data);
nubus_proc_add_rsrc(dir.procdir, &ent);
break; break;
case NUBUS_RESID_SECONDINIT: case NUBUS_RESID_SECONDINIT:
pr_info(" secondary init offset: 0x%06x\n", ent.data); pr_debug(" secondary init offset: 0x%06x\n",
ent.data);
nubus_proc_add_rsrc(dir.procdir, &ent);
break; break;
/* WTF isn't this in the functional resources? */ /* WTF isn't this in the functional resources? */
case NUBUS_RESID_VIDNAMES: case NUBUS_RESID_VIDNAMES:
nubus_get_vidnames(board, &ent); pr_debug(" vidnames directory offset: 0x%06x\n",
ent.data);
nubus_get_block_rsrc_dir(board, dir.procdir, &ent);
break; break;
/* Same goes for this */ /* Same goes for this */
case NUBUS_RESID_VIDMODES: case NUBUS_RESID_VIDMODES:
pr_info(" video mode parameter directory offset: 0x%06x\n", pr_debug(" video mode parameter directory offset: 0x%06x\n",
ent.data); ent.data);
nubus_proc_add_rsrc(dir.procdir, &ent);
break; break;
default: default:
pr_info(" unknown resource %02X, data 0x%06x\n", pr_debug(" unknown resource 0x%02x, data 0x%06x\n",
ent.type, ent.data); ent.type, ent.data);
nubus_proc_add_rsrc_mem(dir.procdir, &ent, 0);
} }
} }
return 0; return 0;
} }
/* Add a board (might be many devices) to the list */ static void __init nubus_add_board(int slot, int bytelanes)
static struct nubus_board * __init nubus_add_board(int slot, int bytelanes)
{ {
struct nubus_board *board; struct nubus_board *board;
struct nubus_board **boardp;
unsigned char *rp; unsigned char *rp;
unsigned long dpat; unsigned long dpat;
struct nubus_dir dir; struct nubus_dir dir;
struct nubus_dirent ent; struct nubus_dirent ent;
int prev_resid = -1;
/* Move to the start of the format block */ /* Move to the start of the format block */
rp = nubus_rom_addr(slot); rp = nubus_rom_addr(slot);
...@@ -690,19 +729,19 @@ static struct nubus_board * __init nubus_add_board(int slot, int bytelanes) ...@@ -690,19 +729,19 @@ static struct nubus_board * __init nubus_add_board(int slot, int bytelanes)
/* Actually we should probably panic if this fails */ /* Actually we should probably panic if this fails */
if ((board = kzalloc(sizeof(*board), GFP_ATOMIC)) == NULL) if ((board = kzalloc(sizeof(*board), GFP_ATOMIC)) == NULL)
return NULL; return;
board->fblock = rp; board->fblock = rp;
/* Dump the format block for debugging purposes */ /* Dump the format block for debugging purposes */
pr_debug("Slot %X, format block at 0x%p:\n", slot, rp); pr_debug("Slot %X, format block at 0x%p:\n", slot, rp);
pr_debug("%08lx\n", nubus_get_rom(&rp, 4, bytelanes));
pr_debug("%08lx\n", nubus_get_rom(&rp, 4, bytelanes));
pr_debug("%08lx\n", nubus_get_rom(&rp, 4, bytelanes));
pr_debug("%02lx\n", nubus_get_rom(&rp, 1, bytelanes)); pr_debug("%02lx\n", nubus_get_rom(&rp, 1, bytelanes));
pr_debug("%02lx\n", nubus_get_rom(&rp, 1, bytelanes)); pr_debug("%02lx\n", nubus_get_rom(&rp, 1, bytelanes));
pr_debug("%08lx\n", nubus_get_rom(&rp, 4, bytelanes)); pr_debug("%08lx\n", nubus_get_rom(&rp, 4, bytelanes));
pr_debug("%02lx\n", nubus_get_rom(&rp, 1, bytelanes)); pr_debug("%02lx\n", nubus_get_rom(&rp, 1, bytelanes));
pr_debug("%02lx\n", nubus_get_rom(&rp, 1, bytelanes)); pr_debug("%02lx\n", nubus_get_rom(&rp, 1, bytelanes));
pr_debug("%08lx\n", nubus_get_rom(&rp, 4, bytelanes));
pr_debug("%08lx\n", nubus_get_rom(&rp, 4, bytelanes));
pr_debug("%08lx\n", nubus_get_rom(&rp, 4, bytelanes));
rp = board->fblock; rp = board->fblock;
board->slot = slot; board->slot = slot;
...@@ -722,10 +761,10 @@ static struct nubus_board * __init nubus_add_board(int slot, int bytelanes) ...@@ -722,10 +761,10 @@ static struct nubus_board * __init nubus_add_board(int slot, int bytelanes)
/* Directory offset should be small and negative... */ /* Directory offset should be small and negative... */
if (!(board->doffset & 0x00FF0000)) if (!(board->doffset & 0x00FF0000))
pr_warn("Dodgy doffset!\n"); pr_warn("Slot %X: Dodgy doffset!\n", slot);
dpat = nubus_get_rom(&rp, 4, bytelanes); dpat = nubus_get_rom(&rp, 4, bytelanes);
if (dpat != NUBUS_TEST_PATTERN) if (dpat != NUBUS_TEST_PATTERN)
pr_warn("Wrong test pattern %08lx!\n", dpat); pr_warn("Slot %X: Wrong test pattern %08lx!\n", slot, dpat);
/* /*
* I wonder how the CRC is meant to work - * I wonder how the CRC is meant to work -
...@@ -742,53 +781,52 @@ static struct nubus_board * __init nubus_add_board(int slot, int bytelanes) ...@@ -742,53 +781,52 @@ static struct nubus_board * __init nubus_add_board(int slot, int bytelanes)
nubus_get_root_dir(board, &dir); nubus_get_root_dir(board, &dir);
/* We're ready to rock */ /* We're ready to rock */
pr_info("Slot %X:\n", slot); pr_debug("Slot %X resources:\n", slot);
/* Each slot should have one board resource and any number of /* Each slot should have one board resource and any number of
functional resources. So we'll fill in some fields in the * functional resources. So we'll fill in some fields in the
struct nubus_board from the board resource, then walk down * struct nubus_board from the board resource, then walk down
the list of functional resources, spinning out a nubus_dev * the list of functional resources, spinning out a nubus_rsrc
for each of them. */ * for each of them.
*/
if (nubus_readdir(&dir, &ent) == -1) { if (nubus_readdir(&dir, &ent) == -1) {
/* We can't have this! */ /* We can't have this! */
pr_err("Board resource not found!\n"); pr_err("Slot %X: Board resource not found!\n", slot);
return NULL; kfree(board);
} else { return;
pr_info(" Board resource:\n");
nubus_get_board_resource(board, slot, &ent);
} }
if (ent.type < 1 || ent.type > 127)
pr_warn("Slot %X: Board resource ID is invalid!\n", slot);
board->procdir = nubus_proc_add_board(board);
nubus_get_board_resource(board, slot, &ent);
while (nubus_readdir(&dir, &ent) != -1) { while (nubus_readdir(&dir, &ent) != -1) {
struct nubus_dev *dev; struct nubus_rsrc *fres;
struct nubus_dev **devp;
dev = nubus_get_functional_resource(board, slot, &ent); fres = nubus_get_functional_resource(board, slot, &ent);
if (dev == NULL) if (fres == NULL)
continue; continue;
/* We zeroed this out above */ /* Resources should appear in ascending ID order. This sanity
if (board->first_dev == NULL) * check prevents duplicate resource IDs.
board->first_dev = dev; */
if (fres->resid <= prev_resid) {
kfree(fres);
continue;
}
prev_resid = fres->resid;
/* Put it on the global NuBus device chain. Keep entries in order. */ list_add_tail(&fres->list, &nubus_func_rsrcs);
for (devp = &nubus_devices; *devp != NULL;
devp = &((*devp)->next))
/* spin */;
*devp = dev;
dev->next = NULL;
} }
/* Put it on the global NuBus board chain. Keep entries in order. */ if (nubus_device_register(board))
for (boardp = &nubus_boards; *boardp != NULL; put_device(&board->dev);
boardp = &((*boardp)->next))
/* spin */;
*boardp = board;
board->next = NULL;
return board;
} }
void __init nubus_probe_slot(int slot) static void __init nubus_probe_slot(int slot)
{ {
unsigned char dp; unsigned char dp;
unsigned char *rp; unsigned char *rp;
...@@ -796,11 +834,8 @@ void __init nubus_probe_slot(int slot) ...@@ -796,11 +834,8 @@ void __init nubus_probe_slot(int slot)
rp = nubus_rom_addr(slot); rp = nubus_rom_addr(slot);
for (i = 4; i; i--) { for (i = 4; i; i--) {
int card_present;
rp--; rp--;
card_present = hwreg_present(rp); if (!hwreg_present(rp))
if (!card_present)
continue; continue;
dp = *rp; dp = *rp;
...@@ -822,10 +857,11 @@ void __init nubus_probe_slot(int slot) ...@@ -822,10 +857,11 @@ void __init nubus_probe_slot(int slot)
} }
} }
void __init nubus_scan_bus(void) static void __init nubus_scan_bus(void)
{ {
int slot; int slot;
pr_info("NuBus: Scanning NuBus slots.\n");
for (slot = 9; slot < 15; slot++) { for (slot = 9; slot < 15; slot++) {
nubus_probe_slot(slot); nubus_probe_slot(slot);
} }
...@@ -833,14 +869,16 @@ void __init nubus_scan_bus(void) ...@@ -833,14 +869,16 @@ void __init nubus_scan_bus(void)
static int __init nubus_init(void) static int __init nubus_init(void)
{ {
int err;
if (!MACH_IS_MAC) if (!MACH_IS_MAC)
return 0; return 0;
pr_info("NuBus: Scanning NuBus slots.\n");
nubus_devices = NULL;
nubus_boards = NULL;
nubus_scan_bus();
nubus_proc_init(); nubus_proc_init();
err = nubus_bus_register();
if (err)
return err;
nubus_scan_bus();
return 0; return 0;
} }
......
...@@ -11,39 +11,37 @@ ...@@ -11,39 +11,37 @@
structure in /proc analogous to the structure of the NuBus ROM structure in /proc analogous to the structure of the NuBus ROM
resources. resources.
Therefore each NuBus device is in fact a directory, which may in Therefore each board function gets a directory, which may in turn
turn contain subdirectories. The "files" correspond to NuBus contain subdirectories. Each slot resource is a file. Unrecognized
resource records. For those types of records which we know how to resources are empty files, since every resource ID requires a special
convert to formats that are meaningful to userspace (mostly just case (e.g. if the resource ID implies a directory or block, then its
icons) these files will provide "cooked" data. Otherwise they will value has to be interpreted as a slot ROM pointer etc.).
simply provide raw access (read-only of course) to the ROM. */ */
#include <linux/types.h> #include <linux/types.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/nubus.h> #include <linux/nubus.h>
#include <linux/proc_fs.h> #include <linux/proc_fs.h>
#include <linux/seq_file.h> #include <linux/seq_file.h>
#include <linux/slab.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/uaccess.h> #include <linux/uaccess.h>
#include <asm/byteorder.h> #include <asm/byteorder.h>
/*
* /proc/bus/nubus/devices stuff
*/
static int static int
nubus_devices_proc_show(struct seq_file *m, void *v) nubus_devices_proc_show(struct seq_file *m, void *v)
{ {
struct nubus_dev *dev = nubus_devices; struct nubus_rsrc *fres;
while (dev) { for_each_func_rsrc(fres)
seq_printf(m, "%x\t%04x %04x %04x %04x", seq_printf(m, "%x\t%04x %04x %04x %04x\t%08lx\n",
dev->board->slot, fres->board->slot, fres->category, fres->type,
dev->category, fres->dr_sw, fres->dr_hw, fres->board->slot_addr);
dev->type,
dev->dr_sw,
dev->dr_hw);
seq_printf(m, "\t%08lx\n", dev->board->slot_addr);
dev = dev->next;
}
return 0; return 0;
} }
...@@ -61,174 +59,163 @@ static const struct file_operations nubus_devices_proc_fops = { ...@@ -61,174 +59,163 @@ static const struct file_operations nubus_devices_proc_fops = {
static struct proc_dir_entry *proc_bus_nubus_dir; static struct proc_dir_entry *proc_bus_nubus_dir;
static const struct file_operations nubus_proc_subdir_fops = { /*
#warning Need to set some I/O handlers here * /proc/bus/nubus/x/ stuff
}; */
static void nubus_proc_subdir(struct nubus_dev* dev, struct proc_dir_entry *nubus_proc_add_board(struct nubus_board *board)
struct proc_dir_entry* parent,
struct nubus_dir* dir)
{ {
struct nubus_dirent ent; char name[2];
/* Some of these are directories, others aren't */ if (!proc_bus_nubus_dir)
while (nubus_readdir(dir, &ent) != -1) { return NULL;
char name[8]; snprintf(name, sizeof(name), "%x", board->slot);
struct proc_dir_entry* e; return proc_mkdir(name, proc_bus_nubus_dir);
sprintf(name, "%x", ent.type);
e = proc_create(name, S_IFREG | S_IRUGO | S_IWUSR, parent,
&nubus_proc_subdir_fops);
if (!e)
return;
}
} }
/* Can't do this recursively since the root directory is structured /* The PDE private data for any directory under /proc/bus/nubus/x/
somewhat differently from the subdirectories */ * is the bytelanes value for the board in slot x.
static void nubus_proc_populate(struct nubus_dev* dev, */
struct proc_dir_entry* parent,
struct nubus_dir* root) struct proc_dir_entry *nubus_proc_add_rsrc_dir(struct proc_dir_entry *procdir,
const struct nubus_dirent *ent,
struct nubus_board *board)
{ {
struct nubus_dirent ent; char name[9];
int lanes = board->lanes;
/* We know these are all directories (board resource + one or
more functional resources) */ if (!procdir)
while (nubus_readdir(root, &ent) != -1) { return NULL;
char name[8]; snprintf(name, sizeof(name), "%x", ent->type);
struct proc_dir_entry* e; return proc_mkdir_data(name, 0555, procdir, (void *)lanes);
struct nubus_dir dir;
sprintf(name, "%x", ent.type);
e = proc_mkdir(name, parent);
if (!e) return;
/* And descend */
if (nubus_get_subdir(&ent, &dir) == -1) {
/* This shouldn't happen */
printk(KERN_ERR "NuBus root directory node %x:%x has no subdir!\n",
dev->board->slot, ent.type);
continue;
} else {
nubus_proc_subdir(dev, e, &dir);
}
}
} }
int nubus_proc_attach_device(struct nubus_dev *dev) /* The PDE private data for a file under /proc/bus/nubus/x/ is a pointer to
* an instance of the following structure, which gives the location and size
* of the resource data in the slot ROM. For slot resources which hold only a
* small integer, this integer value is stored directly and size is set to 0.
* A NULL private data pointer indicates an unrecognized resource.
*/
struct nubus_proc_pde_data {
unsigned char *res_ptr;
unsigned int res_size;
};
static struct nubus_proc_pde_data *
nubus_proc_alloc_pde_data(unsigned char *ptr, unsigned int size)
{ {
struct proc_dir_entry *e; struct nubus_proc_pde_data *pde_data;
struct nubus_dir root;
char name[8];
if (dev == NULL) {
printk(KERN_ERR
"NULL pointer in nubus_proc_attach_device, shoot the programmer!\n");
return -1;
}
if (dev->board == NULL) {
printk(KERN_ERR
"NULL pointer in nubus_proc_attach_device, shoot the programmer!\n");
printk("dev = %p, dev->board = %p\n", dev, dev->board);
return -1;
}
/* Create a directory */
sprintf(name, "%x", dev->board->slot);
e = dev->procdir = proc_mkdir(name, proc_bus_nubus_dir);
if (!e)
return -ENOMEM;
/* Now recursively populate it with files */ pde_data = kmalloc(sizeof(*pde_data), GFP_KERNEL);
nubus_get_root_dir(dev->board, &root); if (!pde_data)
nubus_proc_populate(dev, e, &root); return NULL;
return 0; pde_data->res_ptr = ptr;
pde_data->res_size = size;
return pde_data;
} }
EXPORT_SYMBOL(nubus_proc_attach_device);
/* static int nubus_proc_rsrc_show(struct seq_file *m, void *v)
* /proc/nubus stuff
*/
static int nubus_proc_show(struct seq_file *m, void *v)
{ {
const struct nubus_board *board = v; struct inode *inode = m->private;
struct nubus_proc_pde_data *pde_data;
/* Display header on line 1 */ pde_data = PDE_DATA(inode);
if (v == SEQ_START_TOKEN) if (!pde_data)
seq_puts(m, "Nubus devices found:\n"); return 0;
else
seq_printf(m, "Slot %X: %s\n", board->slot, board->name); if (pde_data->res_size > m->size)
return -EFBIG;
if (pde_data->res_size) {
int lanes = (int)proc_get_parent_data(inode);
struct nubus_dirent ent;
if (!lanes)
return 0;
ent.mask = lanes;
ent.base = pde_data->res_ptr;
ent.data = 0;
nubus_seq_write_rsrc_mem(m, &ent, pde_data->res_size);
} else {
unsigned int data = (unsigned int)pde_data->res_ptr;
seq_putc(m, data >> 16);
seq_putc(m, data >> 8);
seq_putc(m, data >> 0);
}
return 0; return 0;
} }
static void *nubus_proc_start(struct seq_file *m, loff_t *_pos) static int nubus_proc_rsrc_open(struct inode *inode, struct file *file)
{ {
struct nubus_board *board; return single_open(file, nubus_proc_rsrc_show, inode);
unsigned pos;
if (*_pos > LONG_MAX)
return NULL;
pos = *_pos;
if (pos == 0)
return SEQ_START_TOKEN;
for (board = nubus_boards; board; board = board->next)
if (--pos == 0)
break;
return board;
} }
static void *nubus_proc_next(struct seq_file *p, void *v, loff_t *_pos) static const struct file_operations nubus_proc_rsrc_fops = {
.open = nubus_proc_rsrc_open,
.read = seq_read,
.llseek = seq_lseek,
.release = single_release,
};
void nubus_proc_add_rsrc_mem(struct proc_dir_entry *procdir,
const struct nubus_dirent *ent,
unsigned int size)
{ {
/* Walk the list of NuBus boards */ char name[9];
struct nubus_board *board = v; struct nubus_proc_pde_data *pde_data;
++*_pos; if (!procdir)
if (v == SEQ_START_TOKEN) return;
board = nubus_boards;
else if (board) snprintf(name, sizeof(name), "%x", ent->type);
board = board->next; if (size)
return board; pde_data = nubus_proc_alloc_pde_data(nubus_dirptr(ent), size);
else
pde_data = NULL;
proc_create_data(name, S_IFREG | 0444, procdir,
&nubus_proc_rsrc_fops, pde_data);
} }
static void nubus_proc_stop(struct seq_file *p, void *v) void nubus_proc_add_rsrc(struct proc_dir_entry *procdir,
const struct nubus_dirent *ent)
{ {
char name[9];
unsigned char *data = (unsigned char *)ent->data;
if (!procdir)
return;
snprintf(name, sizeof(name), "%x", ent->type);
proc_create_data(name, S_IFREG | 0444, procdir,
&nubus_proc_rsrc_fops,
nubus_proc_alloc_pde_data(data, 0));
} }
static const struct seq_operations nubus_proc_seqops = { /*
.start = nubus_proc_start, * /proc/nubus stuff
.next = nubus_proc_next, */
.stop = nubus_proc_stop,
.show = nubus_proc_show,
};
static int nubus_proc_open(struct inode *inode, struct file *file) static int nubus_proc_open(struct inode *inode, struct file *file)
{ {
return seq_open(file, &nubus_proc_seqops); return single_open(file, nubus_proc_show, NULL);
} }
static const struct file_operations nubus_proc_fops = { static const struct file_operations nubus_proc_fops = {
.open = nubus_proc_open, .open = nubus_proc_open,
.read = seq_read, .read = seq_read,
.llseek = seq_lseek, .llseek = seq_lseek,
.release = seq_release, .release = single_release,
}; };
void __init proc_bus_nubus_add_devices(void)
{
struct nubus_dev *dev;
for(dev = nubus_devices; dev; dev = dev->next)
nubus_proc_attach_device(dev);
}
void __init nubus_proc_init(void) void __init nubus_proc_init(void)
{ {
proc_create("nubus", 0, NULL, &nubus_proc_fops); proc_create("nubus", 0, NULL, &nubus_proc_fops);
if (!MACH_IS_MAC)
return;
proc_bus_nubus_dir = proc_mkdir("bus/nubus", NULL); proc_bus_nubus_dir = proc_mkdir("bus/nubus", NULL);
if (!proc_bus_nubus_dir)
return;
proc_create("devices", 0, proc_bus_nubus_dir, &nubus_devices_proc_fops); proc_create("devices", 0, proc_bus_nubus_dir, &nubus_devices_proc_fops);
proc_bus_nubus_add_devices();
} }
...@@ -556,7 +556,7 @@ static void __init iounmap_macfb(void) ...@@ -556,7 +556,7 @@ static void __init iounmap_macfb(void)
static int __init macfb_init(void) static int __init macfb_init(void)
{ {
int video_cmap_len, video_is_nubus = 0; int video_cmap_len, video_is_nubus = 0;
struct nubus_dev* ndev = NULL; struct nubus_rsrc *ndev = NULL;
char *option = NULL; char *option = NULL;
int err; int err;
...@@ -670,15 +670,17 @@ static int __init macfb_init(void) ...@@ -670,15 +670,17 @@ static int __init macfb_init(void)
* code is really broken :-) * code is really broken :-)
*/ */
while ((ndev = nubus_find_type(NUBUS_CAT_DISPLAY, for_each_func_rsrc(ndev) {
NUBUS_TYPE_VIDEO, ndev)))
{
unsigned long base = ndev->board->slot_addr; unsigned long base = ndev->board->slot_addr;
if (mac_bi_data.videoaddr < base || if (mac_bi_data.videoaddr < base ||
mac_bi_data.videoaddr - base > 0xFFFFFF) mac_bi_data.videoaddr - base > 0xFFFFFF)
continue; continue;
if (ndev->category != NUBUS_CAT_DISPLAY ||
ndev->type != NUBUS_TYPE_VIDEO)
continue;
video_is_nubus = 1; video_is_nubus = 1;
slot_addr = (unsigned char *)base; slot_addr = (unsigned char *)base;
......
...@@ -5,20 +5,36 @@ ...@@ -5,20 +5,36 @@
Originally written by Alan Cox. Originally written by Alan Cox.
Hacked to death by C. Scott Ananian and David Huggins-Daines. Hacked to death by C. Scott Ananian and David Huggins-Daines.
*/
Some of the constants in here are from the corresponding
NetBSD/OpenBSD header file, by Allen Briggs. We figured out the
rest of them on our own. */
#ifndef LINUX_NUBUS_H #ifndef LINUX_NUBUS_H
#define LINUX_NUBUS_H #define LINUX_NUBUS_H
#include <linux/device.h>
#include <asm/nubus.h> #include <asm/nubus.h>
#include <uapi/linux/nubus.h> #include <uapi/linux/nubus.h>
struct proc_dir_entry;
struct seq_file;
struct nubus_dir {
unsigned char *base;
unsigned char *ptr;
int done;
int mask;
struct proc_dir_entry *procdir;
};
struct nubus_dirent {
unsigned char *base;
unsigned char type;
__u32 data; /* Actually 24 bits used */
int mask;
};
struct nubus_board { struct nubus_board {
struct nubus_board* next; struct device dev;
struct nubus_dev* first_dev;
/* Only 9-E actually exist, though 0-8 are also theoretically /* Only 9-E actually exist, though 0-8 are also theoretically
possible, and 0 is a special case which represents the possible, and 0 is a special case which represents the
motherboard and onboard peripherals (Ethernet, video) */ motherboard and onboard peripherals (Ethernet, video) */
...@@ -27,10 +43,10 @@ struct nubus_board { ...@@ -27,10 +43,10 @@ struct nubus_board {
char name[64]; char name[64];
/* Format block */ /* Format block */
unsigned char* fblock; unsigned char *fblock;
/* Root directory (does *not* always equal fblock + doffset!) */ /* Root directory (does *not* always equal fblock + doffset!) */
unsigned char* directory; unsigned char *directory;
unsigned long slot_addr; unsigned long slot_addr;
/* Offset to root directory (sometimes) */ /* Offset to root directory (sometimes) */
unsigned long doffset; unsigned long doffset;
...@@ -41,15 +57,15 @@ struct nubus_board { ...@@ -41,15 +57,15 @@ struct nubus_board {
unsigned char rev; unsigned char rev;
unsigned char format; unsigned char format;
unsigned char lanes; unsigned char lanes;
};
struct nubus_dev {
/* Next link in device list */
struct nubus_dev* next;
/* Directory entry in /proc/bus/nubus */ /* Directory entry in /proc/bus/nubus */
struct proc_dir_entry* procdir; struct proc_dir_entry *procdir;
};
struct nubus_rsrc {
struct list_head list;
/* The functional resource ID of this device */ /* The functional resource ID */
unsigned char resid; unsigned char resid;
/* These are mostly here for convenience; we could always read /* These are mostly here for convenience; we could always read
them from the ROMs if we wanted to */ them from the ROMs if we wanted to */
...@@ -57,79 +73,116 @@ struct nubus_dev { ...@@ -57,79 +73,116 @@ struct nubus_dev {
unsigned short type; unsigned short type;
unsigned short dr_sw; unsigned short dr_sw;
unsigned short dr_hw; unsigned short dr_hw;
/* This is the device's name rather than the board's.
Sometimes they are different. Usually the board name is
more correct. */
char name[64];
/* MacOS driver (I kid you not) */
unsigned char* driver;
/* Actually this is an offset */
unsigned long iobase;
unsigned long iosize;
unsigned char flags, hwdevid;
/* Functional directory */ /* Functional directory */
unsigned char* directory; unsigned char *directory;
/* Much of our info comes from here */ /* Much of our info comes from here */
struct nubus_board* board; struct nubus_board *board;
};
/* This is all NuBus functional resources (used to find devices later on) */
extern struct list_head nubus_func_rsrcs;
struct nubus_driver {
struct device_driver driver;
int (*probe)(struct nubus_board *board);
int (*remove)(struct nubus_board *board);
}; };
/* This is all NuBus devices (used to find devices later on) */ extern struct bus_type nubus_bus_type;
extern struct nubus_dev* nubus_devices;
/* This is all NuBus cards */
extern struct nubus_board* nubus_boards;
/* Generic NuBus interface functions, modelled after the PCI interface */ /* Generic NuBus interface functions, modelled after the PCI interface */
void nubus_scan_bus(void);
#ifdef CONFIG_PROC_FS #ifdef CONFIG_PROC_FS
extern void nubus_proc_init(void); void nubus_proc_init(void);
struct proc_dir_entry *nubus_proc_add_board(struct nubus_board *board);
struct proc_dir_entry *nubus_proc_add_rsrc_dir(struct proc_dir_entry *procdir,
const struct nubus_dirent *ent,
struct nubus_board *board);
void nubus_proc_add_rsrc_mem(struct proc_dir_entry *procdir,
const struct nubus_dirent *ent,
unsigned int size);
void nubus_proc_add_rsrc(struct proc_dir_entry *procdir,
const struct nubus_dirent *ent);
#else #else
static inline void nubus_proc_init(void) {} static inline void nubus_proc_init(void) {}
static inline
struct proc_dir_entry *nubus_proc_add_board(struct nubus_board *board)
{ return NULL; }
static inline
struct proc_dir_entry *nubus_proc_add_rsrc_dir(struct proc_dir_entry *procdir,
const struct nubus_dirent *ent,
struct nubus_board *board)
{ return NULL; }
static inline void nubus_proc_add_rsrc_mem(struct proc_dir_entry *procdir,
const struct nubus_dirent *ent,
unsigned int size) {}
static inline void nubus_proc_add_rsrc(struct proc_dir_entry *procdir,
const struct nubus_dirent *ent) {}
#endif #endif
int get_nubus_list(char *buf);
int nubus_proc_attach_device(struct nubus_dev *dev); struct nubus_rsrc *nubus_first_rsrc_or_null(void);
/* If we need more precision we can add some more of these */ struct nubus_rsrc *nubus_next_rsrc_or_null(struct nubus_rsrc *from);
struct nubus_dev* nubus_find_device(unsigned short category,
unsigned short type, #define for_each_func_rsrc(f) \
unsigned short dr_hw, for (f = nubus_first_rsrc_or_null(); f; f = nubus_next_rsrc_or_null(f))
unsigned short dr_sw,
const struct nubus_dev* from); #define for_each_board_func_rsrc(b, f) \
struct nubus_dev* nubus_find_type(unsigned short category, for_each_func_rsrc(f) if (f->board != b) {} else
unsigned short type,
const struct nubus_dev* from);
/* Might have more than one device in a slot, you know... */
struct nubus_dev* nubus_find_slot(unsigned int slot,
const struct nubus_dev* from);
/* These are somewhat more NuBus-specific. They all return 0 for /* These are somewhat more NuBus-specific. They all return 0 for
success and -1 for failure, as you'd expect. */ success and -1 for failure, as you'd expect. */
/* The root directory which contains the board and functional /* The root directory which contains the board and functional
directories */ directories */
int nubus_get_root_dir(const struct nubus_board* board, int nubus_get_root_dir(const struct nubus_board *board,
struct nubus_dir* dir); struct nubus_dir *dir);
/* The board directory */ /* The board directory */
int nubus_get_board_dir(const struct nubus_board* board, int nubus_get_board_dir(const struct nubus_board *board,
struct nubus_dir* dir); struct nubus_dir *dir);
/* The functional directory */ /* The functional directory */
int nubus_get_func_dir(const struct nubus_dev* dev, int nubus_get_func_dir(const struct nubus_rsrc *fres, struct nubus_dir *dir);
struct nubus_dir* dir);
/* These work on any directory gotten via the above */ /* These work on any directory gotten via the above */
int nubus_readdir(struct nubus_dir* dir, int nubus_readdir(struct nubus_dir *dir,
struct nubus_dirent* ent); struct nubus_dirent *ent);
int nubus_find_rsrc(struct nubus_dir* dir, int nubus_find_rsrc(struct nubus_dir *dir,
unsigned char rsrc_type, unsigned char rsrc_type,
struct nubus_dirent* ent); struct nubus_dirent *ent);
int nubus_rewinddir(struct nubus_dir* dir); int nubus_rewinddir(struct nubus_dir *dir);
/* Things to do with directory entries */ /* Things to do with directory entries */
int nubus_get_subdir(const struct nubus_dirent* ent, int nubus_get_subdir(const struct nubus_dirent *ent,
struct nubus_dir* dir); struct nubus_dir *dir);
void nubus_get_rsrc_mem(void* dest, void nubus_get_rsrc_mem(void *dest, const struct nubus_dirent *dirent,
const struct nubus_dirent *dirent, unsigned int len);
int len); unsigned int nubus_get_rsrc_str(char *dest, const struct nubus_dirent *dirent,
void nubus_get_rsrc_str(void* dest, unsigned int len);
const struct nubus_dirent *dirent, void nubus_seq_write_rsrc_mem(struct seq_file *m,
int maxlen); const struct nubus_dirent *dirent,
unsigned int len);
unsigned char *nubus_dirptr(const struct nubus_dirent *nd);
/* Declarations relating to driver model objects */
int nubus_bus_register(void);
int nubus_device_register(struct nubus_board *board);
int nubus_driver_register(struct nubus_driver *ndrv);
void nubus_driver_unregister(struct nubus_driver *ndrv);
int nubus_proc_show(struct seq_file *m, void *data);
static inline void nubus_set_drvdata(struct nubus_board *board, void *data)
{
dev_set_drvdata(&board->dev, data);
}
static inline void *nubus_get_drvdata(struct nubus_board *board)
{
return dev_get_drvdata(&board->dev);
}
/* Returns a pointer to the "standard" slot space. */
static inline void *nubus_slot_addr(int slot)
{
return (void *)(0xF0000000 | (slot << 24));
}
#endif /* LINUX_NUBUS_H */ #endif /* LINUX_NUBUS_H */
...@@ -221,27 +221,4 @@ enum nubus_display_res_id { ...@@ -221,27 +221,4 @@ enum nubus_display_res_id {
NUBUS_RESID_SIXTHMODE = 0x0085 NUBUS_RESID_SIXTHMODE = 0x0085
}; };
struct nubus_dir
{
unsigned char *base;
unsigned char *ptr;
int done;
int mask;
};
struct nubus_dirent
{
unsigned char *base;
unsigned char type;
__u32 data; /* Actually 24bits used */
int mask;
};
/* We'd like to get rid of this eventually. Only daynaport.c uses it now. */
static inline void *nubus_slot_addr(int slot)
{
return (void *)(0xF0000000|(slot<<24));
}
#endif /* _UAPILINUX_NUBUS_H */ #endif /* _UAPILINUX_NUBUS_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment