Blame view

kernel/linux-imx6_3.14.28/sound/sound_firmware.c 1.61 KB
6b13f685e   김민수   BSP 최초 추가
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
  #include <linux/vmalloc.h>
  #include <linux/module.h>
  #include <linux/fs.h>
  #include <linux/file.h>
  #include <linux/mm.h>
  #include <linux/sched.h>
  #include <asm/uaccess.h>
  #include "oss/sound_firmware.h"
  
  static int do_mod_firmware_load(const char *fn, char **fp)
  {
  	struct file* filp;
  	long l;
  	char *dp;
  	loff_t pos;
  
  	filp = filp_open(fn, 0, 0);
  	if (IS_ERR(filp))
  	{
  		printk(KERN_INFO "Unable to load '%s'.
  ", fn);
  		return 0;
  	}
  	l = i_size_read(file_inode(filp));
  	if (l <= 0 || l > 131072)
  	{
  		printk(KERN_INFO "Invalid firmware '%s'
  ", fn);
  		fput(filp);
  		return 0;
  	}
  	dp = vmalloc(l);
  	if (dp == NULL)
  	{
  		printk(KERN_INFO "Out of memory loading '%s'.
  ", fn);
  		fput(filp);
  		return 0;
  	}
  	pos = 0;
  	if (vfs_read(filp, dp, l, &pos) != l)
  	{
  		printk(KERN_INFO "Failed to read '%s'.
  ", fn);
  		vfree(dp);
  		fput(filp);
  		return 0;
  	}
  	fput(filp);
  	*fp = dp;
  	return (int) l;
  }
  
  /**
   *	mod_firmware_load - load sound driver firmware
   *	@fn: filename
   *	@fp: return for the buffer.
   *
   *	Load the firmware for a sound module (up to 128K) into a buffer.
   *	The buffer is returned in *fp. It is allocated with vmalloc so is
   *	virtually linear and not DMAable. The caller should free it with
   *	vfree when finished.
   *
   *	The length of the buffer is returned on a successful load, the
   *	value zero on a failure.
   *
   *	Caution: This API is not recommended. Firmware should be loaded via
   *	request_firmware.
   */
   
  int mod_firmware_load(const char *fn, char **fp)
  {
  	int r;
  	mm_segment_t fs = get_fs();
  
  	set_fs(get_ds());
  	r = do_mod_firmware_load(fn, fp);
  	set_fs(fs);
  	return r;
  }
  EXPORT_SYMBOL(mod_firmware_load);
  
  MODULE_LICENSE("GPL");