sec-irq.c 6.9 KB
Newer Older
S
Sangbeom Kim 已提交
1
/*
2
 * sec-irq.c
S
Sangbeom Kim 已提交
3 4 5 6 7 8 9 10 11 12 13 14 15 16
 *
 * Copyright (c) 2011 Samsung Electronics Co., Ltd
 *              http://www.samsung.com
 *
 *  This program is free software; you can redistribute  it and/or modify it
 *  under  the terms of  the GNU General  Public License as published by the
 *  Free Software Foundation;  either version 2 of the  License, or (at your
 *  option) any later version.
 *
 */

#include <linux/device.h>
#include <linux/interrupt.h>
#include <linux/irq.h>
S
Sangbeom Kim 已提交
17 18
#include <linux/regmap.h>

S
Sangbeom Kim 已提交
19 20
#include <linux/mfd/samsung/core.h>
#include <linux/mfd/samsung/irq.h>
S
Sangbeom Kim 已提交
21
#include <linux/mfd/samsung/s2mps11.h>
S
Sangbeom Kim 已提交
22 23
#include <linux/mfd/samsung/s5m8763.h>
#include <linux/mfd/samsung/s5m8767.h>
S
Sangbeom Kim 已提交
24

S
Sangbeom Kim 已提交
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
static struct regmap_irq s2mps11_irqs[] = {
	[S2MPS11_IRQ_PWRONF] = {
		.reg_offset = 1,
		.mask = S2MPS11_IRQ_PWRONF_MASK,
	},
	[S2MPS11_IRQ_PWRONR] = {
		.reg_offset = 1,
		.mask = S2MPS11_IRQ_PWRONR_MASK,
	},
	[S2MPS11_IRQ_JIGONBF] = {
		.reg_offset = 1,
		.mask = S2MPS11_IRQ_JIGONBF_MASK,
	},
	[S2MPS11_IRQ_JIGONBR] = {
		.reg_offset = 1,
		.mask = S2MPS11_IRQ_JIGONBR_MASK,
	},
	[S2MPS11_IRQ_ACOKBF] = {
		.reg_offset = 1,
		.mask = S2MPS11_IRQ_ACOKBF_MASK,
	},
	[S2MPS11_IRQ_ACOKBR] = {
		.reg_offset = 1,
		.mask = S2MPS11_IRQ_ACOKBR_MASK,
	},
	[S2MPS11_IRQ_PWRON1S] = {
		.reg_offset = 1,
		.mask = S2MPS11_IRQ_PWRON1S_MASK,
	},
	[S2MPS11_IRQ_MRB] = {
		.reg_offset = 1,
		.mask = S2MPS11_IRQ_MRB_MASK,
	},
	[S2MPS11_IRQ_RTC60S] = {
		.reg_offset = 2,
		.mask = S2MPS11_IRQ_RTC60S_MASK,
	},
	[S2MPS11_IRQ_RTCA1] = {
		.reg_offset = 2,
		.mask = S2MPS11_IRQ_RTCA1_MASK,
	},
	[S2MPS11_IRQ_RTCA2] = {
		.reg_offset = 2,
		.mask = S2MPS11_IRQ_RTCA2_MASK,
	},
	[S2MPS11_IRQ_SMPL] = {
		.reg_offset = 2,
		.mask = S2MPS11_IRQ_SMPL_MASK,
	},
	[S2MPS11_IRQ_RTC1S] = {
		.reg_offset = 2,
		.mask = S2MPS11_IRQ_RTC1S_MASK,
	},
	[S2MPS11_IRQ_WTSR] = {
		.reg_offset = 2,
		.mask = S2MPS11_IRQ_WTSR_MASK,
	},
	[S2MPS11_IRQ_INT120C] = {
		.reg_offset = 3,
		.mask = S2MPS11_IRQ_INT120C_MASK,
	},
	[S2MPS11_IRQ_INT140C] = {
		.reg_offset = 3,
		.mask = S2MPS11_IRQ_INT140C_MASK,
	},
S
Sangbeom Kim 已提交
90 91
};

S
Sangbeom Kim 已提交
92 93

static struct regmap_irq s5m8767_irqs[] = {
S
Sangbeom Kim 已提交
94
	[S5M8767_IRQ_PWRR] = {
S
Sangbeom Kim 已提交
95
		.reg_offset = 1,
S
Sangbeom Kim 已提交
96 97 98
		.mask = S5M8767_IRQ_PWRR_MASK,
	},
	[S5M8767_IRQ_PWRF] = {
S
Sangbeom Kim 已提交
99
		.reg_offset = 1,
S
Sangbeom Kim 已提交
100 101 102
		.mask = S5M8767_IRQ_PWRF_MASK,
	},
	[S5M8767_IRQ_PWR1S] = {
S
Sangbeom Kim 已提交
103
		.reg_offset = 1,
S
Sangbeom Kim 已提交
104 105 106
		.mask = S5M8767_IRQ_PWR1S_MASK,
	},
	[S5M8767_IRQ_JIGR] = {
S
Sangbeom Kim 已提交
107
		.reg_offset = 1,
S
Sangbeom Kim 已提交
108 109 110
		.mask = S5M8767_IRQ_JIGR_MASK,
	},
	[S5M8767_IRQ_JIGF] = {
S
Sangbeom Kim 已提交
111
		.reg_offset = 1,
S
Sangbeom Kim 已提交
112 113 114
		.mask = S5M8767_IRQ_JIGF_MASK,
	},
	[S5M8767_IRQ_LOWBAT2] = {
S
Sangbeom Kim 已提交
115
		.reg_offset = 1,
S
Sangbeom Kim 已提交
116 117 118
		.mask = S5M8767_IRQ_LOWBAT2_MASK,
	},
	[S5M8767_IRQ_LOWBAT1] = {
S
Sangbeom Kim 已提交
119
		.reg_offset = 1,
S
Sangbeom Kim 已提交
120 121 122
		.mask = S5M8767_IRQ_LOWBAT1_MASK,
	},
	[S5M8767_IRQ_MRB] = {
S
Sangbeom Kim 已提交
123
		.reg_offset = 2,
S
Sangbeom Kim 已提交
124 125 126
		.mask = S5M8767_IRQ_MRB_MASK,
	},
	[S5M8767_IRQ_DVSOK2] = {
S
Sangbeom Kim 已提交
127
		.reg_offset = 2,
S
Sangbeom Kim 已提交
128 129 130
		.mask = S5M8767_IRQ_DVSOK2_MASK,
	},
	[S5M8767_IRQ_DVSOK3] = {
S
Sangbeom Kim 已提交
131
		.reg_offset = 2,
S
Sangbeom Kim 已提交
132 133 134
		.mask = S5M8767_IRQ_DVSOK3_MASK,
	},
	[S5M8767_IRQ_DVSOK4] = {
S
Sangbeom Kim 已提交
135
		.reg_offset = 2,
S
Sangbeom Kim 已提交
136 137 138
		.mask = S5M8767_IRQ_DVSOK4_MASK,
	},
	[S5M8767_IRQ_RTC60S] = {
S
Sangbeom Kim 已提交
139
		.reg_offset = 3,
S
Sangbeom Kim 已提交
140 141 142
		.mask = S5M8767_IRQ_RTC60S_MASK,
	},
	[S5M8767_IRQ_RTCA1] = {
S
Sangbeom Kim 已提交
143
		.reg_offset = 3,
S
Sangbeom Kim 已提交
144 145 146
		.mask = S5M8767_IRQ_RTCA1_MASK,
	},
	[S5M8767_IRQ_RTCA2] = {
S
Sangbeom Kim 已提交
147
		.reg_offset = 3,
S
Sangbeom Kim 已提交
148 149 150
		.mask = S5M8767_IRQ_RTCA2_MASK,
	},
	[S5M8767_IRQ_SMPL] = {
S
Sangbeom Kim 已提交
151
		.reg_offset = 3,
S
Sangbeom Kim 已提交
152 153 154
		.mask = S5M8767_IRQ_SMPL_MASK,
	},
	[S5M8767_IRQ_RTC1S] = {
S
Sangbeom Kim 已提交
155
		.reg_offset = 3,
S
Sangbeom Kim 已提交
156 157 158
		.mask = S5M8767_IRQ_RTC1S_MASK,
	},
	[S5M8767_IRQ_WTSR] = {
S
Sangbeom Kim 已提交
159
		.reg_offset = 3,
S
Sangbeom Kim 已提交
160 161 162 163
		.mask = S5M8767_IRQ_WTSR_MASK,
	},
};

S
Sangbeom Kim 已提交
164
static struct regmap_irq s5m8763_irqs[] = {
S
Sangbeom Kim 已提交
165
	[S5M8763_IRQ_DCINF] = {
S
Sangbeom Kim 已提交
166
		.reg_offset = 1,
S
Sangbeom Kim 已提交
167 168 169
		.mask = S5M8763_IRQ_DCINF_MASK,
	},
	[S5M8763_IRQ_DCINR] = {
S
Sangbeom Kim 已提交
170
		.reg_offset = 1,
S
Sangbeom Kim 已提交
171 172 173
		.mask = S5M8763_IRQ_DCINR_MASK,
	},
	[S5M8763_IRQ_JIGF] = {
S
Sangbeom Kim 已提交
174
		.reg_offset = 1,
S
Sangbeom Kim 已提交
175 176 177
		.mask = S5M8763_IRQ_JIGF_MASK,
	},
	[S5M8763_IRQ_JIGR] = {
S
Sangbeom Kim 已提交
178
		.reg_offset = 1,
S
Sangbeom Kim 已提交
179 180 181
		.mask = S5M8763_IRQ_JIGR_MASK,
	},
	[S5M8763_IRQ_PWRONF] = {
S
Sangbeom Kim 已提交
182
		.reg_offset = 1,
S
Sangbeom Kim 已提交
183 184 185
		.mask = S5M8763_IRQ_PWRONF_MASK,
	},
	[S5M8763_IRQ_PWRONR] = {
S
Sangbeom Kim 已提交
186
		.reg_offset = 1,
S
Sangbeom Kim 已提交
187 188 189
		.mask = S5M8763_IRQ_PWRONR_MASK,
	},
	[S5M8763_IRQ_WTSREVNT] = {
S
Sangbeom Kim 已提交
190
		.reg_offset = 2,
S
Sangbeom Kim 已提交
191 192 193
		.mask = S5M8763_IRQ_WTSREVNT_MASK,
	},
	[S5M8763_IRQ_SMPLEVNT] = {
S
Sangbeom Kim 已提交
194
		.reg_offset = 2,
S
Sangbeom Kim 已提交
195 196 197
		.mask = S5M8763_IRQ_SMPLEVNT_MASK,
	},
	[S5M8763_IRQ_ALARM1] = {
S
Sangbeom Kim 已提交
198
		.reg_offset = 2,
S
Sangbeom Kim 已提交
199 200 201
		.mask = S5M8763_IRQ_ALARM1_MASK,
	},
	[S5M8763_IRQ_ALARM0] = {
S
Sangbeom Kim 已提交
202
		.reg_offset = 2,
S
Sangbeom Kim 已提交
203 204 205
		.mask = S5M8763_IRQ_ALARM0_MASK,
	},
	[S5M8763_IRQ_ONKEY1S] = {
S
Sangbeom Kim 已提交
206
		.reg_offset = 3,
S
Sangbeom Kim 已提交
207 208 209
		.mask = S5M8763_IRQ_ONKEY1S_MASK,
	},
	[S5M8763_IRQ_TOPOFFR] = {
S
Sangbeom Kim 已提交
210
		.reg_offset = 3,
S
Sangbeom Kim 已提交
211 212 213
		.mask = S5M8763_IRQ_TOPOFFR_MASK,
	},
	[S5M8763_IRQ_DCINOVPR] = {
S
Sangbeom Kim 已提交
214
		.reg_offset = 3,
S
Sangbeom Kim 已提交
215 216 217
		.mask = S5M8763_IRQ_DCINOVPR_MASK,
	},
	[S5M8763_IRQ_CHGRSTF] = {
S
Sangbeom Kim 已提交
218
		.reg_offset = 3,
S
Sangbeom Kim 已提交
219 220 221
		.mask = S5M8763_IRQ_CHGRSTF_MASK,
	},
	[S5M8763_IRQ_DONER] = {
S
Sangbeom Kim 已提交
222
		.reg_offset = 3,
S
Sangbeom Kim 已提交
223 224 225
		.mask = S5M8763_IRQ_DONER_MASK,
	},
	[S5M8763_IRQ_CHGFAULT] = {
S
Sangbeom Kim 已提交
226
		.reg_offset = 3,
S
Sangbeom Kim 已提交
227 228 229
		.mask = S5M8763_IRQ_CHGFAULT_MASK,
	},
	[S5M8763_IRQ_LOBAT1] = {
S
Sangbeom Kim 已提交
230
		.reg_offset = 4,
S
Sangbeom Kim 已提交
231 232 233
		.mask = S5M8763_IRQ_LOBAT1_MASK,
	},
	[S5M8763_IRQ_LOBAT2] = {
S
Sangbeom Kim 已提交
234
		.reg_offset = 4,
S
Sangbeom Kim 已提交
235 236 237 238
		.mask = S5M8763_IRQ_LOBAT2_MASK,
	},
};

S
Sangbeom Kim 已提交
239 240 241 242 243 244 245 246 247
static struct regmap_irq_chip s2mps11_irq_chip = {
	.name = "s2mps11",
	.irqs = s2mps11_irqs,
	.num_irqs = ARRAY_SIZE(s2mps11_irqs),
	.num_regs = 3,
	.status_base = S2MPS11_REG_INT1,
	.mask_base = S2MPS11_REG_INT1M,
	.ack_base = S2MPS11_REG_INT1,
};
S
Sangbeom Kim 已提交
248

S
Sangbeom Kim 已提交
249
static struct regmap_irq_chip s5m8767_irq_chip = {
S
Sangbeom Kim 已提交
250
	.name = "s5m8767",
S
Sangbeom Kim 已提交
251 252 253 254 255 256
	.irqs = s5m8767_irqs,
	.num_irqs = ARRAY_SIZE(s5m8767_irqs),
	.num_regs = 3,
	.status_base = S5M8767_REG_INT1,
	.mask_base = S5M8767_REG_INT1M,
	.ack_base = S5M8767_REG_INT1,
S
Sangbeom Kim 已提交
257 258
};

S
Sangbeom Kim 已提交
259
static struct regmap_irq_chip s5m8763_irq_chip = {
S
Sangbeom Kim 已提交
260
	.name = "s5m8763",
S
Sangbeom Kim 已提交
261 262 263 264 265 266
	.irqs = s5m8763_irqs,
	.num_irqs = ARRAY_SIZE(s5m8763_irqs),
	.num_regs = 4,
	.status_base = S5M8763_REG_IRQ1,
	.mask_base = S5M8763_REG_IRQM1,
	.ack_base = S5M8763_REG_IRQ1,
S
Sangbeom Kim 已提交
267 268
};

269
int sec_irq_init(struct sec_pmic_dev *sec_pmic)
S
Sangbeom Kim 已提交
270 271
{
	int ret = 0;
272
	int type = sec_pmic->device_type;
S
Sangbeom Kim 已提交
273

274 275
	if (!sec_pmic->irq) {
		dev_warn(sec_pmic->dev,
S
Sangbeom Kim 已提交
276
			 "No interrupt specified, no interrupts\n");
277
		sec_pmic->irq_base = 0;
S
Sangbeom Kim 已提交
278 279 280 281 282
		return 0;
	}

	switch (type) {
	case S5M8763X:
S
Sangbeom Kim 已提交
283 284 285 286
		ret = regmap_add_irq_chip(sec_pmic->regmap, sec_pmic->irq,
				  IRQF_TRIGGER_FALLING | IRQF_ONESHOT,
				  sec_pmic->irq_base, &s5m8763_irq_chip,
				  &sec_pmic->irq_data);
S
Sangbeom Kim 已提交
287 288
		break;
	case S5M8767X:
S
Sangbeom Kim 已提交
289 290 291 292
		ret = regmap_add_irq_chip(sec_pmic->regmap, sec_pmic->irq,
				  IRQF_TRIGGER_FALLING | IRQF_ONESHOT,
				  sec_pmic->irq_base, &s5m8767_irq_chip,
				  &sec_pmic->irq_data);
S
Sangbeom Kim 已提交
293
		break;
S
Sangbeom Kim 已提交
294 295 296 297 298
	case S2MPS11X:
		ret = regmap_add_irq_chip(sec_pmic->regmap, sec_pmic->irq,
				  IRQF_TRIGGER_FALLING | IRQF_ONESHOT,
				  sec_pmic->irq_base, &s2mps11_irq_chip,
				  &sec_pmic->irq_data);
S
Sangbeom Kim 已提交
299 300
		break;
	default:
S
Sangbeom Kim 已提交
301 302 303
		dev_err(sec_pmic->dev, "Unknown device type %d\n",
			sec_pmic->device_type);
		return -EINVAL;
S
Sangbeom Kim 已提交
304 305
	}

S
Sangbeom Kim 已提交
306 307
	if (ret != 0) {
		dev_err(sec_pmic->dev, "Failed to register IRQ chip: %d\n", ret);
308 309
		return ret;
	}
S
Sangbeom Kim 已提交
310 311 312 313

	return 0;
}

314
void sec_irq_exit(struct sec_pmic_dev *sec_pmic)
S
Sangbeom Kim 已提交
315
{
S
Sangbeom Kim 已提交
316
	regmap_del_irq_chip(sec_pmic->irq, sec_pmic->irq_data);
S
Sangbeom Kim 已提交
317
}