--- /dev/null
+/*
+ * Copyright (c) 2013 Qualcomm Atheros, Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted (subject to the limitations in the
+ * disclaimer below) provided that the following conditions are met:
+ *
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ *
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the
+ * distribution.
+ *
+ * * Neither the name of Qualcomm Atheros nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * NO EXPRESS OR IMPLIED LICENSES TO ANY PARTY'S PATENT RIGHTS ARE
+ * GRANTED BY THIS LICENSE. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT
+ * HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
+ * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+#include "sys_cfg.h"
+
+#if SYSTEM_MODULE_MISC
+
+#include "athos_api.h"
+#include "regdump.h"
+
+#if SYSTEM_MODULE_USB
+extern uint16_t UsbDeviceDescriptor[];
+#endif
+
+/* This number gets bumped on each official build. */
+// uint32_t cmnos_target_software_id = AR6K_SW_VERSION;
+
+/*!
+ * system reset
+ */
+LOCAL void
+cmnos_system_reset(void)
+{
+ /* TBD: to be finished */
+ /*!
+ * sytem reset backdoor
+ */
+ HAL_WORD_REG_WRITE(MAGPIE_REG_RST_RESET_ADDR, (0x1<<24));
+}
+
+#if 0
+/*!
+ * wdt reset
+ */
+#LOCAL void cmnos_wdt_reset(void)
+{
+ HAL_WORD_REG_WRITE(MAGPIE_REG_RST_RESET_ADDR, (0x1<<24));
+}
+#endif
+
+/*!
+ * mac reset
+ */
+LOCAL void
+cmnos_mac_reset(void)
+{
+ /* TBD: to be finished */
+ /*!
+ * mac reset backdoor
+ */
+}
+
+volatile int assloop = 1;
+int assprint = 1;
+
+//A_COMPILE_TIME_ASSERT(verify_RD_SIZE, (RD_SIZE == sizeof(CPU_exception_frame_t)))
+
+LOCAL void
+cmnos_misaligned_load_handler(struct register_dump_s *dump)
+{
+ /* TBD: to be finished */
+ if (A_IML_IS_ASSERT(dump->badvaddr)) {
+ /*
+ * Probably an Intentional Misaligned Load, used to
+ * signal an assertion failure
+ */
+ dump->assline = A_IML_ASSLINE(dump->badvaddr);
+ A_ASSFAIL(dump);
+ } else {
+ /* A genuine misaligned load */
+ A_PRINTF("Misaligned load: pc=0x%x badvaddr=0x%x dump area=0x%x\n",
+ dump->pc, dump->badvaddr, dump);
+ dump->assline = 0;
+ A_ASSFAIL(dump); /* Not really an assertion failure, but we'll treat it similarly. */
+ }
+
+ // trigger wdt, in case hang
+ HAL_WORD_REG_WRITE(MAGPIE_REG_RST_WDT_TIMER_CTRL_ADDR, 0x03);
+ HAL_WORD_REG_WRITE(MAGPIE_REG_RST_WDT_TIMER_ADDR, 0x10);
+
+ while(1);
+}
+
+struct register_dump_s *current_dump = NULL;
+
+/*!
+ * A convenient place to set a breakpoint.
+ * Whenever an A_ASSERT triggers, it comes here.
+ */
+LOCAL void
+cmnos_assfail(struct register_dump_s *dump)
+{
+ if (current_dump == NULL ) {
+ A_UINT32 target_id;
+
+ current_dump = dump;
+ //A_TARGET_ID_GET(&target_id);
+ dump->target_id = target_id;
+
+ if (assprint) {
+ unsigned int i;
+
+ A_PRINTF("assertion failed? pc=0x%x, line=%d, dump area=0x%x\n",
+ dump->pc, dump->assline, dump);
+// INF_DBG2_LOG(INF_ASSERTION_FAILED, dump->pc,
+// A_IML_ASSLINE(dump->badvaddr));
+// INF_DBG1_LOG(INF_ASSERTION_FAILED, (A_UINT32)dump);
+
+ A_PRINTF("Target ID: 0x%x (%d)\n", target_id, target_id);
+// INF_DBG1_LOG(INF_TARGET_ID, target_id);
+
+ A_PRINTF("Debug Info:");
+ for (i=0; i<(sizeof(struct register_dump_s)/sizeof(A_UINT32)); i++) {
+ if ((i%4) == 0) {
+ A_PRINTF("\n");
+ }
+ A_PRINTF("0x%08x ", ((A_UINT32 *)dump)[i]);
+// INF_DBG1_LOG(INF_ASSERTION_FAILED, ((A_UINT32 *)dump)[i]);
+ }
+ A_PRINTF("\n");
+ }
+ } else {
+ /*
+ * We must have assfail'ed again while processing the first assfail.
+ * Don't try to print anything -- keep it very simple.
+ */
+
+ }
+}
+
+/*!
+ * failure state report
+ */
+LOCAL void
+cmnos_report_failure_to_host(struct register_dump_s *dump, int len)
+{
+ /* TBD: to be removed! */
+}
+
+/*!
+ * get target id
+ */
+LOCAL int
+cmnos_target_id_get(void)
+{
+ /* TBD: to be removed! */
+}
+
+/*!
+ * get keyboard hit with delay
+ */
+LOCAL uint8_t
+cmnos_get_kbhit(uint8_t delay)
+{
+ uint32_t last_ccount;
+ uint8_t kbhit;
+
+ last_ccount = xthal_get_ccount();
+ while (1)
+ {
+ if( A_GETC(&kbhit) != 0 )
+ break;
+
+ if((xthal_get_ccount() - last_ccount)>=delay*1000*ONE_MSEC)
+ {
+ break;
+ }
+ }
+
+ return kbhit;
+}
+
+/*!
+ * host alive & return the hostif type
+ */
+LOCAL A_HOSTIF
+cmnos_is_host_present(void)
+{
+ /*!
+ * TODO: check the hostif and return the type of host interface
+ */
+ A_HOSTIF mHif = HIF_USB;
+#if defined(PROJECT_K2)
+ A_PRINTF("5. usb only!!\n");
+ return mHif;
+#elif defined(PROJECT_MAGPIE)
+ uint32_t mData;
+
+ mData = MAGPIE_REG_RST_BOOTSTRAP;
+
+ //@RYAN@TODO - this one is somehow not working on L5, need to turn on!!!
+#if 1
+ /* 4:3 of BOOTSTRAP could distinguish the host interfce
+ *
+ * 2'b11 -> gmac
+ * 2'b10 -> pci
+ * 2'b01 -> pcie
+ * 2'b00 -> usb
+ *
+ */
+ if( mData & BIT3 )
+ {
+ if ( mData & BIT2 )
+ mHif = HIF_GMAC;
+ else
+ mHif = HIF_PCI;
+ }
+ else
+ {
+ if ( mData & BIT2 )
+ mHif = HIF_PCIE;
+ else
+ mHif = HIF_USB;
+ }
+#endif
+ //A_PRINTF("5. hif (0x%08x) is read!!\n", mData);
+ return mHif;
+#endif
+}
+
+/*!
+ * get ROM code version
+ */
+LOCAL uint16_t
+cmnos_rom_version_get(void)
+{
+#if SYSTEM_MODULE_USB
+ /* USB Device Descriptor : byte 12, 13 Device BCD -> Device release number in binary-coded decimal. */
+ return UsbDeviceDescriptor[6];
+#else
+ return 0;
+#endif
+}
+
+void
+cmnos_misc_module_install(struct misc_api *tbl)
+{
+ tbl->_system_reset = cmnos_system_reset;
+ tbl->_mac_reset = cmnos_mac_reset;
+ tbl->_assfail = cmnos_assfail;
+ tbl->_misaligned_load_handler= cmnos_misaligned_load_handler;
+ tbl->_report_failure_to_host = cmnos_report_failure_to_host;
+ //tbl->_target_id_get = cmnos_target_id_get;
+ tbl->_is_host_present = cmnos_is_host_present;
+ tbl->_kbhit = cmnos_get_kbhit;
+ tbl->_rom_version_get = cmnos_rom_version_get;
+}
+
+#endif
+