• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  *  linux/drivers/mmc/core/host.c
3  *
4  *  Copyright (C) 2003 Russell King, All Rights Reserved.
5  *  Copyright (C) 2007-2008 Pierre Ossman
6  *  Copyright (C) 2010 Linus Walleij
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License version 2 as
10  * published by the Free Software Foundation.
11  *
12  *  MMC host class device management
13  */
14 
15 #include <linux/device.h>
16 #include <linux/err.h>
17 #include <linux/idr.h>
18 #include <linux/pagemap.h>
19 #include <linux/export.h>
20 #include <linux/leds.h>
21 #include <linux/slab.h>
22 #include <linux/suspend.h>
23 
24 #include <linux/mmc/host.h>
25 #include <linux/mmc/card.h>
26 
27 #include "core.h"
28 #include "host.h"
29 
30 #define cls_dev_to_mmc_host(d)	container_of(d, struct mmc_host, class_dev)
31 
mmc_host_classdev_release(struct device * dev)32 static void mmc_host_classdev_release(struct device *dev)
33 {
34 	struct mmc_host *host = cls_dev_to_mmc_host(dev);
35 	kfree(host);
36 }
37 
38 static struct class mmc_host_class = {
39 	.name		= "mmc_host",
40 	.dev_release	= mmc_host_classdev_release,
41 };
42 
mmc_register_host_class(void)43 int mmc_register_host_class(void)
44 {
45 	return class_register(&mmc_host_class);
46 }
47 
mmc_unregister_host_class(void)48 void mmc_unregister_host_class(void)
49 {
50 	class_unregister(&mmc_host_class);
51 }
52 
53 static DEFINE_IDR(mmc_host_idr);
54 static DEFINE_SPINLOCK(mmc_host_lock);
55 
56 #ifdef CONFIG_MMC_CLKGATE
clkgate_delay_show(struct device * dev,struct device_attribute * attr,char * buf)57 static ssize_t clkgate_delay_show(struct device *dev,
58 		struct device_attribute *attr, char *buf)
59 {
60 	struct mmc_host *host = cls_dev_to_mmc_host(dev);
61 	return snprintf(buf, PAGE_SIZE, "%lu\n", host->clkgate_delay);
62 }
63 
clkgate_delay_store(struct device * dev,struct device_attribute * attr,const char * buf,size_t count)64 static ssize_t clkgate_delay_store(struct device *dev,
65 		struct device_attribute *attr, const char *buf, size_t count)
66 {
67 	struct mmc_host *host = cls_dev_to_mmc_host(dev);
68 	unsigned long flags, value;
69 
70 	if (kstrtoul(buf, 0, &value))
71 		return -EINVAL;
72 
73 	spin_lock_irqsave(&host->clk_lock, flags);
74 	host->clkgate_delay = value;
75 	spin_unlock_irqrestore(&host->clk_lock, flags);
76 	return count;
77 }
78 
79 /*
80  * Enabling clock gating will make the core call out to the host
81  * once up and once down when it performs a request or card operation
82  * intermingled in any fashion. The driver will see this through
83  * set_ios() operations with ios.clock field set to 0 to gate (disable)
84  * the block clock, and to the old frequency to enable it again.
85  */
mmc_host_clk_gate_delayed(struct mmc_host * host)86 static void mmc_host_clk_gate_delayed(struct mmc_host *host)
87 {
88 	unsigned long tick_ns;
89 	unsigned long freq = host->ios.clock;
90 	unsigned long flags;
91 
92 	if (!freq) {
93 		pr_debug("%s: frequency set to 0 in disable function, "
94 			 "this means the clock is already disabled.\n",
95 			 mmc_hostname(host));
96 		return;
97 	}
98 	/*
99 	 * New requests may have appeared while we were scheduling,
100 	 * then there is no reason to delay the check before
101 	 * clk_disable().
102 	 */
103 	spin_lock_irqsave(&host->clk_lock, flags);
104 
105 	/*
106 	 * Delay n bus cycles (at least 8 from MMC spec) before attempting
107 	 * to disable the MCI block clock. The reference count may have
108 	 * gone up again after this delay due to rescheduling!
109 	 */
110 	if (!host->clk_requests) {
111 		spin_unlock_irqrestore(&host->clk_lock, flags);
112 		tick_ns = DIV_ROUND_UP(1000000000, freq);
113 		ndelay(host->clk_delay * tick_ns);
114 	} else {
115 		/* New users appeared while waiting for this work */
116 		spin_unlock_irqrestore(&host->clk_lock, flags);
117 		return;
118 	}
119 	mutex_lock(&host->clk_gate_mutex);
120 	spin_lock_irqsave(&host->clk_lock, flags);
121 	if (!host->clk_requests) {
122 		spin_unlock_irqrestore(&host->clk_lock, flags);
123 		/* This will set host->ios.clock to 0 */
124 		mmc_gate_clock(host);
125 		spin_lock_irqsave(&host->clk_lock, flags);
126 		pr_debug("%s: gated MCI clock\n", mmc_hostname(host));
127 	}
128 	spin_unlock_irqrestore(&host->clk_lock, flags);
129 	mutex_unlock(&host->clk_gate_mutex);
130 }
131 
132 /*
133  * Internal work. Work to disable the clock at some later point.
134  */
mmc_host_clk_gate_work(struct work_struct * work)135 static void mmc_host_clk_gate_work(struct work_struct *work)
136 {
137 	struct mmc_host *host = container_of(work, struct mmc_host,
138 					      clk_gate_work.work);
139 
140 	mmc_host_clk_gate_delayed(host);
141 }
142 
143 /**
144  *	mmc_host_clk_hold - ungate hardware MCI clocks
145  *	@host: host to ungate.
146  *
147  *	Makes sure the host ios.clock is restored to a non-zero value
148  *	past this call.	Increase clock reference count and ungate clock
149  *	if we're the first user.
150  */
mmc_host_clk_hold(struct mmc_host * host)151 void mmc_host_clk_hold(struct mmc_host *host)
152 {
153 	unsigned long flags;
154 
155 	/* cancel any clock gating work scheduled by mmc_host_clk_release() */
156 	cancel_delayed_work_sync(&host->clk_gate_work);
157 	mutex_lock(&host->clk_gate_mutex);
158 	spin_lock_irqsave(&host->clk_lock, flags);
159 	if (host->clk_gated) {
160 		spin_unlock_irqrestore(&host->clk_lock, flags);
161 		mmc_ungate_clock(host);
162 		spin_lock_irqsave(&host->clk_lock, flags);
163 		pr_debug("%s: ungated MCI clock\n", mmc_hostname(host));
164 	}
165 	host->clk_requests++;
166 	spin_unlock_irqrestore(&host->clk_lock, flags);
167 	mutex_unlock(&host->clk_gate_mutex);
168 }
169 
170 /**
171  *	mmc_host_may_gate_card - check if this card may be gated
172  *	@card: card to check.
173  */
mmc_host_may_gate_card(struct mmc_card * card)174 static bool mmc_host_may_gate_card(struct mmc_card *card)
175 {
176 	/* If there is no card we may gate it */
177 	if (!card)
178 		return true;
179 	/*
180 	 * Don't gate SDIO cards! These need to be clocked at all times
181 	 * since they may be independent systems generating interrupts
182 	 * and other events. The clock requests counter from the core will
183 	 * go down to zero since the core does not need it, but we will not
184 	 * gate the clock, because there is somebody out there that may still
185 	 * be using it.
186 	 */
187 	return !(card->quirks & MMC_QUIRK_BROKEN_CLK_GATING);
188 }
189 
190 /**
191  *	mmc_host_clk_release - gate off hardware MCI clocks
192  *	@host: host to gate.
193  *
194  *	Calls the host driver with ios.clock set to zero as often as possible
195  *	in order to gate off hardware MCI clocks. Decrease clock reference
196  *	count and schedule disabling of clock.
197  */
mmc_host_clk_release(struct mmc_host * host)198 void mmc_host_clk_release(struct mmc_host *host)
199 {
200 	unsigned long flags;
201 
202 	spin_lock_irqsave(&host->clk_lock, flags);
203 	host->clk_requests--;
204 	if (mmc_host_may_gate_card(host->card) &&
205 	    !host->clk_requests)
206 		queue_delayed_work(system_nrt_wq, &host->clk_gate_work,
207 				msecs_to_jiffies(host->clkgate_delay));
208 	spin_unlock_irqrestore(&host->clk_lock, flags);
209 }
210 
211 /**
212  *	mmc_host_clk_rate - get current clock frequency setting
213  *	@host: host to get the clock frequency for.
214  *
215  *	Returns current clock frequency regardless of gating.
216  */
mmc_host_clk_rate(struct mmc_host * host)217 unsigned int mmc_host_clk_rate(struct mmc_host *host)
218 {
219 	unsigned long freq;
220 	unsigned long flags;
221 
222 	spin_lock_irqsave(&host->clk_lock, flags);
223 	if (host->clk_gated)
224 		freq = host->clk_old;
225 	else
226 		freq = host->ios.clock;
227 	spin_unlock_irqrestore(&host->clk_lock, flags);
228 	return freq;
229 }
230 
231 /**
232  *	mmc_host_clk_init - set up clock gating code
233  *	@host: host with potential clock to control
234  */
mmc_host_clk_init(struct mmc_host * host)235 static inline void mmc_host_clk_init(struct mmc_host *host)
236 {
237 	host->clk_requests = 0;
238 	/* Hold MCI clock for 8 cycles by default */
239 	host->clk_delay = 8;
240 	/*
241 	 * Default clock gating delay is 0ms to avoid wasting power.
242 	 * This value can be tuned by writing into sysfs entry.
243 	 */
244 	host->clkgate_delay = 0;
245 	host->clk_gated = false;
246 	INIT_DELAYED_WORK(&host->clk_gate_work, mmc_host_clk_gate_work);
247 	spin_lock_init(&host->clk_lock);
248 	mutex_init(&host->clk_gate_mutex);
249 }
250 
251 /**
252  *	mmc_host_clk_exit - shut down clock gating code
253  *	@host: host with potential clock to control
254  */
mmc_host_clk_exit(struct mmc_host * host)255 static inline void mmc_host_clk_exit(struct mmc_host *host)
256 {
257 	/*
258 	 * Wait for any outstanding gate and then make sure we're
259 	 * ungated before exiting.
260 	 */
261 	if (cancel_delayed_work_sync(&host->clk_gate_work))
262 		mmc_host_clk_gate_delayed(host);
263 	if (host->clk_gated)
264 		mmc_host_clk_hold(host);
265 	/* There should be only one user now */
266 	WARN_ON(host->clk_requests > 1);
267 }
268 
mmc_host_clk_sysfs_init(struct mmc_host * host)269 static inline void mmc_host_clk_sysfs_init(struct mmc_host *host)
270 {
271 	host->clkgate_delay_attr.show = clkgate_delay_show;
272 	host->clkgate_delay_attr.store = clkgate_delay_store;
273 	sysfs_attr_init(&host->clkgate_delay_attr.attr);
274 	host->clkgate_delay_attr.attr.name = "clkgate_delay";
275 	host->clkgate_delay_attr.attr.mode = S_IRUGO | S_IWUSR;
276 	if (device_create_file(&host->class_dev, &host->clkgate_delay_attr))
277 		pr_err("%s: Failed to create clkgate_delay sysfs entry\n",
278 				mmc_hostname(host));
279 }
280 #else
281 
mmc_host_clk_init(struct mmc_host * host)282 static inline void mmc_host_clk_init(struct mmc_host *host)
283 {
284 }
285 
mmc_host_clk_exit(struct mmc_host * host)286 static inline void mmc_host_clk_exit(struct mmc_host *host)
287 {
288 }
289 
mmc_host_clk_sysfs_init(struct mmc_host * host)290 static inline void mmc_host_clk_sysfs_init(struct mmc_host *host)
291 {
292 }
293 
294 #endif
295 
296 /**
297  *	mmc_alloc_host - initialise the per-host structure.
298  *	@extra: sizeof private data structure
299  *	@dev: pointer to host device model structure
300  *
301  *	Initialise the per-host structure.
302  */
mmc_alloc_host(int extra,struct device * dev)303 struct mmc_host *mmc_alloc_host(int extra, struct device *dev)
304 {
305 	int err;
306 	struct mmc_host *host;
307 
308 	if (!idr_pre_get(&mmc_host_idr, GFP_KERNEL))
309 		return NULL;
310 
311 	host = kzalloc(sizeof(struct mmc_host) + extra, GFP_KERNEL);
312 	if (!host)
313 		return NULL;
314 
315 	spin_lock(&mmc_host_lock);
316 	err = idr_get_new(&mmc_host_idr, host, &host->index);
317 	spin_unlock(&mmc_host_lock);
318 	if (err)
319 		goto free;
320 
321 	dev_set_name(&host->class_dev, "mmc%d", host->index);
322 
323 	host->parent = dev;
324 	host->class_dev.parent = dev;
325 	host->class_dev.class = &mmc_host_class;
326 	device_initialize(&host->class_dev);
327 
328 	mmc_host_clk_init(host);
329 
330 	spin_lock_init(&host->lock);
331 	init_waitqueue_head(&host->wq);
332 	wake_lock_init(&host->detect_wake_lock, WAKE_LOCK_SUSPEND,
333 		kasprintf(GFP_KERNEL, "%s_detect", mmc_hostname(host)));
334 	INIT_DELAYED_WORK(&host->detect, mmc_rescan);
335 #ifdef CONFIG_PM
336 	host->pm_notify.notifier_call = mmc_pm_notify;
337 #endif
338 
339 	/*
340 	 * By default, hosts do not support SGIO or large requests.
341 	 * They have to set these according to their abilities.
342 	 */
343 	host->max_segs = 1;
344 	host->max_seg_size = PAGE_CACHE_SIZE;
345 
346 	host->max_req_size = PAGE_CACHE_SIZE;
347 	host->max_blk_size = 512;
348 	host->max_blk_count = PAGE_CACHE_SIZE / 512;
349 
350 	return host;
351 
352 free:
353 	kfree(host);
354 	return NULL;
355 }
356 
357 EXPORT_SYMBOL(mmc_alloc_host);
358 
359 /**
360  *	mmc_add_host - initialise host hardware
361  *	@host: mmc host
362  *
363  *	Register the host with the driver model. The host must be
364  *	prepared to start servicing requests before this function
365  *	completes.
366  */
mmc_add_host(struct mmc_host * host)367 int mmc_add_host(struct mmc_host *host)
368 {
369 	int err;
370 
371 	WARN_ON((host->caps & MMC_CAP_SDIO_IRQ) &&
372 		!host->ops->enable_sdio_irq);
373 
374 	err = device_add(&host->class_dev);
375 	if (err)
376 		return err;
377 
378 	led_trigger_register_simple(dev_name(&host->class_dev), &host->led);
379 
380 #ifdef CONFIG_DEBUG_FS
381 	mmc_add_host_debugfs(host);
382 #endif
383 	mmc_host_clk_sysfs_init(host);
384 
385 	mmc_start_host(host);
386 	if (!(host->pm_flags & MMC_PM_IGNORE_PM_NOTIFY))
387 		register_pm_notifier(&host->pm_notify);
388 
389 	return 0;
390 }
391 
392 EXPORT_SYMBOL(mmc_add_host);
393 
394 /**
395  *	mmc_remove_host - remove host hardware
396  *	@host: mmc host
397  *
398  *	Unregister and remove all cards associated with this host,
399  *	and power down the MMC bus. No new requests will be issued
400  *	after this function has returned.
401  */
mmc_remove_host(struct mmc_host * host)402 void mmc_remove_host(struct mmc_host *host)
403 {
404 	if (!(host->pm_flags & MMC_PM_IGNORE_PM_NOTIFY))
405 		unregister_pm_notifier(&host->pm_notify);
406 
407 	mmc_stop_host(host);
408 
409 #ifdef CONFIG_DEBUG_FS
410 	mmc_remove_host_debugfs(host);
411 #endif
412 
413 	device_del(&host->class_dev);
414 
415 	led_trigger_unregister_simple(host->led);
416 
417 	mmc_host_clk_exit(host);
418 }
419 
420 EXPORT_SYMBOL(mmc_remove_host);
421 
422 /**
423  *	mmc_free_host - free the host structure
424  *	@host: mmc host
425  *
426  *	Free the host once all references to it have been dropped.
427  */
mmc_free_host(struct mmc_host * host)428 void mmc_free_host(struct mmc_host *host)
429 {
430 	spin_lock(&mmc_host_lock);
431 	idr_remove(&mmc_host_idr, host->index);
432 	spin_unlock(&mmc_host_lock);
433 	wake_lock_destroy(&host->detect_wake_lock);
434 
435 	put_device(&host->class_dev);
436 }
437 
438 EXPORT_SYMBOL(mmc_free_host);
439