1*4882a593Smuzhiyun // SPDX-License-Identifier: GPL-2.0-only
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun * Copyright (C) 2004 IBM Corporation
4*4882a593Smuzhiyun * Copyright (C) 2014 Intel Corporation
5*4882a593Smuzhiyun *
6*4882a593Smuzhiyun * Authors:
7*4882a593Smuzhiyun * Jarkko Sakkinen <jarkko.sakkinen@linux.intel.com>
8*4882a593Smuzhiyun * Leendert van Doorn <leendert@watson.ibm.com>
9*4882a593Smuzhiyun * Dave Safford <safford@watson.ibm.com>
10*4882a593Smuzhiyun * Reiner Sailer <sailer@watson.ibm.com>
11*4882a593Smuzhiyun * Kylene Hall <kjhall@us.ibm.com>
12*4882a593Smuzhiyun *
13*4882a593Smuzhiyun * Maintained by: <tpmdd-devel@lists.sourceforge.net>
14*4882a593Smuzhiyun *
15*4882a593Smuzhiyun * TPM chip management routines.
16*4882a593Smuzhiyun */
17*4882a593Smuzhiyun
18*4882a593Smuzhiyun #include <linux/poll.h>
19*4882a593Smuzhiyun #include <linux/slab.h>
20*4882a593Smuzhiyun #include <linux/mutex.h>
21*4882a593Smuzhiyun #include <linux/spinlock.h>
22*4882a593Smuzhiyun #include <linux/freezer.h>
23*4882a593Smuzhiyun #include <linux/major.h>
24*4882a593Smuzhiyun #include <linux/tpm_eventlog.h>
25*4882a593Smuzhiyun #include <linux/hw_random.h>
26*4882a593Smuzhiyun #include "tpm.h"
27*4882a593Smuzhiyun
28*4882a593Smuzhiyun DEFINE_IDR(dev_nums_idr);
29*4882a593Smuzhiyun static DEFINE_MUTEX(idr_lock);
30*4882a593Smuzhiyun
31*4882a593Smuzhiyun struct class *tpm_class;
32*4882a593Smuzhiyun struct class *tpmrm_class;
33*4882a593Smuzhiyun dev_t tpm_devt;
34*4882a593Smuzhiyun
tpm_request_locality(struct tpm_chip * chip)35*4882a593Smuzhiyun static int tpm_request_locality(struct tpm_chip *chip)
36*4882a593Smuzhiyun {
37*4882a593Smuzhiyun int rc;
38*4882a593Smuzhiyun
39*4882a593Smuzhiyun if (!chip->ops->request_locality)
40*4882a593Smuzhiyun return 0;
41*4882a593Smuzhiyun
42*4882a593Smuzhiyun rc = chip->ops->request_locality(chip, 0);
43*4882a593Smuzhiyun if (rc < 0)
44*4882a593Smuzhiyun return rc;
45*4882a593Smuzhiyun
46*4882a593Smuzhiyun chip->locality = rc;
47*4882a593Smuzhiyun return 0;
48*4882a593Smuzhiyun }
49*4882a593Smuzhiyun
tpm_relinquish_locality(struct tpm_chip * chip)50*4882a593Smuzhiyun static void tpm_relinquish_locality(struct tpm_chip *chip)
51*4882a593Smuzhiyun {
52*4882a593Smuzhiyun int rc;
53*4882a593Smuzhiyun
54*4882a593Smuzhiyun if (!chip->ops->relinquish_locality)
55*4882a593Smuzhiyun return;
56*4882a593Smuzhiyun
57*4882a593Smuzhiyun rc = chip->ops->relinquish_locality(chip, chip->locality);
58*4882a593Smuzhiyun if (rc)
59*4882a593Smuzhiyun dev_err(&chip->dev, "%s: : error %d\n", __func__, rc);
60*4882a593Smuzhiyun
61*4882a593Smuzhiyun chip->locality = -1;
62*4882a593Smuzhiyun }
63*4882a593Smuzhiyun
tpm_cmd_ready(struct tpm_chip * chip)64*4882a593Smuzhiyun static int tpm_cmd_ready(struct tpm_chip *chip)
65*4882a593Smuzhiyun {
66*4882a593Smuzhiyun if (!chip->ops->cmd_ready)
67*4882a593Smuzhiyun return 0;
68*4882a593Smuzhiyun
69*4882a593Smuzhiyun return chip->ops->cmd_ready(chip);
70*4882a593Smuzhiyun }
71*4882a593Smuzhiyun
tpm_go_idle(struct tpm_chip * chip)72*4882a593Smuzhiyun static int tpm_go_idle(struct tpm_chip *chip)
73*4882a593Smuzhiyun {
74*4882a593Smuzhiyun if (!chip->ops->go_idle)
75*4882a593Smuzhiyun return 0;
76*4882a593Smuzhiyun
77*4882a593Smuzhiyun return chip->ops->go_idle(chip);
78*4882a593Smuzhiyun }
79*4882a593Smuzhiyun
tpm_clk_enable(struct tpm_chip * chip)80*4882a593Smuzhiyun static void tpm_clk_enable(struct tpm_chip *chip)
81*4882a593Smuzhiyun {
82*4882a593Smuzhiyun if (chip->ops->clk_enable)
83*4882a593Smuzhiyun chip->ops->clk_enable(chip, true);
84*4882a593Smuzhiyun }
85*4882a593Smuzhiyun
tpm_clk_disable(struct tpm_chip * chip)86*4882a593Smuzhiyun static void tpm_clk_disable(struct tpm_chip *chip)
87*4882a593Smuzhiyun {
88*4882a593Smuzhiyun if (chip->ops->clk_enable)
89*4882a593Smuzhiyun chip->ops->clk_enable(chip, false);
90*4882a593Smuzhiyun }
91*4882a593Smuzhiyun
92*4882a593Smuzhiyun /**
93*4882a593Smuzhiyun * tpm_chip_start() - power on the TPM
94*4882a593Smuzhiyun * @chip: a TPM chip to use
95*4882a593Smuzhiyun *
96*4882a593Smuzhiyun * Return:
97*4882a593Smuzhiyun * * The response length - OK
98*4882a593Smuzhiyun * * -errno - A system error
99*4882a593Smuzhiyun */
tpm_chip_start(struct tpm_chip * chip)100*4882a593Smuzhiyun int tpm_chip_start(struct tpm_chip *chip)
101*4882a593Smuzhiyun {
102*4882a593Smuzhiyun int ret;
103*4882a593Smuzhiyun
104*4882a593Smuzhiyun tpm_clk_enable(chip);
105*4882a593Smuzhiyun
106*4882a593Smuzhiyun if (chip->locality == -1) {
107*4882a593Smuzhiyun ret = tpm_request_locality(chip);
108*4882a593Smuzhiyun if (ret) {
109*4882a593Smuzhiyun tpm_clk_disable(chip);
110*4882a593Smuzhiyun return ret;
111*4882a593Smuzhiyun }
112*4882a593Smuzhiyun }
113*4882a593Smuzhiyun
114*4882a593Smuzhiyun ret = tpm_cmd_ready(chip);
115*4882a593Smuzhiyun if (ret) {
116*4882a593Smuzhiyun tpm_relinquish_locality(chip);
117*4882a593Smuzhiyun tpm_clk_disable(chip);
118*4882a593Smuzhiyun return ret;
119*4882a593Smuzhiyun }
120*4882a593Smuzhiyun
121*4882a593Smuzhiyun return 0;
122*4882a593Smuzhiyun }
123*4882a593Smuzhiyun EXPORT_SYMBOL_GPL(tpm_chip_start);
124*4882a593Smuzhiyun
125*4882a593Smuzhiyun /**
126*4882a593Smuzhiyun * tpm_chip_stop() - power off the TPM
127*4882a593Smuzhiyun * @chip: a TPM chip to use
128*4882a593Smuzhiyun *
129*4882a593Smuzhiyun * Return:
130*4882a593Smuzhiyun * * The response length - OK
131*4882a593Smuzhiyun * * -errno - A system error
132*4882a593Smuzhiyun */
tpm_chip_stop(struct tpm_chip * chip)133*4882a593Smuzhiyun void tpm_chip_stop(struct tpm_chip *chip)
134*4882a593Smuzhiyun {
135*4882a593Smuzhiyun tpm_go_idle(chip);
136*4882a593Smuzhiyun tpm_relinquish_locality(chip);
137*4882a593Smuzhiyun tpm_clk_disable(chip);
138*4882a593Smuzhiyun }
139*4882a593Smuzhiyun EXPORT_SYMBOL_GPL(tpm_chip_stop);
140*4882a593Smuzhiyun
141*4882a593Smuzhiyun /**
142*4882a593Smuzhiyun * tpm_try_get_ops() - Get a ref to the tpm_chip
143*4882a593Smuzhiyun * @chip: Chip to ref
144*4882a593Smuzhiyun *
145*4882a593Smuzhiyun * The caller must already have some kind of locking to ensure that chip is
146*4882a593Smuzhiyun * valid. This function will lock the chip so that the ops member can be
147*4882a593Smuzhiyun * accessed safely. The locking prevents tpm_chip_unregister from
148*4882a593Smuzhiyun * completing, so it should not be held for long periods.
149*4882a593Smuzhiyun *
150*4882a593Smuzhiyun * Returns -ERRNO if the chip could not be got.
151*4882a593Smuzhiyun */
tpm_try_get_ops(struct tpm_chip * chip)152*4882a593Smuzhiyun int tpm_try_get_ops(struct tpm_chip *chip)
153*4882a593Smuzhiyun {
154*4882a593Smuzhiyun int rc = -EIO;
155*4882a593Smuzhiyun
156*4882a593Smuzhiyun get_device(&chip->dev);
157*4882a593Smuzhiyun
158*4882a593Smuzhiyun down_read(&chip->ops_sem);
159*4882a593Smuzhiyun if (!chip->ops)
160*4882a593Smuzhiyun goto out_ops;
161*4882a593Smuzhiyun
162*4882a593Smuzhiyun mutex_lock(&chip->tpm_mutex);
163*4882a593Smuzhiyun rc = tpm_chip_start(chip);
164*4882a593Smuzhiyun if (rc)
165*4882a593Smuzhiyun goto out_lock;
166*4882a593Smuzhiyun
167*4882a593Smuzhiyun return 0;
168*4882a593Smuzhiyun out_lock:
169*4882a593Smuzhiyun mutex_unlock(&chip->tpm_mutex);
170*4882a593Smuzhiyun out_ops:
171*4882a593Smuzhiyun up_read(&chip->ops_sem);
172*4882a593Smuzhiyun put_device(&chip->dev);
173*4882a593Smuzhiyun return rc;
174*4882a593Smuzhiyun }
175*4882a593Smuzhiyun EXPORT_SYMBOL_GPL(tpm_try_get_ops);
176*4882a593Smuzhiyun
177*4882a593Smuzhiyun /**
178*4882a593Smuzhiyun * tpm_put_ops() - Release a ref to the tpm_chip
179*4882a593Smuzhiyun * @chip: Chip to put
180*4882a593Smuzhiyun *
181*4882a593Smuzhiyun * This is the opposite pair to tpm_try_get_ops(). After this returns chip may
182*4882a593Smuzhiyun * be kfree'd.
183*4882a593Smuzhiyun */
tpm_put_ops(struct tpm_chip * chip)184*4882a593Smuzhiyun void tpm_put_ops(struct tpm_chip *chip)
185*4882a593Smuzhiyun {
186*4882a593Smuzhiyun tpm_chip_stop(chip);
187*4882a593Smuzhiyun mutex_unlock(&chip->tpm_mutex);
188*4882a593Smuzhiyun up_read(&chip->ops_sem);
189*4882a593Smuzhiyun put_device(&chip->dev);
190*4882a593Smuzhiyun }
191*4882a593Smuzhiyun EXPORT_SYMBOL_GPL(tpm_put_ops);
192*4882a593Smuzhiyun
193*4882a593Smuzhiyun /**
194*4882a593Smuzhiyun * tpm_default_chip() - find a TPM chip and get a reference to it
195*4882a593Smuzhiyun */
tpm_default_chip(void)196*4882a593Smuzhiyun struct tpm_chip *tpm_default_chip(void)
197*4882a593Smuzhiyun {
198*4882a593Smuzhiyun struct tpm_chip *chip, *res = NULL;
199*4882a593Smuzhiyun int chip_num = 0;
200*4882a593Smuzhiyun int chip_prev;
201*4882a593Smuzhiyun
202*4882a593Smuzhiyun mutex_lock(&idr_lock);
203*4882a593Smuzhiyun
204*4882a593Smuzhiyun do {
205*4882a593Smuzhiyun chip_prev = chip_num;
206*4882a593Smuzhiyun chip = idr_get_next(&dev_nums_idr, &chip_num);
207*4882a593Smuzhiyun if (chip) {
208*4882a593Smuzhiyun get_device(&chip->dev);
209*4882a593Smuzhiyun res = chip;
210*4882a593Smuzhiyun break;
211*4882a593Smuzhiyun }
212*4882a593Smuzhiyun } while (chip_prev != chip_num);
213*4882a593Smuzhiyun
214*4882a593Smuzhiyun mutex_unlock(&idr_lock);
215*4882a593Smuzhiyun
216*4882a593Smuzhiyun return res;
217*4882a593Smuzhiyun }
218*4882a593Smuzhiyun EXPORT_SYMBOL_GPL(tpm_default_chip);
219*4882a593Smuzhiyun
220*4882a593Smuzhiyun /**
221*4882a593Smuzhiyun * tpm_find_get_ops() - find and reserve a TPM chip
222*4882a593Smuzhiyun * @chip: a &struct tpm_chip instance, %NULL for the default chip
223*4882a593Smuzhiyun *
224*4882a593Smuzhiyun * Finds a TPM chip and reserves its class device and operations. The chip must
225*4882a593Smuzhiyun * be released with tpm_put_ops() after use.
226*4882a593Smuzhiyun * This function is for internal use only. It supports existing TPM callers
227*4882a593Smuzhiyun * by accepting NULL, but those callers should be converted to pass in a chip
228*4882a593Smuzhiyun * directly.
229*4882a593Smuzhiyun *
230*4882a593Smuzhiyun * Return:
231*4882a593Smuzhiyun * A reserved &struct tpm_chip instance.
232*4882a593Smuzhiyun * %NULL if a chip is not found.
233*4882a593Smuzhiyun * %NULL if the chip is not available.
234*4882a593Smuzhiyun */
tpm_find_get_ops(struct tpm_chip * chip)235*4882a593Smuzhiyun struct tpm_chip *tpm_find_get_ops(struct tpm_chip *chip)
236*4882a593Smuzhiyun {
237*4882a593Smuzhiyun int rc;
238*4882a593Smuzhiyun
239*4882a593Smuzhiyun if (chip) {
240*4882a593Smuzhiyun if (!tpm_try_get_ops(chip))
241*4882a593Smuzhiyun return chip;
242*4882a593Smuzhiyun return NULL;
243*4882a593Smuzhiyun }
244*4882a593Smuzhiyun
245*4882a593Smuzhiyun chip = tpm_default_chip();
246*4882a593Smuzhiyun if (!chip)
247*4882a593Smuzhiyun return NULL;
248*4882a593Smuzhiyun rc = tpm_try_get_ops(chip);
249*4882a593Smuzhiyun /* release additional reference we got from tpm_default_chip() */
250*4882a593Smuzhiyun put_device(&chip->dev);
251*4882a593Smuzhiyun if (rc)
252*4882a593Smuzhiyun return NULL;
253*4882a593Smuzhiyun return chip;
254*4882a593Smuzhiyun }
255*4882a593Smuzhiyun
256*4882a593Smuzhiyun /**
257*4882a593Smuzhiyun * tpm_dev_release() - free chip memory and the device number
258*4882a593Smuzhiyun * @dev: the character device for the TPM chip
259*4882a593Smuzhiyun *
260*4882a593Smuzhiyun * This is used as the release function for the character device.
261*4882a593Smuzhiyun */
tpm_dev_release(struct device * dev)262*4882a593Smuzhiyun static void tpm_dev_release(struct device *dev)
263*4882a593Smuzhiyun {
264*4882a593Smuzhiyun struct tpm_chip *chip = container_of(dev, struct tpm_chip, dev);
265*4882a593Smuzhiyun
266*4882a593Smuzhiyun mutex_lock(&idr_lock);
267*4882a593Smuzhiyun idr_remove(&dev_nums_idr, chip->dev_num);
268*4882a593Smuzhiyun mutex_unlock(&idr_lock);
269*4882a593Smuzhiyun
270*4882a593Smuzhiyun kfree(chip->log.bios_event_log);
271*4882a593Smuzhiyun kfree(chip->work_space.context_buf);
272*4882a593Smuzhiyun kfree(chip->work_space.session_buf);
273*4882a593Smuzhiyun kfree(chip->allocated_banks);
274*4882a593Smuzhiyun kfree(chip);
275*4882a593Smuzhiyun }
276*4882a593Smuzhiyun
277*4882a593Smuzhiyun /**
278*4882a593Smuzhiyun * tpm_class_shutdown() - prepare the TPM device for loss of power.
279*4882a593Smuzhiyun * @dev: device to which the chip is associated.
280*4882a593Smuzhiyun *
281*4882a593Smuzhiyun * Issues a TPM2_Shutdown command prior to loss of power, as required by the
282*4882a593Smuzhiyun * TPM 2.0 spec. Then, calls bus- and device- specific shutdown code.
283*4882a593Smuzhiyun *
284*4882a593Smuzhiyun * Return: always 0 (i.e. success)
285*4882a593Smuzhiyun */
tpm_class_shutdown(struct device * dev)286*4882a593Smuzhiyun static int tpm_class_shutdown(struct device *dev)
287*4882a593Smuzhiyun {
288*4882a593Smuzhiyun struct tpm_chip *chip = container_of(dev, struct tpm_chip, dev);
289*4882a593Smuzhiyun
290*4882a593Smuzhiyun down_write(&chip->ops_sem);
291*4882a593Smuzhiyun if (chip->flags & TPM_CHIP_FLAG_TPM2) {
292*4882a593Smuzhiyun if (!tpm_chip_start(chip)) {
293*4882a593Smuzhiyun tpm2_shutdown(chip, TPM2_SU_CLEAR);
294*4882a593Smuzhiyun tpm_chip_stop(chip);
295*4882a593Smuzhiyun }
296*4882a593Smuzhiyun }
297*4882a593Smuzhiyun chip->ops = NULL;
298*4882a593Smuzhiyun up_write(&chip->ops_sem);
299*4882a593Smuzhiyun
300*4882a593Smuzhiyun return 0;
301*4882a593Smuzhiyun }
302*4882a593Smuzhiyun
303*4882a593Smuzhiyun /**
304*4882a593Smuzhiyun * tpm_chip_alloc() - allocate a new struct tpm_chip instance
305*4882a593Smuzhiyun * @pdev: device to which the chip is associated
306*4882a593Smuzhiyun * At this point pdev mst be initialized, but does not have to
307*4882a593Smuzhiyun * be registered
308*4882a593Smuzhiyun * @ops: struct tpm_class_ops instance
309*4882a593Smuzhiyun *
310*4882a593Smuzhiyun * Allocates a new struct tpm_chip instance and assigns a free
311*4882a593Smuzhiyun * device number for it. Must be paired with put_device(&chip->dev).
312*4882a593Smuzhiyun */
tpm_chip_alloc(struct device * pdev,const struct tpm_class_ops * ops)313*4882a593Smuzhiyun struct tpm_chip *tpm_chip_alloc(struct device *pdev,
314*4882a593Smuzhiyun const struct tpm_class_ops *ops)
315*4882a593Smuzhiyun {
316*4882a593Smuzhiyun struct tpm_chip *chip;
317*4882a593Smuzhiyun int rc;
318*4882a593Smuzhiyun
319*4882a593Smuzhiyun chip = kzalloc(sizeof(*chip), GFP_KERNEL);
320*4882a593Smuzhiyun if (chip == NULL)
321*4882a593Smuzhiyun return ERR_PTR(-ENOMEM);
322*4882a593Smuzhiyun
323*4882a593Smuzhiyun mutex_init(&chip->tpm_mutex);
324*4882a593Smuzhiyun init_rwsem(&chip->ops_sem);
325*4882a593Smuzhiyun
326*4882a593Smuzhiyun chip->ops = ops;
327*4882a593Smuzhiyun
328*4882a593Smuzhiyun mutex_lock(&idr_lock);
329*4882a593Smuzhiyun rc = idr_alloc(&dev_nums_idr, NULL, 0, TPM_NUM_DEVICES, GFP_KERNEL);
330*4882a593Smuzhiyun mutex_unlock(&idr_lock);
331*4882a593Smuzhiyun if (rc < 0) {
332*4882a593Smuzhiyun dev_err(pdev, "No available tpm device numbers\n");
333*4882a593Smuzhiyun kfree(chip);
334*4882a593Smuzhiyun return ERR_PTR(rc);
335*4882a593Smuzhiyun }
336*4882a593Smuzhiyun chip->dev_num = rc;
337*4882a593Smuzhiyun
338*4882a593Smuzhiyun device_initialize(&chip->dev);
339*4882a593Smuzhiyun
340*4882a593Smuzhiyun chip->dev.class = tpm_class;
341*4882a593Smuzhiyun chip->dev.class->shutdown_pre = tpm_class_shutdown;
342*4882a593Smuzhiyun chip->dev.release = tpm_dev_release;
343*4882a593Smuzhiyun chip->dev.parent = pdev;
344*4882a593Smuzhiyun chip->dev.groups = chip->groups;
345*4882a593Smuzhiyun
346*4882a593Smuzhiyun if (chip->dev_num == 0)
347*4882a593Smuzhiyun chip->dev.devt = MKDEV(MISC_MAJOR, TPM_MINOR);
348*4882a593Smuzhiyun else
349*4882a593Smuzhiyun chip->dev.devt = MKDEV(MAJOR(tpm_devt), chip->dev_num);
350*4882a593Smuzhiyun
351*4882a593Smuzhiyun rc = dev_set_name(&chip->dev, "tpm%d", chip->dev_num);
352*4882a593Smuzhiyun if (rc)
353*4882a593Smuzhiyun goto out;
354*4882a593Smuzhiyun
355*4882a593Smuzhiyun if (!pdev)
356*4882a593Smuzhiyun chip->flags |= TPM_CHIP_FLAG_VIRTUAL;
357*4882a593Smuzhiyun
358*4882a593Smuzhiyun cdev_init(&chip->cdev, &tpm_fops);
359*4882a593Smuzhiyun chip->cdev.owner = THIS_MODULE;
360*4882a593Smuzhiyun
361*4882a593Smuzhiyun rc = tpm2_init_space(&chip->work_space, TPM2_SPACE_BUFFER_SIZE);
362*4882a593Smuzhiyun if (rc) {
363*4882a593Smuzhiyun rc = -ENOMEM;
364*4882a593Smuzhiyun goto out;
365*4882a593Smuzhiyun }
366*4882a593Smuzhiyun
367*4882a593Smuzhiyun chip->locality = -1;
368*4882a593Smuzhiyun return chip;
369*4882a593Smuzhiyun
370*4882a593Smuzhiyun out:
371*4882a593Smuzhiyun put_device(&chip->dev);
372*4882a593Smuzhiyun return ERR_PTR(rc);
373*4882a593Smuzhiyun }
374*4882a593Smuzhiyun EXPORT_SYMBOL_GPL(tpm_chip_alloc);
375*4882a593Smuzhiyun
376*4882a593Smuzhiyun /**
377*4882a593Smuzhiyun * tpmm_chip_alloc() - allocate a new struct tpm_chip instance
378*4882a593Smuzhiyun * @pdev: parent device to which the chip is associated
379*4882a593Smuzhiyun * @ops: struct tpm_class_ops instance
380*4882a593Smuzhiyun *
381*4882a593Smuzhiyun * Same as tpm_chip_alloc except devm is used to do the put_device
382*4882a593Smuzhiyun */
tpmm_chip_alloc(struct device * pdev,const struct tpm_class_ops * ops)383*4882a593Smuzhiyun struct tpm_chip *tpmm_chip_alloc(struct device *pdev,
384*4882a593Smuzhiyun const struct tpm_class_ops *ops)
385*4882a593Smuzhiyun {
386*4882a593Smuzhiyun struct tpm_chip *chip;
387*4882a593Smuzhiyun int rc;
388*4882a593Smuzhiyun
389*4882a593Smuzhiyun chip = tpm_chip_alloc(pdev, ops);
390*4882a593Smuzhiyun if (IS_ERR(chip))
391*4882a593Smuzhiyun return chip;
392*4882a593Smuzhiyun
393*4882a593Smuzhiyun rc = devm_add_action_or_reset(pdev,
394*4882a593Smuzhiyun (void (*)(void *)) put_device,
395*4882a593Smuzhiyun &chip->dev);
396*4882a593Smuzhiyun if (rc)
397*4882a593Smuzhiyun return ERR_PTR(rc);
398*4882a593Smuzhiyun
399*4882a593Smuzhiyun dev_set_drvdata(pdev, chip);
400*4882a593Smuzhiyun
401*4882a593Smuzhiyun return chip;
402*4882a593Smuzhiyun }
403*4882a593Smuzhiyun EXPORT_SYMBOL_GPL(tpmm_chip_alloc);
404*4882a593Smuzhiyun
tpm_add_char_device(struct tpm_chip * chip)405*4882a593Smuzhiyun static int tpm_add_char_device(struct tpm_chip *chip)
406*4882a593Smuzhiyun {
407*4882a593Smuzhiyun int rc;
408*4882a593Smuzhiyun
409*4882a593Smuzhiyun rc = cdev_device_add(&chip->cdev, &chip->dev);
410*4882a593Smuzhiyun if (rc) {
411*4882a593Smuzhiyun dev_err(&chip->dev,
412*4882a593Smuzhiyun "unable to cdev_device_add() %s, major %d, minor %d, err=%d\n",
413*4882a593Smuzhiyun dev_name(&chip->dev), MAJOR(chip->dev.devt),
414*4882a593Smuzhiyun MINOR(chip->dev.devt), rc);
415*4882a593Smuzhiyun return rc;
416*4882a593Smuzhiyun }
417*4882a593Smuzhiyun
418*4882a593Smuzhiyun if (chip->flags & TPM_CHIP_FLAG_TPM2) {
419*4882a593Smuzhiyun rc = tpm_devs_add(chip);
420*4882a593Smuzhiyun if (rc)
421*4882a593Smuzhiyun goto err_del_cdev;
422*4882a593Smuzhiyun }
423*4882a593Smuzhiyun
424*4882a593Smuzhiyun /* Make the chip available. */
425*4882a593Smuzhiyun mutex_lock(&idr_lock);
426*4882a593Smuzhiyun idr_replace(&dev_nums_idr, chip, chip->dev_num);
427*4882a593Smuzhiyun mutex_unlock(&idr_lock);
428*4882a593Smuzhiyun
429*4882a593Smuzhiyun return 0;
430*4882a593Smuzhiyun
431*4882a593Smuzhiyun err_del_cdev:
432*4882a593Smuzhiyun cdev_device_del(&chip->cdev, &chip->dev);
433*4882a593Smuzhiyun return rc;
434*4882a593Smuzhiyun }
435*4882a593Smuzhiyun
tpm_del_char_device(struct tpm_chip * chip)436*4882a593Smuzhiyun static void tpm_del_char_device(struct tpm_chip *chip)
437*4882a593Smuzhiyun {
438*4882a593Smuzhiyun cdev_device_del(&chip->cdev, &chip->dev);
439*4882a593Smuzhiyun
440*4882a593Smuzhiyun /* Make the chip unavailable. */
441*4882a593Smuzhiyun mutex_lock(&idr_lock);
442*4882a593Smuzhiyun idr_replace(&dev_nums_idr, NULL, chip->dev_num);
443*4882a593Smuzhiyun mutex_unlock(&idr_lock);
444*4882a593Smuzhiyun
445*4882a593Smuzhiyun /* Make the driver uncallable. */
446*4882a593Smuzhiyun down_write(&chip->ops_sem);
447*4882a593Smuzhiyun if (chip->flags & TPM_CHIP_FLAG_TPM2) {
448*4882a593Smuzhiyun if (!tpm_chip_start(chip)) {
449*4882a593Smuzhiyun tpm2_shutdown(chip, TPM2_SU_CLEAR);
450*4882a593Smuzhiyun tpm_chip_stop(chip);
451*4882a593Smuzhiyun }
452*4882a593Smuzhiyun }
453*4882a593Smuzhiyun chip->ops = NULL;
454*4882a593Smuzhiyun up_write(&chip->ops_sem);
455*4882a593Smuzhiyun }
456*4882a593Smuzhiyun
tpm_del_legacy_sysfs(struct tpm_chip * chip)457*4882a593Smuzhiyun static void tpm_del_legacy_sysfs(struct tpm_chip *chip)
458*4882a593Smuzhiyun {
459*4882a593Smuzhiyun struct attribute **i;
460*4882a593Smuzhiyun
461*4882a593Smuzhiyun if (chip->flags & (TPM_CHIP_FLAG_TPM2 | TPM_CHIP_FLAG_VIRTUAL))
462*4882a593Smuzhiyun return;
463*4882a593Smuzhiyun
464*4882a593Smuzhiyun sysfs_remove_link(&chip->dev.parent->kobj, "ppi");
465*4882a593Smuzhiyun
466*4882a593Smuzhiyun for (i = chip->groups[0]->attrs; *i != NULL; ++i)
467*4882a593Smuzhiyun sysfs_remove_link(&chip->dev.parent->kobj, (*i)->name);
468*4882a593Smuzhiyun }
469*4882a593Smuzhiyun
470*4882a593Smuzhiyun /* For compatibility with legacy sysfs paths we provide symlinks from the
471*4882a593Smuzhiyun * parent dev directory to selected names within the tpm chip directory. Old
472*4882a593Smuzhiyun * kernel versions created these files directly under the parent.
473*4882a593Smuzhiyun */
tpm_add_legacy_sysfs(struct tpm_chip * chip)474*4882a593Smuzhiyun static int tpm_add_legacy_sysfs(struct tpm_chip *chip)
475*4882a593Smuzhiyun {
476*4882a593Smuzhiyun struct attribute **i;
477*4882a593Smuzhiyun int rc;
478*4882a593Smuzhiyun
479*4882a593Smuzhiyun if (chip->flags & (TPM_CHIP_FLAG_TPM2 | TPM_CHIP_FLAG_VIRTUAL))
480*4882a593Smuzhiyun return 0;
481*4882a593Smuzhiyun
482*4882a593Smuzhiyun rc = compat_only_sysfs_link_entry_to_kobj(
483*4882a593Smuzhiyun &chip->dev.parent->kobj, &chip->dev.kobj, "ppi", NULL);
484*4882a593Smuzhiyun if (rc && rc != -ENOENT)
485*4882a593Smuzhiyun return rc;
486*4882a593Smuzhiyun
487*4882a593Smuzhiyun /* All the names from tpm-sysfs */
488*4882a593Smuzhiyun for (i = chip->groups[0]->attrs; *i != NULL; ++i) {
489*4882a593Smuzhiyun rc = compat_only_sysfs_link_entry_to_kobj(
490*4882a593Smuzhiyun &chip->dev.parent->kobj, &chip->dev.kobj, (*i)->name, NULL);
491*4882a593Smuzhiyun if (rc) {
492*4882a593Smuzhiyun tpm_del_legacy_sysfs(chip);
493*4882a593Smuzhiyun return rc;
494*4882a593Smuzhiyun }
495*4882a593Smuzhiyun }
496*4882a593Smuzhiyun
497*4882a593Smuzhiyun return 0;
498*4882a593Smuzhiyun }
499*4882a593Smuzhiyun
tpm_hwrng_read(struct hwrng * rng,void * data,size_t max,bool wait)500*4882a593Smuzhiyun static int tpm_hwrng_read(struct hwrng *rng, void *data, size_t max, bool wait)
501*4882a593Smuzhiyun {
502*4882a593Smuzhiyun struct tpm_chip *chip = container_of(rng, struct tpm_chip, hwrng);
503*4882a593Smuzhiyun
504*4882a593Smuzhiyun return tpm_get_random(chip, data, max);
505*4882a593Smuzhiyun }
506*4882a593Smuzhiyun
tpm_add_hwrng(struct tpm_chip * chip)507*4882a593Smuzhiyun static int tpm_add_hwrng(struct tpm_chip *chip)
508*4882a593Smuzhiyun {
509*4882a593Smuzhiyun if (!IS_ENABLED(CONFIG_HW_RANDOM_TPM))
510*4882a593Smuzhiyun return 0;
511*4882a593Smuzhiyun
512*4882a593Smuzhiyun snprintf(chip->hwrng_name, sizeof(chip->hwrng_name),
513*4882a593Smuzhiyun "tpm-rng-%d", chip->dev_num);
514*4882a593Smuzhiyun chip->hwrng.name = chip->hwrng_name;
515*4882a593Smuzhiyun chip->hwrng.read = tpm_hwrng_read;
516*4882a593Smuzhiyun return hwrng_register(&chip->hwrng);
517*4882a593Smuzhiyun }
518*4882a593Smuzhiyun
tpm_get_pcr_allocation(struct tpm_chip * chip)519*4882a593Smuzhiyun static int tpm_get_pcr_allocation(struct tpm_chip *chip)
520*4882a593Smuzhiyun {
521*4882a593Smuzhiyun int rc;
522*4882a593Smuzhiyun
523*4882a593Smuzhiyun rc = (chip->flags & TPM_CHIP_FLAG_TPM2) ?
524*4882a593Smuzhiyun tpm2_get_pcr_allocation(chip) :
525*4882a593Smuzhiyun tpm1_get_pcr_allocation(chip);
526*4882a593Smuzhiyun
527*4882a593Smuzhiyun if (rc > 0)
528*4882a593Smuzhiyun return -ENODEV;
529*4882a593Smuzhiyun
530*4882a593Smuzhiyun return rc;
531*4882a593Smuzhiyun }
532*4882a593Smuzhiyun
533*4882a593Smuzhiyun /*
534*4882a593Smuzhiyun * tpm_chip_register() - create a character device for the TPM chip
535*4882a593Smuzhiyun * @chip: TPM chip to use.
536*4882a593Smuzhiyun *
537*4882a593Smuzhiyun * Creates a character device for the TPM chip and adds sysfs attributes for
538*4882a593Smuzhiyun * the device. As the last step this function adds the chip to the list of TPM
539*4882a593Smuzhiyun * chips available for in-kernel use.
540*4882a593Smuzhiyun *
541*4882a593Smuzhiyun * This function should be only called after the chip initialization is
542*4882a593Smuzhiyun * complete.
543*4882a593Smuzhiyun */
tpm_chip_register(struct tpm_chip * chip)544*4882a593Smuzhiyun int tpm_chip_register(struct tpm_chip *chip)
545*4882a593Smuzhiyun {
546*4882a593Smuzhiyun int rc;
547*4882a593Smuzhiyun
548*4882a593Smuzhiyun rc = tpm_chip_start(chip);
549*4882a593Smuzhiyun if (rc)
550*4882a593Smuzhiyun return rc;
551*4882a593Smuzhiyun rc = tpm_auto_startup(chip);
552*4882a593Smuzhiyun if (rc) {
553*4882a593Smuzhiyun tpm_chip_stop(chip);
554*4882a593Smuzhiyun return rc;
555*4882a593Smuzhiyun }
556*4882a593Smuzhiyun
557*4882a593Smuzhiyun rc = tpm_get_pcr_allocation(chip);
558*4882a593Smuzhiyun tpm_chip_stop(chip);
559*4882a593Smuzhiyun if (rc)
560*4882a593Smuzhiyun return rc;
561*4882a593Smuzhiyun
562*4882a593Smuzhiyun tpm_sysfs_add_device(chip);
563*4882a593Smuzhiyun
564*4882a593Smuzhiyun tpm_bios_log_setup(chip);
565*4882a593Smuzhiyun
566*4882a593Smuzhiyun tpm_add_ppi(chip);
567*4882a593Smuzhiyun
568*4882a593Smuzhiyun rc = tpm_add_hwrng(chip);
569*4882a593Smuzhiyun if (rc)
570*4882a593Smuzhiyun goto out_ppi;
571*4882a593Smuzhiyun
572*4882a593Smuzhiyun rc = tpm_add_char_device(chip);
573*4882a593Smuzhiyun if (rc)
574*4882a593Smuzhiyun goto out_hwrng;
575*4882a593Smuzhiyun
576*4882a593Smuzhiyun rc = tpm_add_legacy_sysfs(chip);
577*4882a593Smuzhiyun if (rc) {
578*4882a593Smuzhiyun tpm_chip_unregister(chip);
579*4882a593Smuzhiyun return rc;
580*4882a593Smuzhiyun }
581*4882a593Smuzhiyun
582*4882a593Smuzhiyun return 0;
583*4882a593Smuzhiyun
584*4882a593Smuzhiyun out_hwrng:
585*4882a593Smuzhiyun if (IS_ENABLED(CONFIG_HW_RANDOM_TPM))
586*4882a593Smuzhiyun hwrng_unregister(&chip->hwrng);
587*4882a593Smuzhiyun out_ppi:
588*4882a593Smuzhiyun tpm_bios_log_teardown(chip);
589*4882a593Smuzhiyun
590*4882a593Smuzhiyun return rc;
591*4882a593Smuzhiyun }
592*4882a593Smuzhiyun EXPORT_SYMBOL_GPL(tpm_chip_register);
593*4882a593Smuzhiyun
594*4882a593Smuzhiyun /*
595*4882a593Smuzhiyun * tpm_chip_unregister() - release the TPM driver
596*4882a593Smuzhiyun * @chip: TPM chip to use.
597*4882a593Smuzhiyun *
598*4882a593Smuzhiyun * Takes the chip first away from the list of available TPM chips and then
599*4882a593Smuzhiyun * cleans up all the resources reserved by tpm_chip_register().
600*4882a593Smuzhiyun *
601*4882a593Smuzhiyun * Once this function returns the driver call backs in 'op's will not be
602*4882a593Smuzhiyun * running and will no longer start.
603*4882a593Smuzhiyun *
604*4882a593Smuzhiyun * NOTE: This function should be only called before deinitializing chip
605*4882a593Smuzhiyun * resources.
606*4882a593Smuzhiyun */
tpm_chip_unregister(struct tpm_chip * chip)607*4882a593Smuzhiyun void tpm_chip_unregister(struct tpm_chip *chip)
608*4882a593Smuzhiyun {
609*4882a593Smuzhiyun tpm_del_legacy_sysfs(chip);
610*4882a593Smuzhiyun if (IS_ENABLED(CONFIG_HW_RANDOM_TPM))
611*4882a593Smuzhiyun hwrng_unregister(&chip->hwrng);
612*4882a593Smuzhiyun tpm_bios_log_teardown(chip);
613*4882a593Smuzhiyun if (chip->flags & TPM_CHIP_FLAG_TPM2)
614*4882a593Smuzhiyun tpm_devs_remove(chip);
615*4882a593Smuzhiyun tpm_del_char_device(chip);
616*4882a593Smuzhiyun }
617*4882a593Smuzhiyun EXPORT_SYMBOL_GPL(tpm_chip_unregister);
618