sa1100_generic.c
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:34k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. /*======================================================================
  2.     Device driver for the PCMCIA control functionality of StrongARM
  3.     SA-1100 microprocessors.
  4.     The contents of this file are subject to the Mozilla Public
  5.     License Version 1.1 (the "License"); you may not use this file
  6.     except in compliance with the License. You may obtain a copy of
  7.     the License at http://www.mozilla.org/MPL/
  8.     Software distributed under the License is distributed on an "AS
  9.     IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
  10.     implied. See the License for the specific language governing
  11.     rights and limitations under the License.
  12.     The initial developer of the original code is John G. Dorsey
  13.     <john+@cs.cmu.edu>.  Portions created by John G. Dorsey are
  14.     Copyright (C) 1999 John G. Dorsey.  All Rights Reserved.
  15.     Alternatively, the contents of this file may be used under the
  16.     terms of the GNU Public License version 2 (the "GPL"), in which
  17.     case the provisions of the GPL are applicable instead of the
  18.     above.  If you wish to allow the use of your version of this file
  19.     only under the terms of the GPL and not to allow others to use
  20.     your version of this file under the MPL, indicate your decision
  21.     by deleting the provisions above and replace them with the notice
  22.     and other provisions required by the GPL.  If you do not delete
  23.     the provisions above, a recipient may use your version of this
  24.     file under either the MPL or the GPL.
  25.     
  26. ======================================================================*/
  27. /*
  28.  * Please see linux/Documentation/arm/SA1100/PCMCIA for more information
  29.  * on the low-level kernel interface.
  30.  */
  31. #include <linux/module.h>
  32. #include <linux/init.h>
  33. #include <linux/config.h>
  34. #include <linux/cpufreq.h>
  35. #include <linux/delay.h>
  36. #include <linux/ioport.h>
  37. #include <linux/kernel.h>
  38. #include <linux/tqueue.h>
  39. #include <linux/timer.h>
  40. #include <linux/mm.h>
  41. #include <linux/notifier.h>
  42. #include <linux/proc_fs.h>
  43. #include <linux/version.h>
  44. #include <linux/cpufreq.h>
  45. #include <pcmcia/version.h>
  46. #include <pcmcia/cs_types.h>
  47. #include <pcmcia/cs.h>
  48. #include <pcmcia/ss.h>
  49. #include <pcmcia/bus_ops.h>
  50. #include <asm/hardware.h>
  51. #include <asm/io.h>
  52. #include <asm/irq.h>
  53. #include <asm/system.h>
  54. #include <asm/arch/assabet.h>
  55. #include "sa1100.h"
  56. #ifdef PCMCIA_DEBUG
  57. static int pc_debug;
  58. #endif
  59. /* This structure maintains housekeeping state for each socket, such
  60.  * as the last known values of the card detect pins, or the Card Services
  61.  * callback value associated with the socket:
  62.  */
  63. static int sa1100_pcmcia_socket_count;
  64. static struct sa1100_pcmcia_socket sa1100_pcmcia_socket[SA1100_PCMCIA_MAX_SOCK];
  65. #define PCMCIA_SOCKET(x) (sa1100_pcmcia_socket + (x))
  66. /* Returned by the low-level PCMCIA interface: */
  67. static struct pcmcia_low_level *pcmcia_low_level;
  68. static struct timer_list poll_timer;
  69. static struct tq_struct sa1100_pcmcia_task;
  70. /*
  71.  * sa1100_pcmcia_state_to_config
  72.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  73.  *
  74.  * Convert PCMCIA socket state to our socket configure structure.
  75.  */
  76. static struct pcmcia_configure
  77. sa1100_pcmcia_state_to_config(unsigned int sock, socket_state_t *state)
  78. {
  79.   struct pcmcia_configure conf;
  80.   conf.sock    = sock;
  81.   conf.vcc     = state->Vcc;
  82.   conf.vpp     = state->Vpp;
  83.   conf.output  = state->flags & SS_OUTPUT_ENA ? 1 : 0;
  84.   conf.speaker = state->flags & SS_SPKR_ENA ? 1 : 0;
  85.   conf.reset   = state->flags & SS_RESET ? 1 : 0;
  86.   conf.irq     = state->io_irq != 0;
  87.   return conf;
  88. }
  89. /* sa1100_pcmcia_init()
  90.  * ^^^^^^^^^^^^^^^^^^^^
  91.  *
  92.  * (Re-)Initialise the socket, turning on status interrupts
  93.  * and PCMCIA bus.  This must wait for power to stabilise
  94.  * so that the card status signals report correctly.
  95.  *
  96.  * Returns: 0
  97.  */
  98. static int sa1100_pcmcia_init(unsigned int sock)
  99. {
  100.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  101.   struct pcmcia_configure conf;
  102.   DEBUG(2, "%s(): initializing socket %un", __FUNCTION__, sock);
  103.   skt->cs_state = dead_socket;
  104.   conf = sa1100_pcmcia_state_to_config(sock, &dead_socket);
  105.   pcmcia_low_level->configure_socket(&conf);
  106.   return pcmcia_low_level->socket_init(sock);
  107. }
  108. /*
  109.  * sa1100_pcmcia_suspend()
  110.  * ^^^^^^^^^^^^^^^^^^^^^^^
  111.  *
  112.  * Remove power on the socket, disable IRQs from the card.
  113.  * Turn off status interrupts, and disable the PCMCIA bus.
  114.  *
  115.  * Returns: 0
  116.  */
  117. static int sa1100_pcmcia_suspend(unsigned int sock)
  118. {
  119.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  120.   struct pcmcia_configure conf;
  121.   int ret;
  122.   DEBUG(2, "%s(): suspending socket %un", __FUNCTION__, sock);
  123.   conf = sa1100_pcmcia_state_to_config(sock, &dead_socket);
  124.   ret = pcmcia_low_level->configure_socket(&conf);
  125.   if (ret == 0) {
  126.     skt->cs_state = dead_socket;
  127.     ret = pcmcia_low_level->socket_suspend(sock);
  128.   }
  129.   return ret;
  130. }
  131. /* sa1100_pcmcia_events()
  132.  * ^^^^^^^^^^^^^^^^^^^^^^
  133.  * Helper routine to generate a Card Services event mask based on
  134.  * state information obtained from the kernel low-level PCMCIA layer
  135.  * in a recent (and previous) sampling. Updates `prev_state'.
  136.  *
  137.  * Returns: an event mask for the given socket state.
  138.  */
  139. static inline unsigned int
  140. sa1100_pcmcia_events(struct pcmcia_state *state,
  141.      struct pcmcia_state *prev_state,
  142.      unsigned int mask, unsigned int flags)
  143. {
  144.   unsigned int events = 0;
  145.   if (state->detect != prev_state->detect) {
  146.     DEBUG(3, "%s(): card detect value %un", __FUNCTION__, state->detect);
  147.     events |= SS_DETECT;
  148.   }
  149.   if (state->ready != prev_state->ready) {
  150.     DEBUG(3, "%s(): card ready value %un", __FUNCTION__, state->ready);
  151.     events |= flags & SS_IOCARD ? 0 : SS_READY;
  152.   }
  153.   if (state->bvd1 != prev_state->bvd1) {
  154.     DEBUG(3, "%s(): card BVD1 value %un", __FUNCTION__, state->bvd1);
  155.     events |= flags & SS_IOCARD ? SS_STSCHG : SS_BATDEAD;
  156.   }
  157.   if (state->bvd2 != prev_state->bvd2) {
  158.     DEBUG(3, "%s(): card BVD2 value %un", __FUNCTION__, state->bvd2);
  159.     events |= flags & SS_IOCARD ? 0 : SS_BATWARN;
  160.   }
  161.   *prev_state = *state;
  162.   events &= mask;
  163.   DEBUG(2, "events: %s%s%s%s%s%sn",
  164. events == 0         ? "<NONE>"   : "",
  165. events & SS_DETECT  ? "DETECT "  : "",
  166. events & SS_READY   ? "READY "   : "",
  167. events & SS_BATDEAD ? "BATDEAD " : "",
  168. events & SS_BATWARN ? "BATWARN " : "",
  169. events & SS_STSCHG  ? "STSCHG "  : "");
  170.   return events;
  171. }  /* sa1100_pcmcia_events() */
  172. /* sa1100_pcmcia_task_handler()
  173.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  174.  * Processes serviceable socket events using the "eventd" thread context.
  175.  *
  176.  * Event processing (specifically, the invocation of the Card Services event
  177.  * callback) occurs in this thread rather than in the actual interrupt
  178.  * handler due to the use of scheduling operations in the PCMCIA core.
  179.  */
  180. static void sa1100_pcmcia_task_handler(void *data)
  181. {
  182.   struct pcmcia_state state[SA1100_PCMCIA_MAX_SOCK];
  183.   struct pcmcia_state_array state_array;
  184.   unsigned int all_events;
  185.   DEBUG(4, "%s(): entering PCMCIA monitoring threadn", __FUNCTION__);
  186.   state_array.size = sa1100_pcmcia_socket_count;
  187.   state_array.state = state;
  188.   do {
  189.     unsigned int events;
  190.     int ret, i;
  191.     memset(state, 0, sizeof(state));
  192.     DEBUG(4, "%s(): interrogating low-level PCMCIA servicen", __FUNCTION__);
  193.     ret = pcmcia_low_level->socket_state(&state_array);
  194.     if (ret < 0) {
  195.       printk(KERN_ERR "sa1100_pcmcia: unable to read socket statusn");
  196.       break;
  197.     }
  198.     all_events = 0;
  199.     for (i = 0; i < state_array.size; i++, all_events |= events) {
  200.       struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(i);
  201.       events = sa1100_pcmcia_events(&state[i], &skt->k_state,
  202.     skt->cs_state.csc_mask,
  203.     skt->cs_state.flags);
  204.       if (events && sa1100_pcmcia_socket[i].handler != NULL)
  205. skt->handler(skt->handler_info, events);
  206.     }
  207.   } while(all_events);
  208. }  /* sa1100_pcmcia_task_handler() */
  209. static struct tq_struct sa1100_pcmcia_task = {
  210. routine: sa1100_pcmcia_task_handler
  211. };
  212. /* sa1100_pcmcia_poll_event()
  213.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^
  214.  * Let's poll for events in addition to IRQs since IRQ only is unreliable...
  215.  */
  216. static void sa1100_pcmcia_poll_event(unsigned long dummy)
  217. {
  218.   DEBUG(4, "%s(): polling for eventsn", __FUNCTION__);
  219.   poll_timer.function = sa1100_pcmcia_poll_event;
  220.   poll_timer.expires = jiffies + SA1100_PCMCIA_POLL_PERIOD;
  221.   add_timer(&poll_timer);
  222.   schedule_task(&sa1100_pcmcia_task);
  223. }
  224. /* sa1100_pcmcia_interrupt()
  225.  * ^^^^^^^^^^^^^^^^^^^^^^^^^
  226.  * Service routine for socket driver interrupts (requested by the
  227.  * low-level PCMCIA init() operation via sa1100_pcmcia_thread()).
  228.  * The actual interrupt-servicing work is performed by
  229.  * sa1100_pcmcia_thread(), largely because the Card Services event-
  230.  * handling code performs scheduling operations which cannot be
  231.  * executed from within an interrupt context.
  232.  */
  233. static void sa1100_pcmcia_interrupt(int irq, void *dev, struct pt_regs *regs)
  234. {
  235.   DEBUG(3, "%s(): servicing IRQ %dn", __FUNCTION__, irq);
  236.   schedule_task(&sa1100_pcmcia_task);
  237. }
  238. /* sa1100_pcmcia_register_callback()
  239.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  240.  * Implements the register_callback() operation for the in-kernel
  241.  * PCMCIA service (formerly SS_RegisterCallback in Card Services). If 
  242.  * the function pointer `handler' is not NULL, remember the callback 
  243.  * location in the state for `sock', and increment the usage counter 
  244.  * for the driver module. (The callback is invoked from the interrupt
  245.  * service routine, sa1100_pcmcia_interrupt(), to notify Card Services
  246.  * of interesting events.) Otherwise, clear the callback pointer in the
  247.  * socket state and decrement the module usage count.
  248.  *
  249.  * Returns: 0
  250.  */
  251. static int
  252. sa1100_pcmcia_register_callback(unsigned int sock,
  253. void (*handler)(void *, unsigned int),
  254. void *info)
  255. {
  256.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  257.   if (handler == NULL) {
  258.     skt->handler = NULL;
  259.     MOD_DEC_USE_COUNT;
  260.   } else {
  261.     MOD_INC_USE_COUNT;
  262.     skt->handler_info = info;
  263.     skt->handler = handler;
  264.   }
  265.   return 0;
  266. }
  267. /* sa1100_pcmcia_inquire_socket()
  268.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  269.  * Implements the inquire_socket() operation for the in-kernel PCMCIA
  270.  * service (formerly SS_InquireSocket in Card Services). Of note is
  271.  * the setting of the SS_CAP_PAGE_REGS bit in the `features' field of
  272.  * `cap' to "trick" Card Services into tolerating large "I/O memory" 
  273.  * addresses. Also set is SS_CAP_STATIC_MAP, which disables the memory
  274.  * resource database check. (Mapped memory is set up within the socket
  275.  * driver itself.)
  276.  *
  277.  * In conjunction with the STATIC_MAP capability is a new field,
  278.  * `io_offset', recommended by David Hinds. Rather than go through
  279.  * the SetIOMap interface (which is not quite suited for communicating
  280.  * window locations up from the socket driver), we just pass up
  281.  * an offset which is applied to client-requested base I/O addresses
  282.  * in alloc_io_space().
  283.  *
  284.  * SS_CAP_PAGE_REGS: used by setup_cis_mem() in cistpl.c to set the
  285.  *   force_low argument to validate_mem() in rsrc_mgr.c -- since in
  286.  *   general, the mapped * addresses of the PCMCIA memory regions
  287.  *   will not be within 0xffff, setting force_low would be
  288.  *   undesirable.
  289.  *
  290.  * SS_CAP_STATIC_MAP: don't bother with the (user-configured) memory
  291.  *   resource database; we instead pass up physical address ranges
  292.  *   and allow other parts of Card Services to deal with remapping.
  293.  *
  294.  * SS_CAP_PCCARD: we can deal with 16-bit PCMCIA & CF cards, but
  295.  *   not 32-bit CardBus devices.
  296.  *
  297.  * Return value is irrelevant; the pcmcia subsystem ignores it.
  298.  */
  299. static int
  300. sa1100_pcmcia_inquire_socket(unsigned int sock, socket_cap_t *cap)
  301. {
  302.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  303.   int ret = -1;
  304.   DEBUG(2, "%s() for sock %un", __FUNCTION__, sock);
  305.   if (sock < sa1100_pcmcia_socket_count) {
  306.     cap->features  = SS_CAP_PAGE_REGS | SS_CAP_STATIC_MAP | SS_CAP_PCCARD;
  307.     cap->irq_mask  = 0;
  308.     cap->map_size  = PAGE_SIZE;
  309.     cap->pci_irq   = skt->irq;
  310.     cap->io_offset = (unsigned long)skt->virt_io;
  311.     ret = 0;
  312.   }
  313.   return ret;
  314. }
  315. /* sa1100_pcmcia_get_status()
  316.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^
  317.  * Implements the get_status() operation for the in-kernel PCMCIA
  318.  * service (formerly SS_GetStatus in Card Services). Essentially just
  319.  * fills in bits in `status' according to internal driver state or
  320.  * the value of the voltage detect chipselect register.
  321.  *
  322.  * As a debugging note, during card startup, the PCMCIA core issues
  323.  * three set_socket() commands in a row the first with RESET deasserted,
  324.  * the second with RESET asserted, and the last with RESET deasserted
  325.  * again. Following the third set_socket(), a get_status() command will
  326.  * be issued. The kernel is looking for the SS_READY flag (see
  327.  * setup_socket(), reset_socket(), and unreset_socket() in cs.c).
  328.  *
  329.  * Returns: 0
  330.  */
  331. static int
  332. sa1100_pcmcia_get_status(unsigned int sock, unsigned int *status)
  333. {
  334.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  335.   struct pcmcia_state state[SA1100_PCMCIA_MAX_SOCK];
  336.   struct pcmcia_state_array state_array;
  337.   unsigned int stat;
  338.   DEBUG(2, "%s() for sock %un", __FUNCTION__, sock);
  339.   state_array.size = sa1100_pcmcia_socket_count;
  340.   state_array.state = state;
  341.   memset(state, 0, sizeof(state));
  342.   if ((pcmcia_low_level->socket_state(&state_array)) < 0) {
  343.     printk(KERN_ERR "sa1100_pcmcia: unable to get socket statusn");
  344.     return -1;
  345.   }
  346.   skt->k_state = state[sock];
  347.   stat = state[sock].detect ? SS_DETECT : 0;
  348.   stat |= state[sock].ready ? SS_READY  : 0;
  349.   stat |= state[sock].vs_3v ? SS_3VCARD : 0;
  350.   stat |= state[sock].vs_Xv ? SS_XVCARD : 0;
  351.   /* The power status of individual sockets is not available
  352.    * explicitly from the hardware, so we just remember the state
  353.    * and regurgitate it upon request:
  354.    */
  355.   stat |= skt->cs_state.Vcc ? SS_POWERON : 0;
  356.   if (skt->cs_state.flags & SS_IOCARD)
  357.     stat |= state[sock].bvd1 ? SS_STSCHG : 0;
  358.   else {
  359.     if (state[sock].bvd1 == 0)
  360.       stat |= SS_BATDEAD;
  361.     else if (state[sock].bvd2 == 0)
  362.       stat |= SS_BATWARN;
  363.   }
  364.   DEBUG(3, "tstatus: %s%s%s%s%s%s%s%sn",
  365. stat & SS_DETECT  ? "DETECT "  : "",
  366. stat & SS_READY   ? "READY "   : "", 
  367. stat & SS_BATDEAD ? "BATDEAD " : "",
  368. stat & SS_BATWARN ? "BATWARN " : "",
  369. stat & SS_POWERON ? "POWERON " : "",
  370. stat & SS_STSCHG  ? "STSCHG "  : "",
  371. stat & SS_3VCARD  ? "3VCARD "  : "",
  372. stat & SS_XVCARD  ? "XVCARD "  : "");
  373.   *status = stat;
  374.   return 0;
  375. }  /* sa1100_pcmcia_get_status() */
  376. /* sa1100_pcmcia_get_socket()
  377.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^
  378.  * Implements the get_socket() operation for the in-kernel PCMCIA
  379.  * service (formerly SS_GetSocket in Card Services). Not a very 
  380.  * exciting routine.
  381.  *
  382.  * Returns: 0
  383.  */
  384. static int
  385. sa1100_pcmcia_get_socket(unsigned int sock, socket_state_t *state)
  386. {
  387.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  388.   DEBUG(2, "%s() for sock %un", __FUNCTION__, sock);
  389.   *state = skt->cs_state;
  390.   return 0;
  391. }
  392. /* sa1100_pcmcia_set_socket()
  393.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^
  394.  * Implements the set_socket() operation for the in-kernel PCMCIA
  395.  * service (formerly SS_SetSocket in Card Services). We more or
  396.  * less punt all of this work and let the kernel handle the details
  397.  * of power configuration, reset, &c. We also record the value of
  398.  * `state' in order to regurgitate it to the PCMCIA core later.
  399.  *
  400.  * Returns: 0
  401.  */
  402. static int
  403. sa1100_pcmcia_set_socket(unsigned int sock, socket_state_t *state)
  404. {
  405.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  406.   struct pcmcia_configure conf;
  407.   DEBUG(2, "%s() for sock %un", __FUNCTION__, sock);
  408.   DEBUG(3, "tmask:  %s%s%s%s%s%sntflags: %s%s%s%s%s%sn",
  409. (state->csc_mask==0)?"<NONE>":"",
  410. (state->csc_mask&SS_DETECT)?"DETECT ":"",
  411. (state->csc_mask&SS_READY)?"READY ":"",
  412. (state->csc_mask&SS_BATDEAD)?"BATDEAD ":"",
  413. (state->csc_mask&SS_BATWARN)?"BATWARN ":"",
  414. (state->csc_mask&SS_STSCHG)?"STSCHG ":"",
  415. (state->flags==0)?"<NONE>":"",
  416. (state->flags&SS_PWR_AUTO)?"PWR_AUTO ":"",
  417. (state->flags&SS_IOCARD)?"IOCARD ":"",
  418. (state->flags&SS_RESET)?"RESET ":"",
  419. (state->flags&SS_SPKR_ENA)?"SPKR_ENA ":"",
  420. (state->flags&SS_OUTPUT_ENA)?"OUTPUT_ENA ":"");
  421.   DEBUG(3, "tVcc %d  Vpp %d  irq %dn",
  422. state->Vcc, state->Vpp, state->io_irq);
  423.   conf = sa1100_pcmcia_state_to_config(sock, state);
  424.   if (pcmcia_low_level->configure_socket(&conf) < 0) {
  425.     printk(KERN_ERR "sa1100_pcmcia: unable to configure socket %dn", sock);
  426.     return -1;
  427.   }
  428.   skt->cs_state = *state;
  429.   
  430.   return 0;
  431. }  /* sa1100_pcmcia_set_socket() */
  432. /* sa1100_pcmcia_get_io_map()
  433.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^
  434.  * Implements the get_io_map() operation for the in-kernel PCMCIA
  435.  * service (formerly SS_GetIOMap in Card Services). Just returns an
  436.  * I/O map descriptor which was assigned earlier by a set_io_map().
  437.  *
  438.  * Returns: 0 on success, -1 if the map index was out of range
  439.  */
  440. static int
  441. sa1100_pcmcia_get_io_map(unsigned int sock, struct pccard_io_map *map)
  442. {
  443.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  444.   int ret = -1;
  445.   DEBUG(2, "%s() for sock %un", __FUNCTION__, sock);
  446.   if (map->map < MAX_IO_WIN) {
  447.     *map = skt->io_map[map->map];
  448.     ret = 0;
  449.   }
  450.   return ret;
  451. }
  452. /* sa1100_pcmcia_set_io_map()
  453.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^
  454.  * Implements the set_io_map() operation for the in-kernel PCMCIA
  455.  * service (formerly SS_SetIOMap in Card Services). We configure
  456.  * the map speed as requested, but override the address ranges
  457.  * supplied by Card Services.
  458.  *
  459.  * Returns: 0 on success, -1 on error
  460.  */
  461. static int
  462. sa1100_pcmcia_set_io_map(unsigned int sock, struct pccard_io_map *map)
  463. {
  464.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  465.   DEBUG(2, "%s() for sock %un", __FUNCTION__, sock);
  466.   DEBUG(3, "tmap %u  speed %untstart 0x%08x  stop 0x%08xn",
  467. map->map, map->speed, map->start, map->stop);
  468.   DEBUG(3, "tflags: %s%s%s%s%s%s%s%sn",
  469. (map->flags==0)?"<NONE>":"",
  470. (map->flags&MAP_ACTIVE)?"ACTIVE ":"",
  471. (map->flags&MAP_16BIT)?"16BIT ":"",
  472. (map->flags&MAP_AUTOSZ)?"AUTOSZ ":"",
  473. (map->flags&MAP_0WS)?"0WS ":"",
  474. (map->flags&MAP_WRPROT)?"WRPROT ":"",
  475. (map->flags&MAP_USE_WAIT)?"USE_WAIT ":"",
  476. (map->flags&MAP_PREFETCH)?"PREFETCH ":"");
  477.   if (map->map >= MAX_IO_WIN) {
  478.     printk(KERN_ERR "%s(): map (%d) out of rangen", __FUNCTION__,
  479.    map->map);
  480.     return -1;
  481.   }
  482.   if (map->flags & MAP_ACTIVE) {
  483.     unsigned int clock, speed = map->speed;
  484.     unsigned long mecr;
  485.     if (speed == 0)
  486.       speed = SA1100_PCMCIA_IO_ACCESS;
  487.     clock = cpufreq_get(0);
  488.     mecr = MECR;
  489.     MECR_BSIO_SET(mecr, sock, sa1100_pcmcia_mecr_bs(speed, clock));
  490.     skt->speed_io = speed;
  491.     DEBUG(4, "%s(): FAST%u %lx  BSM%u %lx  BSA%u %lx  BSIO%u %lxn",
  492.   __FUNCTION__, sock, MECR_FAST_GET(mecr, sock), sock,
  493.   MECR_BSM_GET(mecr, sock), sock, MECR_BSA_GET(mecr, sock), 
  494.   sock, MECR_BSIO_GET(mecr, sock));
  495.     MECR = mecr;
  496.   }
  497.   if (map->stop == 1)
  498.     map->stop = PAGE_SIZE-1;
  499.   map->stop -= map->start;
  500.   map->stop += (unsigned long)skt->virt_io;
  501.   map->start = (unsigned long)skt->virt_io;
  502.   skt->io_map[map->map] = *map;
  503.   return 0;
  504. }  /* sa1100_pcmcia_set_io_map() */
  505. /* sa1100_pcmcia_get_mem_map()
  506.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^^
  507.  * Implements the get_mem_map() operation for the in-kernel PCMCIA
  508.  * service (formerly SS_GetMemMap in Card Services). Just returns a
  509.  *  memory map descriptor which was assigned earlier by a
  510.  *  set_mem_map() request.
  511.  *
  512.  * Returns: 0 on success, -1 if the map index was out of range
  513.  */
  514. static int
  515. sa1100_pcmcia_get_mem_map(unsigned int sock, struct pccard_mem_map *map)
  516. {
  517.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  518.   int ret = -1;
  519.   DEBUG(2, "%s() for sock %un", __FUNCTION__, sock);
  520.   if (map->map < MAX_WIN) {
  521.     *map = skt->mem_map[map->map];
  522.     ret = 0;
  523.   }
  524.   return ret;
  525. }
  526. /* sa1100_pcmcia_set_mem_map()
  527.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^^
  528.  * Implements the set_mem_map() operation for the in-kernel PCMCIA
  529.  * service (formerly SS_SetMemMap in Card Services). We configure
  530.  * the map speed as requested, but override the address ranges
  531.  * supplied by Card Services.
  532.  *
  533.  * Returns: 0 on success, -1 on error
  534.  */
  535. static int
  536. sa1100_pcmcia_set_mem_map(unsigned int sock, struct pccard_mem_map *map)
  537. {
  538.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  539.   unsigned long start;
  540.   DEBUG(2, "%s() for sock %un", __FUNCTION__, sock);
  541.   DEBUG(3, "tmap %u speed %u sys_start %08lx sys_stop %08lx card_start %08xn",
  542. map->map, map->speed, map->sys_start, map->sys_stop, map->card_start);
  543.   DEBUG(3, "tflags: %s%s%s%s%s%s%s%sn",
  544. (map->flags==0)?"<NONE>":"",
  545. (map->flags&MAP_ACTIVE)?"ACTIVE ":"",
  546. (map->flags&MAP_16BIT)?"16BIT ":"",
  547. (map->flags&MAP_AUTOSZ)?"AUTOSZ ":"",
  548. (map->flags&MAP_0WS)?"0WS ":"",
  549. (map->flags&MAP_WRPROT)?"WRPROT ":"",
  550. (map->flags&MAP_ATTRIB)?"ATTRIB ":"",
  551. (map->flags&MAP_USE_WAIT)?"USE_WAIT ":"");
  552.   if (map->map >= MAX_WIN){
  553.     printk(KERN_ERR "%s(): map (%d) out of rangen", __FUNCTION__,
  554.    map->map);
  555.     return -1;
  556.   }
  557.   if (map->flags & MAP_ACTIVE) {
  558.     unsigned int clock, speed = map->speed;
  559.     unsigned long mecr;
  560.     /*
  561.      * When clients issue RequestMap, the access speed is not always
  562.      * properly configured.  Choose some sensible defaults.
  563.      */
  564.     if (speed == 0) {
  565.       if (skt->cs_state.Vcc == 33)
  566. speed = SA1100_PCMCIA_3V_MEM_ACCESS;
  567.       else
  568. speed = SA1100_PCMCIA_5V_MEM_ACCESS;
  569.     }
  570.     clock = cpufreq_get(0);
  571.     /* Fixme: MECR is not pre-empt safe. */
  572.     mecr = MECR;
  573.     if (map->flags & MAP_ATTRIB) {
  574.       MECR_BSA_SET(mecr, sock, sa1100_pcmcia_mecr_bs(speed, clock));
  575.       skt->speed_attr = speed;
  576.     } else {
  577.       MECR_BSM_SET(mecr, sock, sa1100_pcmcia_mecr_bs(speed, clock));
  578.       skt->speed_mem = speed;
  579.     }
  580.     DEBUG(4, "%s(): FAST%u %lx  BSM%u %lx  BSA%u %lx  BSIO%u %lxn",
  581.   __FUNCTION__, sock, MECR_FAST_GET(mecr, sock), sock,
  582.   MECR_BSM_GET(mecr, sock), sock, MECR_BSA_GET(mecr, sock), 
  583.   sock, MECR_BSIO_GET(mecr, sock));
  584.     MECR = mecr;
  585.   }
  586.   start = (map->flags & MAP_ATTRIB) ? skt->phys_attr : skt->phys_mem;
  587.   if (map->sys_stop == 0)
  588.     map->sys_stop = PAGE_SIZE-1;
  589.   map->sys_stop -= map->sys_start;
  590.   map->sys_stop += start;
  591.   map->sys_start = start;
  592.   skt->mem_map[map->map] = *map;
  593.   return 0;
  594. }  /* sa1100_pcmcia_set_mem_map() */
  595. #if defined(CONFIG_PROC_FS)
  596. /* sa1100_pcmcia_proc_status()
  597.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^^
  598.  * Implements the /proc/bus/pccard/??/status file.
  599.  *
  600.  * Returns: the number of characters added to the buffer
  601.  */
  602. static int
  603. sa1100_pcmcia_proc_status(char *buf, char **start, off_t pos,
  604.   int count, int *eof, void *data)
  605. {
  606.   unsigned int sock = (unsigned int)data;
  607.   unsigned int clock = cpufreq_get(0);
  608.   struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(sock);
  609.   unsigned long mecr = MECR;
  610.   char *p = buf;
  611.   p+=sprintf(p, "k_state  : %s%s%s%s%s%s%sn", 
  612.      skt->k_state.detect ? "detect " : "",
  613.      skt->k_state.ready  ? "ready "  : "",
  614.      skt->k_state.bvd1   ? "bvd1 "   : "",
  615.      skt->k_state.bvd2   ? "bvd2 "   : "",
  616.      skt->k_state.wrprot ? "wrprot " : "",
  617.      skt->k_state.vs_3v  ? "vs_3v "  : "",
  618.      skt->k_state.vs_Xv  ? "vs_Xv "  : "");
  619.   p+=sprintf(p, "status   : %s%s%s%s%s%s%s%s%sn",
  620.      skt->k_state.detect ? "SS_DETECT " : "",
  621.      skt->k_state.ready  ? "SS_READY " : "",
  622.      skt->cs_state.Vcc   ? "SS_POWERON " : "",
  623.      skt->cs_state.flags & SS_IOCARD ? "SS_IOCARD " : "",
  624.      (skt->cs_state.flags & SS_IOCARD &&
  625.       skt->k_state.bvd1) ? "SS_STSCHG " : "",
  626.      ((skt->cs_state.flags & SS_IOCARD)==0 &&
  627.       (skt->k_state.bvd1==0)) ? "SS_BATDEAD " : "",
  628.      ((skt->cs_state.flags & SS_IOCARD)==0 &&
  629.       (skt->k_state.bvd2==0)) ? "SS_BATWARN " : "",
  630.      skt->k_state.vs_3v  ? "SS_3VCARD " : "",
  631.      skt->k_state.vs_Xv  ? "SS_XVCARD " : "");
  632.   p+=sprintf(p, "mask     : %s%s%s%s%sn",
  633.      skt->cs_state.csc_mask & SS_DETECT  ? "SS_DETECT "  : "",
  634.      skt->cs_state.csc_mask & SS_READY   ? "SS_READY "   : "",
  635.      skt->cs_state.csc_mask & SS_BATDEAD ? "SS_BATDEAD " : "",
  636.      skt->cs_state.csc_mask & SS_BATWARN ? "SS_BATWARN " : "",
  637.      skt->cs_state.csc_mask & SS_STSCHG  ? "SS_STSCHG "  : "");
  638.   p+=sprintf(p, "cs_flags : %s%s%s%s%sn",
  639.      skt->cs_state.flags & SS_PWR_AUTO   ? "SS_PWR_AUTO "   : "",
  640.      skt->cs_state.flags & SS_IOCARD     ? "SS_IOCARD "     : "",
  641.      skt->cs_state.flags & SS_RESET      ? "SS_RESET "      : "",
  642.      skt->cs_state.flags & SS_SPKR_ENA   ? "SS_SPKR_ENA "   : "",
  643.      skt->cs_state.flags & SS_OUTPUT_ENA ? "SS_OUTPUT_ENA " : "");
  644.   p+=sprintf(p, "Vcc      : %dn", skt->cs_state.Vcc);
  645.   p+=sprintf(p, "Vpp      : %dn", skt->cs_state.Vpp);
  646.   p+=sprintf(p, "IRQ      : %dn", skt->cs_state.io_irq);
  647.   p+=sprintf(p, "I/O      : %u (%u)n", skt->speed_io,
  648.      sa1100_pcmcia_cmd_time(clock, MECR_BSIO_GET(mecr, sock)));
  649.   p+=sprintf(p, "attribute: %u (%u)n", skt->speed_attr,
  650.      sa1100_pcmcia_cmd_time(clock, MECR_BSA_GET(mecr, sock)));
  651.   p+=sprintf(p, "common   : %u (%u)n", skt->speed_mem,
  652.      sa1100_pcmcia_cmd_time(clock, MECR_BSM_GET(mecr, sock)));
  653.   return p-buf;
  654. }
  655. /* sa1100_pcmcia_proc_setup()
  656.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^
  657.  * Implements the proc_setup() operation for the in-kernel PCMCIA
  658.  * service (formerly SS_ProcSetup in Card Services).
  659.  *
  660.  * Returns: 0 on success, -1 on error
  661.  */
  662. static void
  663. sa1100_pcmcia_proc_setup(unsigned int sock, struct proc_dir_entry *base)
  664. {
  665.   struct proc_dir_entry *entry;
  666.   DEBUG(4, "%s() for sock %un", __FUNCTION__, sock);
  667.   if ((entry = create_proc_entry("status", 0, base)) == NULL){
  668.     printk(KERN_ERR "unable to install "status" procfs entryn");
  669.     return;
  670.   }
  671.   entry->read_proc = sa1100_pcmcia_proc_status;
  672.   entry->data = (void *)sock;
  673. }
  674. #endif  /* defined(CONFIG_PROC_FS) */
  675. static struct pccard_operations sa1100_pcmcia_operations = {
  676.   init: sa1100_pcmcia_init,
  677.   suspend: sa1100_pcmcia_suspend,
  678.   register_callback: sa1100_pcmcia_register_callback,
  679.   inquire_socket: sa1100_pcmcia_inquire_socket,
  680.   get_status: sa1100_pcmcia_get_status,
  681.   get_socket: sa1100_pcmcia_get_socket,
  682.   set_socket: sa1100_pcmcia_set_socket,
  683.   get_io_map: sa1100_pcmcia_get_io_map,
  684.   set_io_map: sa1100_pcmcia_set_io_map,
  685.   get_mem_map: sa1100_pcmcia_get_mem_map,
  686.   set_mem_map: sa1100_pcmcia_set_mem_map,
  687. #ifdef CONFIG_PROC_FS
  688.   proc_setup: sa1100_pcmcia_proc_setup
  689. #endif
  690. };
  691. #ifdef CONFIG_CPU_FREQ
  692. /* sa1100_pcmcia_update_mecr()
  693.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^^
  694.  * When sa1100_pcmcia_notifier() decides that a MECR adjustment (due
  695.  * to a core clock frequency change) is needed, this routine establishes
  696.  * new BS_xx values consistent with the clock speed `clock'.
  697.  */
  698. static void sa1100_pcmcia_update_mecr(unsigned int clock)
  699. {
  700.   unsigned int sock;
  701.   unsigned long mecr = MECR;
  702.   for(sock = 0; sock < SA1100_PCMCIA_MAX_SOCK; ++sock){
  703.     MECR_BSIO_SET(mecr, sock,
  704.   sa1100_pcmcia_mecr_bs(sa1100_pcmcia_socket[sock].speed_io,
  705. clock));
  706.     MECR_BSA_SET(mecr, sock,
  707.  sa1100_pcmcia_mecr_bs(sa1100_pcmcia_socket[sock].speed_attr,
  708.        clock));
  709.     MECR_BSM_SET(mecr, sock,
  710.  sa1100_pcmcia_mecr_bs(sa1100_pcmcia_socket[sock].speed_mem,
  711.        clock));
  712.   }
  713.   MECR = mecr;
  714. }
  715. /* sa1100_pcmcia_notifier()
  716.  * ^^^^^^^^^^^^^^^^^^^^^^^^
  717.  * When changing the processor core clock frequency, it is necessary
  718.  * to adjust the MECR timings accordingly. We've recorded the timings
  719.  * requested by Card Services, so this is just a matter of finding
  720.  * out what our current speed is, and then recomputing the new MECR
  721.  * values.
  722.  *
  723.  * Returns: 0 on success, -1 on error
  724.  */
  725. static int
  726. sa1100_pcmcia_notifier(struct notifier_block *nb, unsigned long val,
  727.        void *data)
  728. {
  729.   struct cpufreq_info *ci = data;
  730.   switch (val) {
  731.   case CPUFREQ_PRECHANGE:
  732.     if (ci->new_freq > ci->old_freq) {
  733.       DEBUG(2, "%s(): new frequency %u.%uMHz > %u.%uMHz, pre-updatingn",
  734.     __FUNCTION__,
  735.     ci->new_freq / 1000, (ci->new_freq / 100) % 10,
  736.     ci->old_freq / 1000, (ci->old_freq / 100) % 10);
  737.       sa1100_pcmcia_update_mecr(ci->new_freq);
  738.     }
  739.     break;
  740.   case CPUFREQ_POSTCHANGE:
  741.     if (ci->new_freq < ci->old_freq) {
  742.       DEBUG(2, "%s(): new frequency %u.%uMHz < %u.%uMHz, post-updatingn",
  743.     __FUNCTION__,
  744.     ci->new_freq / 1000, (ci->new_freq / 100) % 10,
  745.     ci->old_freq / 1000, (ci->old_freq / 100) % 10);
  746.       sa1100_pcmcia_update_mecr(ci->new_freq);
  747.     }
  748.     break;
  749.   }
  750.   return 0;
  751. }
  752. static struct notifier_block sa1100_pcmcia_notifier_block = {
  753.   notifier_call: sa1100_pcmcia_notifier
  754. };
  755. #endif
  756. static int __init sa1100_pcmcia_machine_init(void)
  757. {
  758. #ifdef CONFIG_SA1100_ASSABET
  759.   if(machine_is_assabet()) {
  760.     if(machine_has_neponset()) {
  761. #ifdef CONFIG_ASSABET_NEPONSET
  762.       pcmcia_low_level = &neponset_pcmcia_ops;
  763. #else
  764.       printk(KERN_ERR "Card Services disabled: missing Neponset supportn");
  765.       return -1;
  766. #endif
  767.     } else
  768.       pcmcia_low_level = &assabet_pcmcia_ops;
  769.   }
  770. #endif
  771. #ifdef CONFIG_SA1100_BADGE4
  772.   if (machine_is_badge4())
  773.     pcmcia_low_level = &badge4_pcmcia_ops;
  774. #endif
  775. #ifdef CONFIG_SA1100_FREEBIRD
  776.   if (machine_is_freebird())
  777.     pcmcia_low_level = &freebird_pcmcia_ops;
  778. #endif
  779. #ifdef CONFIG_SA1100_H3600
  780.   if (machine_is_h3600())
  781.     pcmcia_low_level = &h3600_pcmcia_ops;
  782. #endif
  783. #ifdef CONFIG_SA1100_CERF
  784.   if (machine_is_cerf())
  785.     pcmcia_low_level = &cerf_pcmcia_ops;
  786. #endif
  787. #ifdef CONFIG_SA1100_GRAPHICSCLIENT
  788.   if (machine_is_graphicsclient())
  789.     pcmcia_low_level = &gcplus_pcmcia_ops;
  790. #endif
  791. #ifdef CONFIG_SA1100_XP860
  792.   if (machine_is_xp860())
  793.     pcmcia_low_level = &xp860_pcmcia_ops;
  794. #endif
  795. #ifdef CONFIG_SA1100_YOPY
  796.   if (machine_is_yopy())
  797.     pcmcia_low_level = &yopy_pcmcia_ops;
  798. #endif
  799. #ifdef CONFIG_SA1100_SHANNON
  800.   if (machine_is_shannon())
  801.     pcmcia_low_level = &shannon_pcmcia_ops;
  802. #endif
  803. #ifdef CONFIG_SA1100_PANGOLIN
  804.   if (machine_is_pangolin())
  805.     pcmcia_low_level = &pangolin_pcmcia_ops;
  806. #endif
  807. #ifdef CONFIG_SA1100_JORNADA720
  808.   if (machine_is_jornada720())
  809.     pcmcia_low_level = &jornada720_pcmcia_ops;
  810. #endif
  811. #ifdef CONFIG_SA1100_PFS168
  812.   if(machine_is_pfs168())
  813.     pcmcia_low_level = &pfs168_pcmcia_ops;
  814. #endif
  815. #ifdef CONFIG_SA1100_FLEXANET
  816.   if(machine_is_flexanet())
  817.     pcmcia_low_level = &flexanet_pcmcia_ops;
  818. #endif
  819. #ifdef CONFIG_SA1100_SIMPAD
  820.   if(machine_is_simpad())
  821.     pcmcia_low_level = &simpad_pcmcia_ops;
  822. #endif
  823. #ifdef CONFIG_SA1100_GRAPHICSMASTER
  824.   if(machine_is_graphicsmaster())
  825.     pcmcia_low_level = &graphicsmaster_pcmcia_ops;
  826. #endif
  827. #ifdef CONFIG_SA1100_ADSBITSY
  828.   if(machine_is_adsbitsy())
  829.     pcmcia_low_level = &adsbitsy_pcmcia_ops;
  830. #endif
  831. #ifdef CONFIG_SA1100_STORK
  832.   if(machine_is_stork())
  833.     pcmcia_low_level = &stork_pcmcia_ops;
  834. #endif
  835.   if (!pcmcia_low_level) {
  836.     printk(KERN_ERR "This hardware is not supported by the SA1100 Card Service drivern");
  837.     return -ENODEV;
  838.   }
  839.   return 0;
  840. }
  841. /* sa1100_pcmcia_driver_init()
  842.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^^
  843.  *
  844.  * This routine performs a basic sanity check to ensure that this
  845.  * kernel has been built with the appropriate board-specific low-level
  846.  * PCMCIA support, performs low-level PCMCIA initialization, registers
  847.  * this socket driver with Card Services, and then spawns the daemon
  848.  * thread which is the real workhorse of the socket driver.
  849.  *
  850.  * Returns: 0 on success, -1 on error
  851.  */
  852. static int __init sa1100_pcmcia_driver_init(void)
  853. {
  854.   servinfo_t info;
  855.   struct pcmcia_init pcmcia_init;
  856.   struct pcmcia_state state[SA1100_PCMCIA_MAX_SOCK];
  857.   struct pcmcia_state_array state_array;
  858.   unsigned int i, clock;
  859.   unsigned long mecr;
  860.   int ret;
  861.   printk(KERN_INFO "SA-1100 PCMCIA (CS release %s)n", CS_RELEASE);
  862.   CardServices(GetCardServicesInfo, &info);
  863.   if (info.Revision != CS_RELEASE_CODE) {
  864.     printk(KERN_ERR "Card Services release codes do not matchn");
  865.     return -EINVAL;
  866.   }
  867.   ret = sa1100_pcmcia_machine_init();
  868.   if (ret)
  869.     return ret;
  870.   pcmcia_init.handler = sa1100_pcmcia_interrupt;
  871.   ret = pcmcia_low_level->init(&pcmcia_init);
  872.   if (ret < 0) {
  873.     printk(KERN_ERR "Unable to initialize kernel PCMCIA service (%d).n", ret);
  874.     return ret == -1 ? -EIO : ret;
  875.   }
  876.   sa1100_pcmcia_socket_count = ret;
  877.   state_array.size  = sa1100_pcmcia_socket_count;
  878.   state_array.state = state;
  879.   memset(state, 0, sizeof(state));
  880.   if (pcmcia_low_level->socket_state(&state_array) < 0) {
  881.     pcmcia_low_level->shutdown();
  882.     printk(KERN_ERR "Unable to get PCMCIA status from kernel.n");
  883.     return -EIO;
  884.   }
  885.   /*
  886.    * We initialize the MECR to default values here, because we are
  887.    * not guaranteed to see a SetIOMap operation at runtime.
  888.    */
  889.   mecr = 0;
  890.   clock = cpufreq_get(0);
  891.   for (i = 0; i < sa1100_pcmcia_socket_count; i++) {
  892.     struct sa1100_pcmcia_socket *skt = PCMCIA_SOCKET(i);
  893.     struct pcmcia_irq_info irq_info;
  894.     if (!request_mem_region(_PCMCIA(i), PCMCIASp, "PCMCIA")) {
  895.       ret = -EBUSY;
  896.       goto out_err;
  897.     }
  898.     irq_info.sock = i;
  899.     irq_info.irq  = -1;
  900.     ret = pcmcia_low_level->get_irq_info(&irq_info);
  901.     if (ret < 0)
  902.       printk(KERN_ERR "Unable to get IRQ for socket %u (%d)n", i, ret);
  903.     skt->irq        = irq_info.irq;
  904.     skt->k_state    = state[i];
  905.     skt->speed_io   = SA1100_PCMCIA_IO_ACCESS;
  906.     skt->speed_attr = SA1100_PCMCIA_5V_MEM_ACCESS;
  907.     skt->speed_mem  = SA1100_PCMCIA_5V_MEM_ACCESS;
  908.     skt->phys_attr  = _PCMCIAAttr(i);
  909.     skt->phys_mem   = _PCMCIAMem(i);
  910.     skt->virt_io    = ioremap(_PCMCIAIO(i), 0x10000);
  911.     if (skt->virt_io == NULL) {
  912.       ret = -ENOMEM;
  913.       goto out_err;
  914.     }
  915.     MECR_FAST_SET(mecr, i, 0);
  916.     MECR_BSIO_SET(mecr, i, sa1100_pcmcia_mecr_bs(skt->speed_io, clock));
  917.     MECR_BSA_SET(mecr, i, sa1100_pcmcia_mecr_bs(skt->speed_attr, clock));
  918.     MECR_BSM_SET(mecr, i, sa1100_pcmcia_mecr_bs(skt->speed_mem, clock));
  919.   }
  920.   MECR = mecr;
  921. #ifdef CONFIG_CPU_FREQ
  922.   ret = cpufreq_register_notifier(&sa1100_pcmcia_notifier_block);
  923.   if (ret < 0) {
  924.     printk(KERN_ERR "Unable to register CPU frequency change notifier (%d)n", ret);
  925.     goto out_err;
  926.   }
  927. #endif
  928.   /* Only advertise as many sockets as we can detect */
  929.   ret = register_ss_entry(sa1100_pcmcia_socket_count,
  930.   &sa1100_pcmcia_operations);
  931.   if (ret < 0) {
  932.     printk(KERN_ERR "Unable to register socketsn");
  933.     goto out_err;
  934.   }
  935.   /*
  936.    * Start the event poll timer.  It will reschedule by itself afterwards.
  937.    */
  938.   sa1100_pcmcia_poll_event(0);
  939.   return 0;
  940.  out_err:
  941.   for (i = 0; i < sa1100_pcmcia_socket_count; i++) {
  942.     iounmap(sa1100_pcmcia_socket[i].virt_io);
  943.     release_mem_region(_PCMCIA(i), PCMCIASp);
  944.   }
  945.   pcmcia_low_level->shutdown();
  946.   return ret;
  947. }  /* sa1100_pcmcia_driver_init() */
  948. /* sa1100_pcmcia_driver_shutdown()
  949.  * ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  950.  * Invokes the low-level kernel service to free IRQs associated with this
  951.  * socket controller and reset GPIO edge detection.
  952.  */
  953. static void __exit sa1100_pcmcia_driver_shutdown(void)
  954. {
  955.   int i;
  956.   del_timer_sync(&poll_timer);
  957.   unregister_ss_entry(&sa1100_pcmcia_operations);
  958. #ifdef CONFIG_CPU_FREQ
  959.   cpufreq_unregister_notifier(&sa1100_pcmcia_notifier_block);
  960. #endif
  961.   for (i = 0; i < sa1100_pcmcia_socket_count; i++) {
  962.     iounmap(sa1100_pcmcia_socket[i].virt_io);
  963.     release_mem_region(_PCMCIA(i), PCMCIASp);
  964.   }
  965.   pcmcia_low_level->shutdown();
  966.   flush_scheduled_tasks();
  967. }
  968. MODULE_AUTHOR("John Dorsey <john+@cs.cmu.edu>");
  969. MODULE_DESCRIPTION("Linux PCMCIA Card Services: SA-1100 Socket Controller");
  970. MODULE_LICENSE("Dual MPL/GPL");
  971. module_init(sa1100_pcmcia_driver_init);
  972. module_exit(sa1100_pcmcia_driver_shutdown);