The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/dev/smartpqi/smartpqi_misc.c

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*-
    2  * Copyright 2016-2021 Microchip Technology, Inc. and/or its subsidiaries.
    3  *
    4  * Redistribution and use in source and binary forms, with or without
    5  * modification, are permitted provided that the following conditions
    6  * are met:
    7  * 1. Redistributions of source code must retain the above copyright
    8  *    notice, this list of conditions and the following disclaimer.
    9  * 2. Redistributions in binary form must reproduce the above copyright
   10  *    notice, this list of conditions and the following disclaimer in the
   11  *    documentation and/or other materials provided with the distribution.
   12  *
   13  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
   14  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
   15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
   16  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
   17  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
   18  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
   19  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
   20  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
   21  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
   22  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   23  * SUCH DAMAGE.
   24  */
   25 
   26 /* $FreeBSD$ */
   27 
   28 #include "smartpqi_includes.h"
   29 
   30 /*
   31  * Populate hostwellness time variables in bcd format from FreeBSD format
   32  */
   33 void
   34 os_get_time(struct bmic_host_wellness_time *host_wellness_time)
   35 {
   36         struct timespec ts;
   37         struct clocktime ct;
   38 
   39         getnanotime(&ts);
   40         clock_ts_to_ct(&ts, &ct);
   41 
   42         /* Fill the time In BCD Format */
   43         host_wellness_time->hour= (uint8_t)bin2bcd(ct.hour);
   44         host_wellness_time->min = (uint8_t)bin2bcd(ct.min);
   45         host_wellness_time->sec= (uint8_t)bin2bcd(ct.sec);
   46         host_wellness_time->reserved = 0;
   47         host_wellness_time->month = (uint8_t)bin2bcd(ct.mon);
   48         host_wellness_time->day = (uint8_t)bin2bcd(ct.day);
   49         host_wellness_time->century = (uint8_t)bin2bcd(ct.year / 100);
   50         host_wellness_time->year = (uint8_t)bin2bcd(ct.year % 100);
   51 
   52 }
   53 
   54 /*
   55  * Update host time to f/w every 24 hours in a periodic timer.
   56  */
   57 
   58 void
   59 os_wellness_periodic(void *data)
   60 {
   61         struct pqisrc_softstate *softs = (struct pqisrc_softstate *)data;
   62         int ret = 0;
   63 
   64         /* update time to FW */
   65         if (!pqisrc_ctrl_offline(softs)){
   66                 if( (ret = pqisrc_write_current_time_to_host_wellness(softs)) != 0 )
   67                         DBG_ERR("Failed to update time to FW in periodic ret = %d\n", ret);
   68         }
   69 
   70         /* reschedule ourselves */
   71         callout_reset(&softs->os_specific.wellness_periodic,
   72                         PQI_HOST_WELLNESS_TIMEOUT_SEC * hz, os_wellness_periodic, softs);
   73 }
   74 
   75 /*
   76  * Routine used to stop the heart-beat timer
   77  */
   78 void
   79 os_stop_heartbeat_timer(pqisrc_softstate_t *softs)
   80 {
   81         DBG_FUNC("IN\n");
   82 
   83         /* Kill the heart beat event */
   84         callout_stop(&softs->os_specific.heartbeat_timeout_id);
   85 
   86         DBG_FUNC("OUT\n");
   87 }
   88 
   89 /*
   90  * Routine used to start the heart-beat timer
   91  */
   92 void
   93 os_start_heartbeat_timer(void *data)
   94 {
   95         struct pqisrc_softstate *softs = (struct pqisrc_softstate *)data;
   96         DBG_FUNC("IN\n");
   97 
   98         pqisrc_heartbeat_timer_handler(softs);
   99         if (!pqisrc_ctrl_offline(softs)) {
  100                 callout_reset(&softs->os_specific.heartbeat_timeout_id,
  101                                 PQI_HEARTBEAT_TIMEOUT_SEC * hz,
  102                                 os_start_heartbeat_timer, softs);
  103         }
  104 
  105        DBG_FUNC("OUT\n");
  106 }
  107 
  108 /*
  109  * Mutex initialization function
  110  */
  111 int
  112 os_init_spinlock(struct pqisrc_softstate *softs, struct mtx *lock,
  113                         char *lockname)
  114 {
  115         mtx_init(lock, lockname, NULL, MTX_SPIN);
  116         return 0;
  117 }
  118 
  119 /*
  120  * Mutex uninitialization function
  121  */
  122 void
  123 os_uninit_spinlock(struct mtx *lock)
  124 {
  125         mtx_destroy(lock);
  126         return;
  127 }
  128 
  129 /*
  130  * Semaphore initialization function
  131  */
  132 int
  133 os_create_semaphore(const char *name, int value, struct sema *sema)
  134 {
  135         sema_init(sema, value, name);
  136         return PQI_STATUS_SUCCESS;
  137 }
  138 
  139 /*
  140  * Semaphore uninitialization function
  141  */
  142 int
  143 os_destroy_semaphore(struct sema *sema)
  144 {
  145         sema_destroy(sema);
  146         return PQI_STATUS_SUCCESS;
  147 }
  148 
  149 /*
  150  * Semaphore grab function
  151  */
  152 void inline
  153 os_sema_lock(struct sema *sema)
  154 {
  155         sema_post(sema);
  156 }
  157 
  158 /*
  159  * Semaphore release function
  160  */
  161 void inline
  162 os_sema_unlock(struct sema *sema)
  163 {
  164         sema_wait(sema);
  165 }
  166 
  167 /*
  168  * string copy wrapper function
  169  */
  170 int
  171 os_strlcpy(char *dst, char *src, int size)
  172 {
  173         return strlcpy(dst, src, size);
  174 }
  175 
  176 int
  177 bsd_status_to_pqi_status(int bsd_status)
  178 {
  179         if (bsd_status == BSD_SUCCESS)
  180                 return PQI_STATUS_SUCCESS;
  181         else
  182                 return PQI_STATUS_FAILURE;
  183 }

Cache object: 4cd09118bc6f237dbd3225c8b1d86d47


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.