Linux Audio

Check our new training course

Loading...
v6.8
 1// SPDX-License-Identifier: GPL-2.0-only
 2/*
 3 * Copyright (C) 2017 James.Bottomley@HansenPartnership.com
 
 
 4 */
 5#include <linux/slab.h>
 6#include "tpm-dev.h"
 7
 8struct tpmrm_priv {
 9	struct file_priv priv;
10	struct tpm_space space;
11};
12
13static int tpmrm_open(struct inode *inode, struct file *file)
14{
15	struct tpm_chip *chip;
16	struct tpmrm_priv *priv;
17	int rc;
18
19	chip = container_of(inode->i_cdev, struct tpm_chip, cdevs);
20	priv = kzalloc(sizeof(*priv), GFP_KERNEL);
21	if (priv == NULL)
22		return -ENOMEM;
23
24	rc = tpm2_init_space(&priv->space, TPM2_SPACE_BUFFER_SIZE);
25	if (rc) {
26		kfree(priv);
27		return -ENOMEM;
28	}
29
30	tpm_common_open(file, chip, &priv->priv, &priv->space);
31
32	return 0;
33}
34
35static int tpmrm_release(struct inode *inode, struct file *file)
36{
37	struct file_priv *fpriv = file->private_data;
38	struct tpmrm_priv *priv = container_of(fpriv, struct tpmrm_priv, priv);
39
40	tpm_common_release(file, fpriv);
41	tpm2_del_space(fpriv->chip, &priv->space);
42	kfree(priv);
43
44	return 0;
45}
46
 
 
 
 
 
 
 
 
 
47const struct file_operations tpmrm_fops = {
48	.owner = THIS_MODULE,
49	.llseek = no_llseek,
50	.open = tpmrm_open,
51	.read = tpm_common_read,
52	.write = tpm_common_write,
53	.poll = tpm_common_poll,
54	.release = tpmrm_release,
55};
v4.17
 
 1/*
 2 * Copyright (C) 2017 James.Bottomley@HansenPartnership.com
 3 *
 4 * GPLv2
 5 */
 6#include <linux/slab.h>
 7#include "tpm-dev.h"
 8
 9struct tpmrm_priv {
10	struct file_priv priv;
11	struct tpm_space space;
12};
13
14static int tpmrm_open(struct inode *inode, struct file *file)
15{
16	struct tpm_chip *chip;
17	struct tpmrm_priv *priv;
18	int rc;
19
20	chip = container_of(inode->i_cdev, struct tpm_chip, cdevs);
21	priv = kzalloc(sizeof(*priv), GFP_KERNEL);
22	if (priv == NULL)
23		return -ENOMEM;
24
25	rc = tpm2_init_space(&priv->space);
26	if (rc) {
27		kfree(priv);
28		return -ENOMEM;
29	}
30
31	tpm_common_open(file, chip, &priv->priv);
32
33	return 0;
34}
35
36static int tpmrm_release(struct inode *inode, struct file *file)
37{
38	struct file_priv *fpriv = file->private_data;
39	struct tpmrm_priv *priv = container_of(fpriv, struct tpmrm_priv, priv);
40
41	tpm_common_release(file, fpriv);
42	tpm2_del_space(fpriv->chip, &priv->space);
43	kfree(priv);
44
45	return 0;
46}
47
48static ssize_t tpmrm_write(struct file *file, const char __user *buf,
49		   size_t size, loff_t *off)
50{
51	struct file_priv *fpriv = file->private_data;
52	struct tpmrm_priv *priv = container_of(fpriv, struct tpmrm_priv, priv);
53
54	return tpm_common_write(file, buf, size, off, &priv->space);
55}
56
57const struct file_operations tpmrm_fops = {
58	.owner = THIS_MODULE,
59	.llseek = no_llseek,
60	.open = tpmrm_open,
61	.read = tpm_common_read,
62	.write = tpmrm_write,
 
63	.release = tpmrm_release,
64};
65