summaryrefslogtreecommitdiff
path: root/drivers/ata/pata_cs5530.c
blob: 1e67b0f8db438390f4a616dadabaac661b89a22a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
// SPDX-License-Identifier: GPL-2.0-only
/*
 * pata-cs5530.c 	- CS5530 PATA for new ATA layer
 *			  (C) 2005 Red Hat Inc
 *
 * based upon cs5530.c by Mark Lord.
 *
 * Loosely based on the piix & svwks drivers.
 *
 * Documentation:
 *	Available from AMD web site.
 */

#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/pci.h>
#include <linux/blkdev.h>
#include <linux/delay.h>
#include <scsi/scsi_host.h>
#include <linux/libata.h>
#include <linux/dmi.h>

#define DRV_NAME	"pata_cs5530"
#define DRV_VERSION	"0.7.4"

static void __iomem *cs5530_port_base(struct ata_port *ap)
{
	unsigned long bmdma = (unsigned long)ap->ioaddr.bmdma_addr;

	return (void __iomem *)((bmdma & ~0x0F) + 0x20 + 0x10 * ap->port_no);
}

/**
 *	cs5530_set_piomode		-	PIO setup
 *	@ap: ATA interface
 *	@adev: device on the interface
 *
 *	Set our PIO requirements. This is fairly simple on the CS5530
 *	chips.
 */

static void cs5530_set_piomode(struct ata_port *ap, struct ata_device *adev)
{
	static const unsigned int cs5530_pio_timings[2][5] = {
		{0x00009172, 0x00012171, 0x00020080, 0x00032010, 0x00040010},
		{0xd1329172, 0x71212171, 0x30200080, 0x20102010, 0x00100010}
	};
	void __iomem *base = cs5530_port_base(ap);
	u32 tuning;
	int format;

	/* Find out which table to use */
	tuning = ioread32(base + 0x04);
	format = (tuning & 0x80000000UL) ? 1 : 0;

	/* Now load the right timing register */
	if (adev->devno)
		base += 0x08;

	iowrite32(cs5530_pio_timings[format][adev->pio_mode - XFER_PIO_0], base);
}

/**
 *	cs5530_set_dmamode		-	DMA timing setup
 *	@ap: ATA interface
 *	@adev: Device being configured
 *
 *	We cannot mix MWDMA and UDMA without reloading timings each switch
 *	master to slave. We track the last DMA setup in order to minimise
 *	reloads.
 */

static void cs5530_set_dmamode(struct ata_port *ap, struct ata_device *adev)
{
	void __iomem *base = cs5530_port_base(ap);
	u32 tuning, timing = 0;
	u8 reg;

	/* Find out which table to use */
	tuning = ioread32(base + 0x04);

	switch(adev->dma_mode) {
		case XFER_UDMA_0:
			timing  = 0x00921250;break;
		case XFER_UDMA_1:
			timing  = 0x00911140;break;
		case XFER_UDMA_2:
			timing  = 0x00911030;break;
		case XFER_MW_DMA_0:
			timing  = 0x00077771;break;
		case XFER_MW_DMA_1:
			timing  = 0x00012121;break;
		case XFER_MW_DMA_2:
			timing  = 0x00002020;break;
		default:
			BUG();
	}
	/* Merge in the PIO format bit */
	timing |= (tuning & 0x80000000UL);
	if (adev->devno == 0) /* Master */
		iowrite32(timing, base + 0x04);
	else {
		if (timing & 0x00100000)
			tuning |= 0x00100000;	/* UDMA for both */
		else
			tuning &= ~0x00100000;	/* MWDMA for both */
		iowrite32(tuning, base + 0x04);
		iowrite32(timing, base + 0x0C);
	}

	/* Set the DMA capable bit in the BMDMA area */
	reg = ioread8(ap->ioaddr.bmdma_addr + ATA_DMA_STATUS);
	reg |= (1 << (5 + adev->devno));
	iowrite8(reg, ap->ioaddr.bmdma_addr + ATA_DMA_STATUS);

	/* Remember the last DMA setup we did */

	ap->private_data = adev;
}

/**
 *	cs5530_qc_issue		-	command issue
 *	@qc: command pending
 *
 *	Called when the libata layer is about to issue a command. We wrap
 *	this interface so that we can load the correct ATA timings if
 *	necessary.  Specifically we have a problem that there is only
 *	one MWDMA/UDMA bit.
 */

static unsigned int cs5530_qc_issue(struct ata_queued_cmd *qc)
{
	struct ata_port *ap = qc->ap;
	struct ata_device *adev = qc->dev;
	struct ata_device *prev = ap->private_data;

	/* See if the DMA settings could be wrong */
	if (ata_dma_enabled(adev) && adev != prev && prev != NULL) {
		/* Maybe, but do the channels match MWDMA/UDMA ? */
		if ((ata_using_udma(adev) && !ata_using_udma(prev)) ||
		    (ata_using_udma(prev) && !ata_using_udma(adev)))
		    	/* Switch the mode bits */
		    	cs5530_set_dmamode(ap, adev);
	}

	return ata_bmdma_qc_issue(qc);
}

static const struct scsi_host_template cs5530_sht = {
	ATA_BASE_SHT(DRV_NAME),
	.sg_tablesize	= LIBATA_DUMB_MAX_PRD,
	.dma_boundary	= ATA_DMA_BOUNDARY,
};

static struct ata_port_operations cs5530_port_ops = {
	.inherits	= &ata_bmdma_port_ops,

	.qc_prep 	= ata_bmdma_dumb_qc_prep,
	.qc_issue	= cs5530_qc_issue,

	.cable_detect	= ata_cable_40wire,
	.set_piomode	= cs5530_set_piomode,
	.set_dmamode	= cs5530_set_dmamode,
};

static const struct dmi_system_id palmax_dmi_table[] = {
	{
		.ident = "Palmax PD1100",
		.matches = {
			DMI_MATCH(DMI_SYS_VENDOR, "Cyrix"),
			DMI_MATCH(DMI_PRODUCT_NAME, "Caddis"),
		},
	},
	{ }
};

static int cs5530_is_palmax(void)
{
	if (dmi_check_system(palmax_dmi_table)) {
		printk(KERN_INFO "Palmax PD1100: Disabling DMA on docking port.\n");
		return 1;
	}
	return 0;
}


/**
 *	cs5530_init_chip	-	Chipset init
 *
 *	Perform the chip initialisation work that is shared between both
 *	setup and resume paths
 */

static int cs5530_init_chip(void)
{
	struct pci_dev *master_0 = NULL, *cs5530_0 = NULL, *dev = NULL;

	while ((dev = pci_get_device(PCI_VENDOR_ID_CYRIX, PCI_ANY_ID, dev)) != NULL) {
		switch (dev->device) {
			case PCI_DEVICE_ID_CYRIX_PCI_MASTER:
				master_0 = pci_dev_get(dev);
				break;
			case PCI_DEVICE_ID_CYRIX_5530_LEGACY:
				cs5530_0 = pci_dev_get(dev);
				break;
		}
	}
	if (!master_0) {
		printk(KERN_ERR DRV_NAME ": unable to locate PCI MASTER function\n");
		goto fail_put;
	}
	if (!cs5530_0) {
		printk(KERN_ERR DRV_NAME ": unable to locate CS5530 LEGACY function\n");
		goto fail_put;
	}

	pci_set_master(cs5530_0);
	pci_try_set_mwi(cs5530_0);

	/*
	 * Set PCI CacheLineSize to 16-bytes:
	 * --> Write 0x04 into 8-bit PCI CACHELINESIZE reg of function 0 of the cs5530
	 *
	 * Note: This value is constant because the 5530 is only a Geode companion
	 */

	pci_write_config_byte(cs5530_0, PCI_CACHE_LINE_SIZE, 0x04);

	/*
	 * Disable trapping of UDMA register accesses (Win98 hack):
	 * --> Write 0x5006 into 16-bit reg at offset 0xd0 of function 0 of the cs5530
	 */

	pci_write_config_word(cs5530_0, 0xd0, 0x5006);

	/*
	 * Bit-1 at 0x40 enables MemoryWriteAndInvalidate on internal X-bus:
	 * The other settings are what is necessary to get the register
	 * into a sane state for IDE DMA operation.
	 */

	pci_write_config_byte(master_0, 0x40, 0x1e);

	/*
	 * Set max PCI burst size (16-bytes seems to work best):
	 *	   16bytes: set bit-1 at 0x41 (reg value of 0x16)
	 *	all others: clear bit-1 at 0x41, and do:
	 *	  128bytes: OR 0x00 at 0x41
	 *	  256bytes: OR 0x04 at 0x41
	 *	  512bytes: OR 0x08 at 0x41
	 *	 1024bytes: OR 0x0c at 0x41
	 */

	pci_write_config_byte(master_0, 0x41, 0x14);

	/*
	 * These settings are necessary to get the chip
	 * into a sane state for IDE DMA operation.
	 */

	pci_write_config_byte(master_0, 0x42, 0x00);
	pci_write_config_byte(master_0, 0x43, 0xc1);

	pci_dev_put(master_0);
	pci_dev_put(cs5530_0);
	return 0;
fail_put:
	pci_dev_put(master_0);
	pci_dev_put(cs5530_0);
	return -ENODEV;
}

/**
 *	cs5530_init_one		-	Initialise a CS5530
 *	@pdev: PCI device
 *	@id: Entry in match table
 *
 *	Install a driver for the newly found CS5530 companion chip. Most of
 *	this is just housekeeping. We have to set the chip up correctly and
 *	turn off various bits of emulation magic.
 */

static int cs5530_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
{
	static const struct ata_port_info info = {
		.flags = ATA_FLAG_SLAVE_POSS,
		.pio_mask = ATA_PIO4,
		.mwdma_mask = ATA_MWDMA2,
		.udma_mask = ATA_UDMA2,
		.port_ops = &cs5530_port_ops
	};
	/* The docking connector doesn't do UDMA, and it seems not MWDMA */
	static const struct ata_port_info info_palmax_secondary = {
		.flags = ATA_FLAG_SLAVE_POSS,
		.pio_mask = ATA_PIO4,
		.port_ops = &cs5530_port_ops
	};
	const struct ata_port_info *ppi[] = { &info, NULL };
	int rc;

	rc = pcim_enable_device(pdev);
	if (rc)
		return rc;

	/* Chip initialisation */
	if (cs5530_init_chip())
		return -ENODEV;

	if (cs5530_is_palmax())
		ppi[1] = &info_palmax_secondary;

	/* Now kick off ATA set up */
	return ata_pci_bmdma_init_one(pdev, ppi, &cs5530_sht, NULL, 0);
}

#ifdef CONFIG_PM_SLEEP
static int cs5530_reinit_one(struct pci_dev *pdev)
{
	struct ata_host *host = pci_get_drvdata(pdev);
	int rc;

	rc = ata_pci_device_do_resume(pdev);
	if (rc)
		return rc;

	/* If we fail on resume we are doomed */
	if (cs5530_init_chip())
		return -EIO;

	ata_host_resume(host);
	return 0;
}
#endif /* CONFIG_PM_SLEEP */

static const struct pci_device_id cs5530[] = {
	{ PCI_VDEVICE(CYRIX, PCI_DEVICE_ID_CYRIX_5530_IDE), },

	{ },
};

static struct pci_driver cs5530_pci_driver = {
	.name 		= DRV_NAME,
	.id_table	= cs5530,
	.probe 		= cs5530_init_one,
	.remove		= ata_pci_remove_one,
#ifdef CONFIG_PM_SLEEP
	.suspend	= ata_pci_device_suspend,
	.resume		= cs5530_reinit_one,
#endif
};

module_pci_driver(cs5530_pci_driver);

MODULE_AUTHOR("Alan Cox");
MODULE_DESCRIPTION("low-level driver for the Cyrix/NS/AMD 5530");
MODULE_LICENSE("GPL");
MODULE_DEVICE_TABLE(pci, cs5530);
MODULE_VERSION(DRV_VERSION);
wُejն>޻8( -=b3\}EC Ei}=:kÑ>VSI$OaaX0x?< hrJ QZ/gj?c8ƪݻp݋}\],ZƞS8hXnN)4Ҙ.kJ+[ƾ;Ȼ}+˱}`o7)wpKE֭G#ٷNg?0{ 5O@g<I[(ȐhjPfhXMʁ7C8\W96gsҀ;PsVElwm 붚k ~՚Β]B AWjz}c_nH:)8ô\DTLFɃ-eQ1=ػB. 8}]#ѳƷ]`ѳ v |:b#ݜlE~e[&8KLl\p**D^A?ٓč_*6X9!C$e[^jՄ ߱I/XUGilO'n/LC"!0=Ǎ(~8eckZJg=\=m<æ;Â<Uj3p)?7"NF7-?ɔצnda'3cjjl5 Ǫ߂;P[fHGķ`aƌ$yix BWJ *PDSu4Z:es"q>\ɍjrN :8F0iEeh`H`Be ǜO ;Hpm5 $Yc?}PMق6aPT 2sLw4PD7Oq,{Li6$G;uS䐿:Ͷ= >i^kmpɶ%4YR#4Kϲp86bi,c?G$; 76SۂD хIF|Ȁsu.#۝~t@[zx_CDk&~:^}wpx,wtyNj,fqf)^i9v|u>8 |at7# HY:7u(&MV .34Dk3D;Plr̫-DcKwx(xɵɾn:LܵQ;L]V*MMeGw\W24ÒN&5n ;N9#K^T $̥Rr4: D yb21*(nDŽ!ev镜 (UR\>f/~3!fc%1N$]\ɟ{{E0"%'Vs%}KLeNäp{zw]bfYdz_Sclm@#[kV ռ1,+5.Q*I 7#k_ r>Sn$!Bd髃uɌ"w΃ XBn;1jTfPB|dĶA˦4\UvN q "(ju$ <'~Ŕ aLҁ> !p^FFDPb7}L•#;N6ˋEP@S>Z<J;YZ oL_gM 4ha暇u֏s ?0 é_Jegi#xti9k֧s.O9d[ip1}Ah@KdpB3ki/ؑ[^̣#k)\||!}}?]K-vW/uDqS \$¡D ]6'!Яx0hAC|'9 IDd7=%TY .Bz`oa*ΫDP3R?;H"4)J?Vn*~lgTqp YYxvY)H;L{SKx.?tt3GnHdb.uN`4'놼=ER=CX |\5٩n"At+Ja?#{8{3 dVW hB9 M(Gf3SKu-a LyA(ຼђeٻG1]>BUhsqK~c&W{9%xý8aff 2p~ٜ+h_x|bՌqA͖bÅ{0I]vg,G pXiF0eк-k!ϧgyA)kմK>cIyt32Oxy\Vnr͢YRd5 /u+ 'HWjSGjlG#^CTW^F UYP&RpxU8I6fsxAĊ/HO'Q4e*9&YL*yskbCvlݻNgᕜ*v4ЈgoR׏x0cXsa-> t:<.ib_hc0h~˴T6 kY;5>kmJd}P(ޕrsa}BP6Qp))H[Átob.hCpB-s&-,=͑(7ז>M7(uv  j&B"ƻ!lPN̕Ex|W6˥l^JLc{1>BP_N)۷8_ xN);|}쥕R cƁ#NnZFY9C놝d z-n=B K'._+;Mpf,3S04ĐkuЩlX2&cT|r˖A0/ OxjhЋ[o1`!dExw>Җ['{8UbsyآMOTz*RRE̱FѻhcƣB)ei"X1n%[)8zn] _6&@Z訬ʚAv*x l9E{(yq8q<ѿw9m zLjWO:vS _bEYbWPy1f#G3BIDsKv\6'u9p/;S;HmE =6hPmVË#(@5eb O m*3VTYRO(bNuc XfQx,+!+[5p/Nzk".^ sWj{+}izNS*ZYMfĢ(𲫄y9njkBIן[%:\\]%pdqˢ <Iūpt-F=생DìjQOEn񬹻>aòiף+eӲžVsז-:[SJV|Hu4i-47 䳃B?)~4:|[^^w/Xa{Mŷjk13ޡWa ;#r ] 2 aYHw2k.aFP7\ug(B X-3;z˧MR^/\1 Pr7d^Goʚpt4.lh}nϏt` *=$P+zYr28{^na[EZ,hy Tص^ Oܵ&~OIuŸR+A{WE| 9>.yܴiyYF0S]-Jx6_mgsTiu0 *a6CQ=2E 9GxoP4>!w!u9l 3%Vuِ­ۆq:uHt/ղ[V1<4|3ઑ]moj ePKߕzzX9}h:]YU]ߣAlB-r¨Pw=mjJa!^A2y˻ߞ9rP_^Աc;=Դo??'^aȌg<=:a G#TT#1h#! u[ [}F3BN 2aLS5)vLh zuq\x|vn5l5Rzs?oۈB2p.xri~7$eCd.9I6twKcʝ9Jd&с[B9 ̣*lPKP7=HK8̫hb$6΋C%m&IDsu,6>o|⚖Pv?[˫;I`/}-FN f> aFy>k9:Tf/Gz*|(c_尣K#+;;l{(~@]ATw|fBk¨ Q )[ZXv?ɷ cgxĒ?:[RꅩeZ!j՗ ׷YiS!5dq{c{ECs&}ӕJuD("v.qXXDIFދyIOxq[ ez/X$A" )Qn۹cH4:mQ 6ЗqE< X5j;nuzjA(ƾ}||Lkw'Bڇe6qh)HK^@"t HB<5:0KJzNtf{?qn B N2'&aSDbwTc }sݘ~vk3)'elOTrL!Dģ$O|a e^8v=3p9aUY#vWup* SW`pY*Hg} 﫟ڒ6;1P)T"C'pc$ٜ`a@Ίu*\m[kzG>o;H'UL5 ?3s.<R@4 s╔8(v$uN욱c=JBjIAWKjp<{ANH2U [\HkZ N3|tvnzR*aX; e?l?sxG@^E҃KPK0%YqX4~ 7zq}6 е0YOm=}5]y8&wvXS7苿 ft҃bhXҩ?ohp`)1*>떠p<~#4dD?j #U־+j_eM';DecvRH=:.p;8C4-hfӐ2 j押5͗}KTrdrGA cbJD`6PŞylZ$@wT̃IqeKrpawt`Zn>Bx& 6oP%d6QW6+2xaJ E*)k9a:;~d9H߉LebߙW f6R(V #im0+fF$9b󂟣TXu/Ӯ]t}OςXӽqhe7]i2ژ~wJKO8 [Q[pxjB+ [8~s]5ajV#+/״VYt!Cj\T+GXgD6o,*?S{ 0"*\(ݒ:娮 -^Vxh$=d"䇶tvs }THB"`%̣ݩ)b%XB}=[E|6 P_77z~2_/d+?xgL֤ueo_M?%d2WvI . {McPH±{XT(~9s-%ȯxcˉw]rpx)}ӴYk ao ,7ثMpQDzKia0ꩂo]DZ>b/Ȭt7b>j-, ӌ"+aw? &6[Rt.7jExԜ/iF5Pr70;~5Q8NQ l8GgADh* uSՐI;v$de7}u-fɜ_99 ڦSm,bVU[E BR̰}`eW:u*s#K@!\Cvlՙϵ'؊ڵn6bz".K~/˵7֝ p7e"0~8pDG/_ΌBWu.k"he7_$e]& cqr>|V1T -pKsQ@%;ەGE۬n. /|Ol)?ULJۆ{R]¿'#'t0v{z,  :K%Vs s0b:b 3[d'^r] N޸GT:@օ{'_CL>MJev>ip)"B\,S$C^yryy0<<+!~r~s8Kŏ?U:I2MOJ#9Q?[ƐbOoܠes33 d:)\fXD" Ùx'@Pqus3wkDb:AmUРD6XTV cGra[q[@^RЫP/qr3 yLϮO'/-#m1Blz",cᠾxq@r/IX3c#o [G$|ި:F=/Y]zDvwo1߇`Ms2i[o>;YVu}˩|>HKH(ܫ=y[dzر&ܸVv_)oVwq"=ɤ(^83Xh$*4C}|Sbؼ7̨5RP'Qg~FMm(d藪bj _I:~q_fm>;mnvZp_3X*;_8ɠ-`0>Ub!wSR eDQUm6Q[ 8ZJ J5n[b# dYQ.֨[FNŰb`BvL g8}(v[] $m^X;Cm~p(a4w~ƏeY.{Cدaޢ8QtΨLsT%8rR:qT"9twa\fwƌ>i ?^᭝ݞ؇"PPWD.ImMm1fG:b=cfA&6Jnr;Lӄ$ ؉R/ǬŃQ%Uq&Nyʔr*c R%D[s4ͪ9 C:=szz)yI%?Zt~9ϽGi;4yeE=oD+1hT=j]cse!SznXN=*mh7slTx2EYN*_%ANyXx>m۬%GuCÓH~=ZTu6J԰䛓S6Fՙ>'Xw%s}E8!7|+s0iu5ɿw i!7z/suէ zWڧ>cL`ǜx9 4ZZm4gX7 ;3p\#YQ1Evp" + sTu%V6b3g`(mEE5!|$ux=vE4ugx+3z)xĔsg*(Y>4FU]H8:\F2|U+$[ ,"_r: VO't\a_(Q'> tUZ˥Kl!hIyUƯMI.zYv|UkВ\@ttaYl4sVXV{86#v)WCpvt\c7(̙7]͛ԻOZg% %A2o3+*: b,XGKUT%Տa"ΤL #ԭ _J%OH 4ZPMI;Go'sXޮ7.e $Ѳ谅}Dh*єp0j*,eQX23}Qk楟®qXyj&nN1sD7N>g@ vpBR"> z7R "\PQB33?`T+ꕑP.q:@2W' p6y"No'6W0u y@YT`XA;mb]՞ /QMYt N RԬСDh ]R}I 9h̳q.5gaktm ֐XaLqcE!~qR8of`sc>;A)x+"lsc6ֺˠu{u8c!(`@`4~ro]^@&tTW ~Pł"i'MQeMʊ%dӣ`R̆7]dɩHkyIwSѣL7iôiycxQ-Fd9ߪ\HHT Uwpic{Umnϳwp`,I 5}=& $]:nmw661JZW4pRxA~zuJun@P}wކtbS y ZjtGv侧A67v!wؗ3~<<<5]WoL 5^ D ͥ=͒ݕ"F3vidm>:SO_bHwsAī=8:'HfQpӽYi}3wDګ쯏=FapZ%$qJ`ʓ[܍'d=3hlzhP1ܧS- _O $8 >/uj<4䄊'[Tdd]F2um.Yh}4niPQyR.sfAfbn {[ ڀ+D$Oɋf:r.RkZ_veIz^O=<%$>^4wj7,wGh1w71K4X?MFqZ#ᚈ㬂ױ|1z_Uniէqܒ8^|<oTe\y;C5;*v}mdߩwhOҜ%*ܹ׈ ohEqYT1vLjnj]3R 6T$׾Ut.Q]i7J?S0ΧaT=Q`n&6:$ B)QƉuXD,L;n/n ΒƩ/k _>;|#YzMyL9y_N{y)ss¾$ͅnGw#I  EXHE]0VJ %^YdH:Q`in=eXu!9C?/N Vb^4P폑Ox2J^YNB>}:U"":n7>=O`Dj=.Sg֭3FSVtzv #FZ0s񬬓q46ёWJs|?w[a:3Prľ4:4YES^2Jڻ'vomN&W" QQ-WUmn&Lf Q(!] s_tbA6gV DdM8." >bÑ ?ifL#{DGPf^^|۰zyyXդ/ɜ>|6?DFu__%zl.|6#mE+zV8~?K ƒQTdnqWwE2@mjְԴ(Kꕣj Cef(QSsسx'rk6lݏBjRԿ'XsUݢ>%b7 #v[2ݛXoQhQ 6ek^]o-*o83*}Ù2 Ƥ~Kw76~'z\(* UA$-5@SUP<;_Go(|7}yOWC( #9cr7z v,î.`ƽͫyNw 9&uUxӅE;%1XɄ:[t]%wHx U=3_l7xD'D WZū^ލ74=pnC'mSի66*Rms9]P/FѹVEU 9 /3ly wrgMbzLÌぇ~nM$_[{OjB>cX(NlsAHUHF~2>aAp! &ME9=D==*&iRz\_:.yWFo^JÔ;Mq79|&{tJu^3nxȃ  -s'{GS/5&4"[ H}v]$wUP*"\"-1PWzDG}uB<0a>SJ!6jEjQBϽ!1t( 0,|z~1{>,Ǟ{^/=Q4b] 4+y,wP z+-ab)dDEPg(/8HH%;;:{ACԀzc8 tAƾ&C —ou@nuv`]z9'C)Mk|3y_fͻ+2~.S@^KVJ&&e.y$!~wdsXRߝ]q3#ǘnLbʾO5h_Lov#Ϩl˙8ІAc[^L^QޔL]jVN@ ЍZN PEn OcE-CᩬWM`FBCЄO$*ϮMC` NtԲr"ē U Ex[>[Pb7od=Ϗ >~9 |T{ă8=I9$%,R.@@gY猍߿VaCҳ'1/eZ n2'"ك*UMε/tT_F$5H Q47rثn]Q ,PHᏳ sUO9ڹV(N4ܡy΍0Fv x-"_N󄏇- ȇy>WŖdꥆǼzz;wUN{T*0J \# [ X?и# ޠm6G 23_M5{W>kFlİ bE/ =RT*wfaT:Lc&oTdt"zcD1A/tZz )k)vPlj/ 6Vw^DAQ * gYV$So/.y?RX\^mf7fOĶt:Dd9ͽ)BzR~YhL=aE ΐGߧ FD\OĨyt]`K:\X0lwRKubkxD:%t/,B Y&/b^=*eaUY}ִ97ld%ѡ$@@ߓrxJ]߭%v 5;㏻٥<,ؤ~0KyB>5>5Z ֽ%ռ|'mv<>i%k2WtXȹ'׍czW^ b GgDĶ_ĺ;5ڳ3[N U 6csDJ:j!o'!90 кrZ# vn*i?B5x'>/"/^>ZKl1 (3ջn`Is y!ޑ,lۮ?v8M=n\벘a*bY{&22}5WxpO6y:>%WW𯋯T*(SWhv!/ D`)`6{t9^:|? XRV< s'ѷݐ>[_Z mHdۚHPnr]ۈ 7=z𨉲d?S{1p/rtRKwq{ \u=s 0+mltSR!6"{^Vq o^95XvGmvu8anמgsLt 6p_@߹RC*?\H96K2F/iSky =$W΢vwCt/xND14Q$͵kx~OF7z()IqiD{;۝1ـ_?<t[>ŇV"};Z;0xpOU˳krح֊rbsQ ^_-i:?*!B>y&ȡ'#gUu4J5)+6V0Vd+kHf(Q85xyg/7#8Dz[.1k=ST,o'ۙ(5^!0蛝֯F$*). B>p\9r'پKfp[Oǂ.* GH(7vëe}>{mΗ`:V`y*FJ60MNַ -=F`qkx3^T}$e ߏ4V[EW=qL(t7쫦#V ޞ isc>%T@/ ze\&aqaCzFB"\ɰ?{3hc]p+BxGWH9G%7[_$$$m e}~~l+<(E48͓ۢٮmٚyqw rc 賌&̠@!ͤ/䥯",xSHsj2njqocz¬T>v 4;T=z_j#D<<<%qOb8] ?`joڣ(|Sۋ#^fuP9פ-e]dpxFGs$|bܤܲ,cTJ 㙄1Y9ejb;cY|q3^zqǛ;rcvOc}iwfH \fs wLJg3Ylw֗}ڿn!suktFurkY]=GiFq96M*ʧ!KtiU*LPo_0?5N1Ll3bv<^9*\>y=Y y7="19tL:(jh^$jY-v]lfdUY}e(#}5Ҥ磱6-jk˓:]Ow9ٶ7ښqI%΂߉حK2 ΅<'8~x? ^;<-햦ts*;1(`,JLTs-6Ql#~9ޤWh-":Is߄3GdhW¸g-ۯG͵zn~ncG vɳ˜8}9󋒍'Mk` T~b./Ò8m1; {*pAD9N>tɪL?uIbf~;LtEK(FIAiUʎNsF.!جKՍ?WP'7ECe{Ot>_0% +Vv3vi)m{5<(Mp? oydFgSkU@r'i-=a,UPpQ0!σ1CSo#eE6;?,^3 #8L+?凴UcE"uSA˷>y8Ȣ4mgI%"xá-3A#GAFI$ 5/T7imV Î(GO|&j)(!7Փ@ij4f0wǙX0# UG G}P-2n}$rY"fr_+n5 -wն~PFnɽK '/j*@K˓!Qn Te|q3AUA8 +N:7ƷMz1Yr:I(84GT/tf/#cW&5yY9`\l7m4-9gLgPMz19E*R1N fnM\*@u{(6.z4DzGos4"dSU5)M[^ՕʀLFq-sE!1rk}`fٌiqViAؤ4ż<+#u|,ﯬ\<۵~_Y$GdBc —nöxpu37o9m>l P�U|{06oP)[uŐxHyk4)?G$ u xXLiЦ,4IaS\~~ЭKeρ$gQ,M~8{ߡv7'un~0'L%)ARx{ZdSxTOQɈ0ZO؛o')?hCVSS>}&XQ@Q2T^#54hG3t5p|=L#euNҿ[-A+K*,7Δ;mQ9xpO-ῥEXc83l[o\*L-M_ڛ-6A oBbZͣ>'w.ܭےҩ#)n&2Uf6xgϪXq 7G~BI:;\ ,Hڊ#vp 5:HaTAJlۀZԾ.0g%G_.q:\AVldː_he5m2/|ao94sM:a+>lDFЋr Yd% %;Vf_^Qh}BEJkZMdc+n1$ ! QGbYNn (Xe,OD(#'WZ~?縛#B'8?uiq%EϼcKPl9oD۬gws-7gw@D9!(/ 傐^~ e'r-.翷 {ǫ&cG7BlZ3!sQw~Vy:<}M/`WPRh (mc`ک~{&E pp O$u5:FZȾ{l43̭)DHz?{s`.B3|5;OCJo, Լ^aɻJ~Y:꒻hSG68rwkuo,`hHSͫ};mdA7x8ǗOJ ?.On| +%BY$}?Mn!u FNd~ ۑJQGd:@G0MbjI?cB NsI $sTDl0wْTgPtB4kPx͂bë\& R"F *}ղؒ}eD& O_OY C47}^mp< \r/⾙xb ?ZԹV6CmI^8d"#τwǘ9BH Z0԰o&oWsPAwӾ1kru c̷隿SOߛ|fY+.]qzmgYr5/x P?:1yҙzR p?OOOHwWžѻGDG]| 6J,Kz$6B,@z~LV}">v`x<6/>"pgzYo聓(:(X_--Euk[ar'(P@R \5N?$9JP_iPPd˰HO Q9Wb'p4r8grņd NF( cmOw9mrAw3j0#kOQSCj NYWd1p]fRxu+1s$=(yO7`ŐR$rS}<:N'=劢yL!@tI PQ(ʼn W $*@"L0?y4sF( J D>灅M0ꏒ l;`vw.þ8u!iuv] AQbߘ2;+a迡d<ߐ3m5Gݿَ !c#}ޛ?%ͅ>!}Kǫs9m%9O4g5|Y,`Rvt%z"w>yUJۖW7ש~o=}Nf,v GP:ņv8i>xϏ72ݿt*K=%(}sۚo Ń(Ȅ@7Q: di`ܫ#snr3ueÿmgPc4أo"7mөF߄^8Wmќ].u| ػV|wu% ^c}h'pkhtN;Wc\(ړ/A]'Ճ<qu{5q>)Ӛz}ѵ6̲=m/D);Z݄|]Z쿚o3 ֚:J]s:m#yn˧L ]9 DkQ2Q(>g{Zdm^ႤՖCo\Q+>Uk ة[P^N ?U`B޷Ԯz̰@ Fj3N_CXVUH2:dqf# ,蔢ڌBAQ"/ uoa'AT-]]q.ƣ٧rv<4\m-Yeu'Y|UТ'84pYk 9uR*w?k¶BgkC`YS>y~i{=?=#B}WYPm{,i7ZCQhqˣV1CU''J3C M8:T| Ϫ)U 61ǟZL{NUVV3:l(WDxy "}P\?>kdzggGoW=] ;BlO$(I?a͘iJLIk%A4Ry.)T-Ƥ3g{! 91i?͉C@100m)}{??$y~NU GɶY#Y WrK[,60 K;J/0g ^Wъq"[nw|bS^+-h;?n_gӨoWCGD_n8xY ,0VuVX!Mex@aL1͂sD"?\5_;7IV ܷٗ[FgF} N?lSA!VgCKȯ~8 _g1$=PS~T?XES@BlRs~7 pDm_T/},`]XMlMqeT`(܏Ѱ"kxy?OlfvSoݷS [5 B'rDՐOrHAkg9(c &%$Iҙ oO׹m \z6Me};̹P:rXE+!KֻlM y) COw RQN/|H(Gji$ͯ1&ZNS^;m?i]Mơ9r$xkۖ(nON_o)ThK!ZS`ľUX#KVq,f#Z T!}4-bB1iƥC7RA`A谺HDg ڲ AE඀o"~$Ik6w9ˑDc>BP w ET1XZifߵ.aSB{ n$;ؕ}9y3@x_NFysU=>q^f)2$PZ|\-/5.x?cΗ0#qFߖDP-sgvk.Р&IOV[g/adE&ձ2YIӘo,nҷkx ^mu=_fx/Xj'7,' ,pZ[H;^(2@"@i(0iY W" q|T&bQNgK~-e!T_IgI-UޝD=^ve]Uu,M|!je(;`vHfr'8 F.(g0-᧢Gm[MՄ0k6Jl.wETz1 ]ex_lG`"lA*o>NZ2SC"<{}F5~'a|.ߣ[ݵ'g` d=vNlS%tJW>;p\Qr Au/wuQ.\uX5b @ bT5Iu̐h"GC0+eы){VO:T*t֕q*cb(>XCy!/#62ϖ|V ׽=pqe~DsAA<4d+Wxi=QÜ{.ŠᲠToM57Yb]TZԴ60F=X GW+[1ajf%4Ƞi2C46**h+'gsը3}(%5۷/ho$`DDNoDZs|#F#a`3˕_"m4 ~wwɛEYg8+w7]6; ~ȭ뛞:,s/ľk[&!XOEIB1hCI"^ϻB26ꃙ͐?c\~W˪Q!@NYlQַlaa)ʪT]zR9,N:8q2\e-O׌m50c'0R/^i:H9ʍ; Z'U ^p 2祬y:ȱy}3X{ǣL3%,EvYB=[:21y/ڐ$e$4JH{qH5[_UV*+^-3-IՔ&9 ~>wP_b[xyr*_ Sؓ1*YC\c7nژY're]v8%\ڼ_|bNX4 ܘC^ػoۇudA]*YVcTZ~-+\GluΉ|iHgKB $S._D[ MeN<{nb V 뛿&r#8[w;˹(J*4*V(D_VK$Jr|H.e:8]^9#CRW3fr*% =Vx_8;]˲dY_nIkMrnb-yUh? :5sCyay]+a[=9YwDmzI:NM³e iDUC 0 v?u;=6܉4!+cS>Ic`ex]x.O2NVi,P&q3~@? >䕴s)X4֞]%v맺ET7s8V2edZWFyYiyPMX}l!es@!ï<~BQcm"ɇk$.n5bЊG8XeizdO^j&mm^.S X!={lg勬!m cyDİor_PW S|{lzSzgw7wit*{BV2+ *;MG7BqsC)暹w? E*ר&:|hQ@qz\uq+/VOW3vu[cj?&2X`Z`<"SP97Lcl Nþ=*Gvwv$9&&;d'C־TIp+]m瓪'=n%y0PN+"o ,I]qʰ|XZkB>0< cjB՘]n|[dsF$YX |\ov?@YXyȑ+3>߶'?xFx }b'U!2isfB@)ɂ0dzDD#8OQFE tN9Go>vwڀEK~OFPM"(\F?#.\*9 ۸ ڏ`8A$-+0Qk[Zm&c?xhj5N@$!n meKU1wԴ@TDC$+\N`R@łW-0AǗy/(}g!ːALj yV"xg/O=|Fu.QFo35%6tcFl S& PDkAjl(qy HOC  DloI/ԂRg F@qw㵾w7/ n!IeH܈ W'.Y>A(?A 2w> e_9@~9?;u]d`~yo?6}xyBBu\;" {K>mߩw숀ab> gy.<ąl^. J?z #S\v y{ `@bd1@ͺlS ^;`Kl;Kpe6후C)j"IN ݆ā8ؗC)[m~ǵxW%};vۜ9(~Ps}bL=uEjM-sl~1W^ށC A 4 D!Sbv2QМaњֺ7*G;>#%+f}fY_ HpZ &SNU|s.VTHhRLt'W_N:;ocC N,̆&7ZVJ |KV d iK$k<(`0\b1Mt# $g!_-bMbHѴH "F[֦V0XF7o.[h\rjKup)Gr+Ư,ifΝ\'C1UꩼBB?Cw_$@7L,PhlP;1jQ(#Ջ~:8[_yjn<;bv~$Ğ6ou9+#|t+oiX~/g @wMl,Zg`]FJJòݖf8!c'n׼u2N,eVutu箌]Oaۤ3x9ufjU6j +~Y8kWhz(pTK 7W=n2/]nVba+ET"uƩ0'\ O::, _;1u_-npTRc i 1DA j@ r;s7>cE-H4ہ;WV\  $!nA@ [4Mw0npp0[ݫGm,Wj4II*]X$W579r5+t4#wEM@<Ng"jzdȃrݗ7aii-DglM¿CImZ/}񚺎Hl\HEϜ_7xSySq+٘0}G׌ɀ%᩸Ì6Y7eaP²col[dVmǵjp/$l@/SF/f-LǪf&6vnlDiFEXDQje%iG1&s^hbwFaΖ zҕ+s.C}; 1p]s;1|U.Qg1xnd!lQ  mrDW ܯ[ZS8SAvT%]VZ꾋;AHl.sGWOmi\<53>%W,-ҍϴ Zq_jOd2u5R_?"-SUhpf6vժX`\kvz-ŖeX 0􎕳ޓ`GTh%Z@ՁLљUIQ1'KIGb \Ԃ2G3O'!Akd8~&/ VƊ>?mT]g~w~vAxe?namhh0etnk+U Yy}>X)AE!G>>H(|(Z5hA <ݍ):)0^;!~7.$9otezm ^5'E.AgpyIKVe4%KDul Ole4Aڝ?t ϙ;G[v}9KזߐM<76/wG8גy1Hly='J lOJX}9uԆdJi-c8=mrqҦ?ӫLCzk>rrOva#iNE/[(" NaIRS|9v.vgy@|}(9bw f6BMs?"}c8p{HkwF5K Hj*l cB9za;Yr|?V3g̅!3I2xFܙ0b@Kؐ:×50`-硍9Yp= TR*|`lNހ*rˊ#f<4g{zEq_Qv:)I#Woz{fCc.0<ឫm?ᲊt;yAP. @!GpE3B@Liߧ]G?awWƶI)\p݅nA*D~2GቔIl†BHahQo[`x ;wlVvÙ+,wm]q&=P0;.Þ΃!@onF"T (((j(j(j(j( Z B&>lirD 4)?O.^fMۯ.Ȼw\+ueH\: ZBMAשtG۾D&=: Ec=:xp&bOcR_4@,r)d-eRrmж`ϟSc$D)w]}@2#?'*gc3z8nJ5feBf$P U %@TEUUM #0DHCBPRP0H7lv8j"B$d$hhhaő1E+(b4KH#DHD!$$! ) B) Bb"j("(zet2@>`tԼ-3 O|5~=7_7cGw ڂGce]Lۓχh@;LM1$: ז Z D|+sd#H9͕-N&`njooR:Y5l&9j<_YL 'h/`: =*DU焪H[ٺ&DN-0m;7=m~4dGXA;JߦO@oO5F~c㓇ƽ.@M[kn=ջ %s mg@U! ad"Z匟9BCivݷ}Asi:'l$z>s}CK;1 f0 R@BGG)9_o̸K 63|z.LkXFf&$m1Tɾđ mڜlOjGB3 0l;CibC_ :oG@vjv쓟o$9'dy,tp=F2͖ ~vi{k) I&̣6uH1# @_ tD!@" g㠴x%9DtH#|V.m@nJND;'i܆ޫ]WX9뤸DCzV|歙A T T@U҈Dȑ(OrċH@J0`_0M<SE\*" ϙE~.D B)*Ȕ?TkQW*W@ TQd(!Mb*C9P=0@J kK7ңlPL4!AK(ZD<[MZ@!ށ&l Y^<|[H^C[y3'ǯvR-8ĨYvH *qDr,n,O=<8㣄2fI&HS^%M@ˏ=jp@A0/kfA /ʼ8kN0,#Yfy"؉$T? ө&<>Nc6WqF?Bh8&  L82Dz`35"-`?XW#k]](\!EJ-BiIBVWav.3SFoJF9\DK+T X bU}tGgcuI izDA)x~JӠ+m~ZĈ92{/Sﰨ@"-ؑ.[y]jy`d:2-؇JztPDL@ܦ &o]Qe w` :WQek9(wN"80dpZm6&\u-Iﴢv'?Ҕ>P9[ (*b)!|"eD {taÌedg{VC0PWu@oKQM']r@2dpx-̾֎,8TEN{fx'e=DHf`f|Bq F[ Q>0C3J`{Go7zO}.޺F.I>4~ww?[¿ՖnvcOi=h}u{g%/o{SOk6p>Ʃʭf@$RHd#\`3j#7WGcX;GfBGy0@g:j;4 Q /<@<{>^^ğqD3י~ 0͞cJyg%Ǩ@A3onpt?+JvBE~[/1i  C#ƀ4tO%pUR(v"_apYbM"9?Nqa;T[+w^podO/![gk5KeO[=/S8ۗy.']tvTzl0B"|£;U&f\FfjBOHA9!(U>}} k#yܛ[7g<1RT{-wg6W-dZiG6?珮Ӛq/XpCPXfrt @V?mpԢ#%?,^vVoe{[zFݡ[R.27],KQ@:s,ċI$pܶET%%x:)S{JW[JFR RpXlz)zJc1tA#vid))Hֶ2>Sv#fS|]c䝤TLp }olUCq[,,M6{8n~ވ385;3+i@tu5Mi2D#_y7p&dtU64J?ݹYQϪů:LZiE>-]?kw4Ș+zu\a5P,3#yA\@Dz!_5@A^|oӭF%f O"u_zت7cL e}XaFɵ$۴髵T1&|!rr0Sb) |.d +{?LKdkQcX5/k+~=/|F(NuDPHu! AO+U#!P̈ ^?f_ bȣ>Яr6>9J| &#~}2lyt|HbR iCv %\?tacyȏWW盥f>aZ;84sls?u^PL4$!6we[9Qks<y@F`ZZEqX,md_ʦMBngn]|-`!XYC nzo;Q8!-#QlTy1O,{WD{۝n~ob׭gܹs`vI 3ffk/.Gdz)n#ku:񕲵y5 6ZR) kQFw4 Էbfb99zV4jv 0 f9+> T-'ziZ3\%wvS%$D.=KC}C(@bxռKϾz X 45j}=#P~h:,zis ~UNr~~Vgq,%WT )KU<pGJEt?_ <`0lBR&)Ct1(&w;ǔ1lDžwvTQU_ 0jy|;V % KDb1f ~-34~NF[QH%> 5 llF_ߝ{]Euaaw9b۫ #kKZ0xui A%zU`zCݲM[/ċGcE3m_9e;~A )#S[#=   L{'ٴRk{Š!^ /5]U5S;P4i'<`nzw 0 KY&#fؕL1JƙDTJq~yl#9sx:9;`o"@Ѽ%m!wteJ