Changes in 4.9.212 xfs: Sanity check flags of Q_XQUOTARM call powerpc/archrandom: fix arch_get_random_seed_int() mt7601u: fix bbp version check in mt7601u_wait_bbp_ready drm/sti: do not remove the drm_bridge that was never added drm/virtio: fix bounds check in virtio_gpu_cmd_get_capset() ALSA: hda: fix unused variable warning IB/rxe: replace kvfree with vfree ALSA: usb-audio: update quirk for B&W PX to remove microphone staging: comedi: ni_mio_common: protect register write overflow pwm: lpss: Release runtime-pm reference from the driver's remove callback mlxsw: reg: QEEC: Add minimum shaper fields pcrypt: use format specifier in kobject_add exportfs: fix 'passing zero to ERR_PTR()' warning drm/dp_mst: Skip validating ports during destruction, just ref net: phy: Fix not to call phy_resume() if PHY is not attached pinctrl: sh-pfc: r8a7740: Add missing REF125CK pin to gether_gmii group pinctrl: sh-pfc: r8a7740: Add missing LCD0 marks to lcd0_data24_1 group pinctrl: sh-pfc: r8a7791: Remove bogus ctrl marks from qspi_data4_b group pinctrl: sh-pfc: r8a7791: Remove bogus marks from vin1_b_data18 group pinctrl: sh-pfc: sh73a0: Add missing TO pin to tpu4_to3 group pinctrl: sh-pfc: r8a7794: Remove bogus IPSR9 field pinctrl: sh-pfc: sh7734: Add missing IPSR11 field pinctrl: sh-pfc: sh7269: Add missing PCIOR0 field pinctrl: sh-pfc: sh7734: Remove bogus IPSR10 value Input: nomadik-ske-keypad - fix a loop timeout test clk: highbank: fix refcount leak in hb_clk_init() clk: qoriq: fix refcount leak in clockgen_init() clk: socfpga: fix refcount leak clk: samsung: exynos4: fix refcount leak in exynos4_get_xom() clk: imx6q: fix refcount leak in imx6q_clocks_init() clk: imx6sx: fix refcount leak in imx6sx_clocks_init() clk: imx7d: fix refcount leak in imx7d_clocks_init() clk: vf610: fix refcount leak in vf610_clocks_init() clk: armada-370: fix refcount leak in a370_clk_init() clk: kirkwood: fix refcount leak in kirkwood_clk_init() clk: armada-xp: fix refcount leak in axp_clk_init() clk: dove: fix refcount leak in dove_clk_init() IB/usnic: Fix out of bounds index check in query pkey RDMA/ocrdma: Fix out of bounds index check in query pkey RDMA/qedr: Fix out of bounds index check in query pkey arm64: dts: apq8016-sbc: Increase load on l11 for SDCARD drm/etnaviv: NULL vs IS_ERR() buf in etnaviv_core_dump() media: s5p-jpeg: Correct step and max values for V4L2_CID_JPEG_RESTART_INTERVAL crypto: tgr192 - fix unaligned memory access ASoC: imx-sgtl5000: put of nodes if finding codec fails IB/iser: Pass the correct number of entries for dma mapped SGL rtc: cmos: ignore bogus century byte clk: sunxi-ng: sun8i-a23: Enable PLL-MIPI LDOs when ungating it iwlwifi: mvm: fix A-MPDU reference assignment tty: ipwireless: Fix potential NULL pointer dereference crypto: crypto4xx - Fix wrong ppc4xx_trng_probe()/ppc4xx_trng_remove() arguments ARM: dts: lpc32xx: add required clocks property to keypad device node ARM: dts: lpc32xx: reparent keypad controller to SIC1 ARM: dts: lpc32xx: fix ARM PrimeCell LCD controller variant ARM: dts: lpc32xx: fix ARM PrimeCell LCD controller clocks property ARM: dts: lpc32xx: phy3250: fix SD card regulator voltage iwlwifi: mvm: fix RSS config command staging: most: cdev: add missing check for cdev_add failure rtc: ds1672: fix unintended sign extension thermal: mediatek: fix register index error net: phy: fixed_phy: Fix fixed_phy not checking GPIO rtc: 88pm860x: fix unintended sign extension rtc: 88pm80x: fix unintended sign extension rtc: pm8xxx: fix unintended sign extension fbdev: chipsfb: remove set but not used variable 'size' iw_cxgb4: use tos when importing the endpoint iw_cxgb4: use tos when finding ipv6 routes pinctrl: sh-pfc: emev2: Add missing pinmux functions pinctrl: sh-pfc: r8a7791: Fix scifb2_data_c pin group pinctrl: sh-pfc: r8a7792: Fix vin1_data18_b pin group pinctrl: sh-pfc: sh73a0: Fix fsic_spdif pin groups usb: phy: twl6030-usb: fix possible use-after-free on remove block: don't use bio->bi_vcnt to figure out segment number keys: Timestamp new keys vfio_pci: Enable memory accesses before calling pci_map_rom dmaengine: mv_xor: Use correct device for DMA API cdc-wdm: pass return value of recover_from_urb_loss regulator: pv88060: Fix array out-of-bounds access regulator: pv88080: Fix array out-of-bounds access regulator: pv88090: Fix array out-of-bounds access net: dsa: qca8k: Enable delay for RGMII_ID mode drm/nouveau/bios/ramcfg: fix missing parentheses when calculating RON drm/nouveau/pmu: don't print reply values if exec is false ASoC: qcom: Fix of-node refcount unbalance in apq8016_sbc_parse_of() fs/nfs: Fix nfs_parse_devname to not modify it's argument NFS: Fix a soft lockup in the delegation recovery code clocksource/drivers/sun5i: Fail gracefully when clock rate is unavailable clocksource/drivers/exynos_mct: Fix error path in timer resources initialization mmc: sdhci-brcmstb: handle mmc_of_parse() errors during probe ARM: 8847/1: pm: fix HYP/SVC mode mismatch when MCPM is used ARM: 8848/1: virt: Align GIC version check with arm64 counterpart regulator: wm831x-dcdc: Fix list of wm831x_dcdc_ilim from mA to uA nios2: ksyms: Add missing symbol exports scsi: megaraid_sas: reduce module load time drivers/rapidio/rio_cm.c: fix potential oops in riocm_ch_listen() xen, cpu_hotplug: Prevent an out of bounds access net: sh_eth: fix a missing check of of_get_phy_mode media: ivtv: update *pos correctly in ivtv_read_pos() media: cx18: update *pos correctly in cx18_read_pos() media: wl128x: Fix an error code in fm_download_firmware() media: cx23885: check allocation return regulator: tps65086: Fix tps65086_ldoa1_ranges for selector 0xB jfs: fix bogus variable self-initialization tipc: tipc clang warning m68k: mac: Fix VIA timer counter accesses ARM: OMAP2+: Fix potentially uninitialized return value for _setup_reset() media: davinci-isif: avoid uninitialized variable use media: tw5864: Fix possible NULL pointer dereference in tw5864_handle_frame spi: tegra114: clear packed bit for unpacked mode spi: tegra114: fix for unpacked mode transfers soc/fsl/qe: Fix an error code in qe_pin_request() spi: bcm2835aux: fix driver to not allow 65535 (=-1) cs-gpios ehea: Fix a copy-paste err in ehea_init_port_res scsi: qla2xxx: Unregister chrdev if module initialization fails ARM: pxa: ssp: Fix "WARNING: invalid free of devm_ allocated data" hwmon: (w83627hf) Use request_muxed_region for Super-IO accesses tipc: set sysctl_tipc_rmem and named_timeout right range powerpc: vdso: Make vdso32 installation conditional in vdso_install ARM: dts: ls1021: Fix SGMII PCS link remaining down after PHY disconnect media: ov2659: fix unbalanced mutex_lock/unlock 6lowpan: Off by one handling ->nexthdr dmaengine: axi-dmac: Don't check the number of frames for alignment ALSA: usb-audio: Handle the error from snd_usb_mixer_apply_create_quirk() packet: in recvmsg msg_name return at least sizeof sockaddr_ll ASoC: fix valid stream condition usb: gadget: fsl: fix link error against usb-gadget module IB/mlx5: Add missing XRC options to QP optional params mask iommu/vt-d: Make kernel parameter igfx_off work with vIOMMU net: ena: fix swapped parameters when calling ena_com_indirect_table_fill_entry net: ena: fix: Free napi resources when ena_up() fails net: ena: fix incorrect test of supported hash function net: ena: fix ena_com_fill_hash_function() implementation dmaengine: tegra210-adma: restore channel status l2tp: Fix possible NULL pointer dereference media: omap_vout: potential buffer overflow in vidioc_dqbuf() media: davinci/vpbe: array underflow in vpbe_enum_outputs() platform/x86: alienware-wmi: printing the wrong error code netfilter: ebtables: CONFIG_COMPAT: reject trailing data after last rule pwm: meson: Don't disable PWM when setting duty repeatedly ARM: riscpc: fix lack of keyboard interrupts after irq conversion kdb: do a sanity check on the cpu in kdb_per_cpu() backlight: lm3630a: Return 0 on success in update_status functions thermal: cpu_cooling: Actually trace CPU load in thermal_power_cpu_get_power dmaengine: tegra210-adma: Fix crash during probe spi: spi-fsl-spi: call spi_finalize_current_message() at the end crypto: ccp - fix AES CFB error exposed by new test vectors serial: stm32: fix transmit_chars when tx is stopped misc: sgi-xp: Properly initialize buf in xpc_get_rsvd_page_pa iommu: Use right function to get group for device signal/cifs: Fix cifs_put_tcp_session to call send_sig instead of force_sig inet: frags: call inet_frags_fini() after unregister_pernet_subsys() media: vivid: fix incorrect assignment operation when setting video mode powerpc/cacheinfo: add cacheinfo_teardown, cacheinfo_rebuild drm/msm/mdp5: Fix mdp5_cfg_init error return net: netem: fix backlog accounting for corrupted GSO frames net/af_iucv: always register net_device notifier ASoC: ti: davinci-mcasp: Fix slot mask settings when using multiple AXRs rtc: pcf8563: Clear event flags and disable interrupts before requesting irq drm/msm/a3xx: remove TPL1 regs from snapshot perf/ioctl: Add check for the sample_period value dmaengine: hsu: Revert "set HSU_CH_MTSR to memory width" clk: qcom: Fix -Wunused-const-variable iommu/amd: Make iommu_disable safer mfd: intel-lpss: Release IDA resources rxrpc: Fix uninitialized error code in rxrpc_send_data_packet() devres: allow const resource arguments RDMA/hns: Fixs hw access invalid dma memory error net: pasemi: fix an use-after-free in pasemi_mac_phy_init() scsi: libfc: fix null pointer dereference on a null lport libertas_tf: Use correct channel range in lbtf_geo_init qed: reduce maximum stack frame size usb: host: xhci-hub: fix extra endianness conversion mic: avoid statically declaring a 'struct device'. x86/kgbd: Use NMI_VECTOR not APIC_DM_NMI ALSA: aoa: onyx: always initialize register read value net/mlx5: Fix mlx5_ifc_query_lag_out_bits cifs: fix rmmod regression in cifs.ko caused by force_sig changes crypto: caam - free resources in case caam_rng registration failed ext4: set error return correctly when ext4_htree_store_dirent fails ASoC: es8328: Fix copy-paste error in es8328_right_line_controls ASoC: cs4349: Use PM ops 'cs4349_runtime_pm' ASoC: wm8737: Fix copy-paste error in wm8737_snd_controls signal: Allow cifs and drbd to receive their terminating signals ASoC: sun4i-i2s: RX and TX counter registers are swapped dmaengine: dw: platform: Switch to acpi_dma_controller_register() mac80211: minstrel_ht: fix per-group max throughput rate initialization mips: avoid explicit UB in assignment of mips_io_port_base ahci: Do not export local variable ahci_em_messages Partially revert "kfifo: fix kfifo_alloc() and kfifo_init()" hwmon: (lm75) Fix write operations for negative temperatures power: supply: Init device wakeup after device_add() x86, perf: Fix the dependency of the x86 insn decoder selftest staging: greybus: light: fix a couple double frees bcma: fix incorrect update of BCMA_CORE_PCI_MDIO_DATA iio: dac: ad5380: fix incorrect assignment to val ath9k: dynack: fix possible deadlock in ath_dynack_node_{de}init net: sonic: return NETDEV_TX_OK if failed to map buffer Btrfs: fix hang when loading existing inode cache off disk hwmon: (shtc1) fix shtc1 and shtw1 id mask net: sonic: replace dev_kfree_skb in sonic_send_packet net/rds: Fix 'ib_evt_handler_call' element in 'rds_ib_stat_names' iommu/amd: Wait for completion of IOTLB flush in attach_device net: hisilicon: Fix signedness bug in hix5hd2_dev_probe() net: broadcom/bcmsysport: Fix signedness in bcm_sysport_probe() net: stmmac: dwmac-meson8b: Fix signedness bug in probe of: mdio: Fix a signedness bug in of_phy_get_and_connect() net: ethernet: stmmac: Fix signedness bug in ipq806x_gmac_of_parse() nvme: retain split access workaround for capability reads net: stmmac: gmac4+: Not all Unicast addresses may be available mac80211: accept deauth frames in IBSS mode llc: fix another potential sk_buff leak in llc_ui_sendmsg() llc: fix sk_buff refcounting in llc_conn_state_process() net: stmmac: fix length of PTP clock's name string act_mirred: Fix mirred_init_module error handling drm/msm/dsi: Implement reset correctly dmaengine: imx-sdma: fix size check for sdma script_number net: netem: fix error path for corrupted GSO frames net: netem: correct the parent's backlog when corrupted packet was dropped net: qca_spi: Move reset_count to struct qcaspi afs: Fix large file support media: ov6650: Fix incorrect use of JPEG colorspace media: ov6650: Fix some format attributes not under control media: ov6650: Fix .get_fmt() V4L2_SUBDEV_FORMAT_TRY support MIPS: Loongson: Fix return value of loongson_hwmon_init net: neigh: use long type to store jiffies delta packet: fix data-race in fanout_flow_is_huge() dmaengine: ti: edma: fix missed failure handling drm/radeon: fix bad DMA from INTERRUPT_CNTL2 arm64: dts: juno: Fix UART frequency IB/iser: Fix dma_nents type definition m68k: Call timer_interrupt() with interrupts disabled net: ethtool: Add back transceiver type net: phy: Keep reporting transceiver type can, slip: Protect tty->disc_data in write_wakeup and close with RCU firestream: fix memory leaks net: cxgb3_main: Add CAP_NET_ADMIN check to CHELSIO_GET_MEM net, ip6_tunnel: fix namespaces move net, ip_tunnel: fix namespaces move net_sched: fix datalen for ematch tcp_bbr: improve arithmetic division in bbr_update_bw() net: usb: lan78xx: Add .ndo_features_check gtp: make sure only SOCK_DGRAM UDP sockets are accepted hwmon: (adt7475) Make volt2reg return same reg as reg2volt input hwmon: (core) Simplify sysfs attribute name allocation hwmon: Deal with errors from the thermal subsystem hwmon: (core) Fix double-free in __hwmon_device_register() hwmon: (core) Do not use device managed functions for memory allocations Input: keyspan-remote - fix control-message timeouts ARM: 8950/1: ftrace/recordmcount: filter relocation types mmc: tegra: fix SDR50 tuning override mmc: sdhci: fix minimum clock rate for v3 controller Input: sur40 - fix interface sanity checks Input: gtco - fix endpoint sanity check Input: aiptek - fix endpoint sanity check Input: pegasus_notetaker - fix endpoint sanity check Input: sun4i-ts - add a check for devm_thermal_zone_of_sensor_register hwmon: (nct7802) Fix voltage limits to wrong registers scsi: RDMA/isert: Fix a recently introduced regression related to logout tracing: xen: Ordered comparison of function pointers do_last(): fetch directory ->i_mode and ->i_uid before it's too late Documentation: Document arm64 kpti control arm64: kpti: Whitelist Cortex-A CPUs that don't implement the CSV3 field coresight: etb10: Do not call smp_processor_id from preemptible coresight: tmc-etf: Do not call smp_processor_id from preemptible libertas: Fix two buffer overflows at parsing bss descriptor bcache: silence static checker warning scsi: iscsi: Avoid potential deadlock in iscsi_if_rx func md: Avoid namespace collision with bitmap API bitmap: Add bitmap_alloc(), bitmap_zalloc() and bitmap_free() netfilter: ipset: use bitmap infrastructure completely net/x25: fix nonblocking connect Linux 4.9.212 Signed-off-by: Greg Kroah-Hartman <gregkh@google.com> Change-Id: I2e83a05c5f119a7467a4d6984045d45d0c06b764
351 lines
9.7 KiB
C
351 lines
9.7 KiB
C
/*
|
|
* arch/m68k/bvme6000/config.c
|
|
*
|
|
* Copyright (C) 1997 Richard Hirst [richard@sleepie.demon.co.uk]
|
|
*
|
|
* Based on:
|
|
*
|
|
* linux/amiga/config.c
|
|
*
|
|
* Copyright (C) 1993 Hamish Macdonald
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
* License. See the file README.legal in the main directory of this archive
|
|
* for more details.
|
|
*/
|
|
|
|
#include <linux/types.h>
|
|
#include <linux/kernel.h>
|
|
#include <linux/mm.h>
|
|
#include <linux/tty.h>
|
|
#include <linux/console.h>
|
|
#include <linux/linkage.h>
|
|
#include <linux/init.h>
|
|
#include <linux/major.h>
|
|
#include <linux/genhd.h>
|
|
#include <linux/rtc.h>
|
|
#include <linux/interrupt.h>
|
|
#include <linux/bcd.h>
|
|
|
|
#include <asm/bootinfo.h>
|
|
#include <asm/bootinfo-vme.h>
|
|
#include <asm/byteorder.h>
|
|
#include <asm/pgtable.h>
|
|
#include <asm/setup.h>
|
|
#include <asm/irq.h>
|
|
#include <asm/traps.h>
|
|
#include <asm/machdep.h>
|
|
#include <asm/bvme6000hw.h>
|
|
|
|
static void bvme6000_get_model(char *model);
|
|
extern void bvme6000_sched_init(irq_handler_t handler);
|
|
extern u32 bvme6000_gettimeoffset(void);
|
|
extern int bvme6000_hwclk (int, struct rtc_time *);
|
|
extern int bvme6000_set_clock_mmss (unsigned long);
|
|
extern void bvme6000_reset (void);
|
|
void bvme6000_set_vectors (void);
|
|
|
|
|
|
int __init bvme6000_parse_bootinfo(const struct bi_record *bi)
|
|
{
|
|
if (be16_to_cpu(bi->tag) == BI_VME_TYPE)
|
|
return 0;
|
|
else
|
|
return 1;
|
|
}
|
|
|
|
void bvme6000_reset(void)
|
|
{
|
|
volatile PitRegsPtr pit = (PitRegsPtr)BVME_PIT_BASE;
|
|
|
|
printk ("\r\n\nCalled bvme6000_reset\r\n"
|
|
"\r\r\r\r\r\r\r\r\r\r\r\r\r\r\r\r\r\r");
|
|
/* The string of returns is to delay the reset until the whole
|
|
* message is output. */
|
|
/* Enable the watchdog, via PIT port C bit 4 */
|
|
|
|
pit->pcddr |= 0x10; /* WDOG enable */
|
|
|
|
while(1)
|
|
;
|
|
}
|
|
|
|
static void bvme6000_get_model(char *model)
|
|
{
|
|
sprintf(model, "BVME%d000", m68k_cputype == CPU_68060 ? 6 : 4);
|
|
}
|
|
|
|
/*
|
|
* This function is called during kernel startup to initialize
|
|
* the bvme6000 IRQ handling routines.
|
|
*/
|
|
static void __init bvme6000_init_IRQ(void)
|
|
{
|
|
m68k_setup_user_interrupt(VEC_USER, 192);
|
|
}
|
|
|
|
void __init config_bvme6000(void)
|
|
{
|
|
volatile PitRegsPtr pit = (PitRegsPtr)BVME_PIT_BASE;
|
|
|
|
/* Board type is only set by newer versions of vmelilo/tftplilo */
|
|
if (!vme_brdtype) {
|
|
if (m68k_cputype == CPU_68060)
|
|
vme_brdtype = VME_TYPE_BVME6000;
|
|
else
|
|
vme_brdtype = VME_TYPE_BVME4000;
|
|
}
|
|
#if 0
|
|
/* Call bvme6000_set_vectors() so ABORT will work, along with BVMBug
|
|
* debugger. Note trap_init() will splat the abort vector, but
|
|
* bvme6000_init_IRQ() will put it back again. Hopefully. */
|
|
|
|
bvme6000_set_vectors();
|
|
#endif
|
|
|
|
mach_max_dma_address = 0xffffffff;
|
|
mach_sched_init = bvme6000_sched_init;
|
|
mach_init_IRQ = bvme6000_init_IRQ;
|
|
arch_gettimeoffset = bvme6000_gettimeoffset;
|
|
mach_hwclk = bvme6000_hwclk;
|
|
mach_set_clock_mmss = bvme6000_set_clock_mmss;
|
|
mach_reset = bvme6000_reset;
|
|
mach_get_model = bvme6000_get_model;
|
|
|
|
printk ("Board is %sconfigured as a System Controller\n",
|
|
*config_reg_ptr & BVME_CONFIG_SW1 ? "" : "not ");
|
|
|
|
/* Now do the PIT configuration */
|
|
|
|
pit->pgcr = 0x00; /* Unidirectional 8 bit, no handshake for now */
|
|
pit->psrr = 0x18; /* PIACK and PIRQ functions enabled */
|
|
pit->pacr = 0x00; /* Sub Mode 00, H2 i/p, no DMA */
|
|
pit->padr = 0x00; /* Just to be tidy! */
|
|
pit->paddr = 0x00; /* All inputs for now (safest) */
|
|
pit->pbcr = 0x80; /* Sub Mode 1x, H4 i/p, no DMA */
|
|
pit->pbdr = 0xbc | (*config_reg_ptr & BVME_CONFIG_SW1 ? 0 : 0x40);
|
|
/* PRI, SYSCON?, Level3, SCC clks from xtal */
|
|
pit->pbddr = 0xf3; /* Mostly outputs */
|
|
pit->pcdr = 0x01; /* PA transceiver disabled */
|
|
pit->pcddr = 0x03; /* WDOG disable */
|
|
|
|
/* Disable snooping for Ethernet and VME accesses */
|
|
|
|
bvme_acr_addrctl = 0;
|
|
}
|
|
|
|
|
|
irqreturn_t bvme6000_abort_int (int irq, void *dev_id)
|
|
{
|
|
unsigned long *new = (unsigned long *)vectors;
|
|
unsigned long *old = (unsigned long *)0xf8000000;
|
|
|
|
/* Wait for button release */
|
|
while (*(volatile unsigned char *)BVME_LOCAL_IRQ_STAT & BVME_ABORT_STATUS)
|
|
;
|
|
|
|
*(new+4) = *(old+4); /* Illegal instruction */
|
|
*(new+9) = *(old+9); /* Trace */
|
|
*(new+47) = *(old+47); /* Trap #15 */
|
|
*(new+0x1f) = *(old+0x1f); /* ABORT switch */
|
|
return IRQ_HANDLED;
|
|
}
|
|
|
|
|
|
static irqreturn_t bvme6000_timer_int (int irq, void *dev_id)
|
|
{
|
|
irq_handler_t timer_routine = dev_id;
|
|
unsigned long flags;
|
|
volatile RtcPtr_t rtc = (RtcPtr_t)BVME_RTC_BASE;
|
|
unsigned char msr;
|
|
|
|
local_irq_save(flags);
|
|
msr = rtc->msr & 0xc0;
|
|
rtc->msr = msr | 0x20; /* Ack the interrupt */
|
|
timer_routine(0, NULL);
|
|
local_irq_restore(flags);
|
|
|
|
return IRQ_HANDLED;
|
|
}
|
|
|
|
/*
|
|
* Set up the RTC timer 1 to mode 2, so T1 output toggles every 5ms
|
|
* (40000 x 125ns). It will interrupt every 10ms, when T1 goes low.
|
|
* So, when reading the elapsed time, you should read timer1,
|
|
* subtract it from 39999, and then add 40000 if T1 is high.
|
|
* That gives you the number of 125ns ticks in to the 10ms period,
|
|
* so divide by 8 to get the microsecond result.
|
|
*/
|
|
|
|
void bvme6000_sched_init (irq_handler_t timer_routine)
|
|
{
|
|
volatile RtcPtr_t rtc = (RtcPtr_t)BVME_RTC_BASE;
|
|
unsigned char msr = rtc->msr & 0xc0;
|
|
|
|
rtc->msr = 0; /* Ensure timer registers accessible */
|
|
|
|
if (request_irq(BVME_IRQ_RTC, bvme6000_timer_int, 0, "timer",
|
|
timer_routine))
|
|
panic ("Couldn't register timer int");
|
|
|
|
rtc->t1cr_omr = 0x04; /* Mode 2, ext clk */
|
|
rtc->t1msb = 39999 >> 8;
|
|
rtc->t1lsb = 39999 & 0xff;
|
|
rtc->irr_icr1 &= 0xef; /* Route timer 1 to INTR pin */
|
|
rtc->msr = 0x40; /* Access int.cntrl, etc */
|
|
rtc->pfr_icr0 = 0x80; /* Just timer 1 ints enabled */
|
|
rtc->irr_icr1 = 0;
|
|
rtc->t1cr_omr = 0x0a; /* INTR+T1 active lo, push-pull */
|
|
rtc->t0cr_rtmr &= 0xdf; /* Stop timers in standby */
|
|
rtc->msr = 0; /* Access timer 1 control */
|
|
rtc->t1cr_omr = 0x05; /* Mode 2, ext clk, GO */
|
|
|
|
rtc->msr = msr;
|
|
|
|
if (request_irq(BVME_IRQ_ABORT, bvme6000_abort_int, 0,
|
|
"abort", bvme6000_abort_int))
|
|
panic ("Couldn't register abort int");
|
|
}
|
|
|
|
|
|
/* This is always executed with interrupts disabled. */
|
|
|
|
/*
|
|
* NOTE: Don't accept any readings within 5us of rollover, as
|
|
* the T1INT bit may be a little slow getting set. There is also
|
|
* a fault in the chip, meaning that reads may produce invalid
|
|
* results...
|
|
*/
|
|
|
|
u32 bvme6000_gettimeoffset(void)
|
|
{
|
|
volatile RtcPtr_t rtc = (RtcPtr_t)BVME_RTC_BASE;
|
|
volatile PitRegsPtr pit = (PitRegsPtr)BVME_PIT_BASE;
|
|
unsigned char msr = rtc->msr & 0xc0;
|
|
unsigned char t1int, t1op;
|
|
u32 v = 800000, ov;
|
|
|
|
rtc->msr = 0; /* Ensure timer registers accessible */
|
|
|
|
do {
|
|
ov = v;
|
|
t1int = rtc->msr & 0x20;
|
|
t1op = pit->pcdr & 0x04;
|
|
rtc->t1cr_omr |= 0x40; /* Latch timer1 */
|
|
v = rtc->t1msb << 8; /* Read timer1 */
|
|
v |= rtc->t1lsb; /* Read timer1 */
|
|
} while (t1int != (rtc->msr & 0x20) ||
|
|
t1op != (pit->pcdr & 0x04) ||
|
|
abs(ov-v) > 80 ||
|
|
v > 39960);
|
|
|
|
v = 39999 - v;
|
|
if (!t1op) /* If in second half cycle.. */
|
|
v += 40000;
|
|
v /= 8; /* Convert ticks to microseconds */
|
|
if (t1int)
|
|
v += 10000; /* Int pending, + 10ms */
|
|
rtc->msr = msr;
|
|
|
|
return v * 1000;
|
|
}
|
|
|
|
/*
|
|
* Looks like op is non-zero for setting the clock, and zero for
|
|
* reading the clock.
|
|
*
|
|
* struct hwclk_time {
|
|
* unsigned sec; 0..59
|
|
* unsigned min; 0..59
|
|
* unsigned hour; 0..23
|
|
* unsigned day; 1..31
|
|
* unsigned mon; 0..11
|
|
* unsigned year; 00...
|
|
* int wday; 0..6, 0 is Sunday, -1 means unknown/don't set
|
|
* };
|
|
*/
|
|
|
|
int bvme6000_hwclk(int op, struct rtc_time *t)
|
|
{
|
|
volatile RtcPtr_t rtc = (RtcPtr_t)BVME_RTC_BASE;
|
|
unsigned char msr = rtc->msr & 0xc0;
|
|
|
|
rtc->msr = 0x40; /* Ensure clock and real-time-mode-register
|
|
* are accessible */
|
|
if (op)
|
|
{ /* Write.... */
|
|
rtc->t0cr_rtmr = t->tm_year%4;
|
|
rtc->bcd_tenms = 0;
|
|
rtc->bcd_sec = bin2bcd(t->tm_sec);
|
|
rtc->bcd_min = bin2bcd(t->tm_min);
|
|
rtc->bcd_hr = bin2bcd(t->tm_hour);
|
|
rtc->bcd_dom = bin2bcd(t->tm_mday);
|
|
rtc->bcd_mth = bin2bcd(t->tm_mon + 1);
|
|
rtc->bcd_year = bin2bcd(t->tm_year%100);
|
|
if (t->tm_wday >= 0)
|
|
rtc->bcd_dow = bin2bcd(t->tm_wday+1);
|
|
rtc->t0cr_rtmr = t->tm_year%4 | 0x08;
|
|
}
|
|
else
|
|
{ /* Read.... */
|
|
do {
|
|
t->tm_sec = bcd2bin(rtc->bcd_sec);
|
|
t->tm_min = bcd2bin(rtc->bcd_min);
|
|
t->tm_hour = bcd2bin(rtc->bcd_hr);
|
|
t->tm_mday = bcd2bin(rtc->bcd_dom);
|
|
t->tm_mon = bcd2bin(rtc->bcd_mth)-1;
|
|
t->tm_year = bcd2bin(rtc->bcd_year);
|
|
if (t->tm_year < 70)
|
|
t->tm_year += 100;
|
|
t->tm_wday = bcd2bin(rtc->bcd_dow)-1;
|
|
} while (t->tm_sec != bcd2bin(rtc->bcd_sec));
|
|
}
|
|
|
|
rtc->msr = msr;
|
|
|
|
return 0;
|
|
}
|
|
|
|
/*
|
|
* Set the minutes and seconds from seconds value 'nowtime'. Fail if
|
|
* clock is out by > 30 minutes. Logic lifted from atari code.
|
|
* Algorithm is to wait for the 10ms register to change, and then to
|
|
* wait a short while, and then set it.
|
|
*/
|
|
|
|
int bvme6000_set_clock_mmss (unsigned long nowtime)
|
|
{
|
|
int retval = 0;
|
|
short real_seconds = nowtime % 60, real_minutes = (nowtime / 60) % 60;
|
|
unsigned char rtc_minutes, rtc_tenms;
|
|
volatile RtcPtr_t rtc = (RtcPtr_t)BVME_RTC_BASE;
|
|
unsigned char msr = rtc->msr & 0xc0;
|
|
unsigned long flags;
|
|
volatile int i;
|
|
|
|
rtc->msr = 0; /* Ensure clock accessible */
|
|
rtc_minutes = bcd2bin (rtc->bcd_min);
|
|
|
|
if ((rtc_minutes < real_minutes
|
|
? real_minutes - rtc_minutes
|
|
: rtc_minutes - real_minutes) < 30)
|
|
{
|
|
local_irq_save(flags);
|
|
rtc_tenms = rtc->bcd_tenms;
|
|
while (rtc_tenms == rtc->bcd_tenms)
|
|
;
|
|
for (i = 0; i < 1000; i++)
|
|
;
|
|
rtc->bcd_min = bin2bcd(real_minutes);
|
|
rtc->bcd_sec = bin2bcd(real_seconds);
|
|
local_irq_restore(flags);
|
|
}
|
|
else
|
|
retval = -1;
|
|
|
|
rtc->msr = msr;
|
|
|
|
return retval;
|
|
}
|
|
|