Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 370058
b: refs/heads/master
c: 2ce8fce
h: refs/heads/master
v: v3
  • Loading branch information
Al Viro committed Apr 13, 2013
1 parent a613c93 commit aa13d1c
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 59 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 05c0ae21c034a6f7c6f4c0c63a31167ebb4b061f
refs/heads/master: 2ce8fce2ea1663d7a62dd780653a137ca33d6ee4
83 changes: 25 additions & 58 deletions trunk/drivers/media/pci/cx25821/cx25821-audio-upstream.c
Original file line number Diff line number Diff line change
Expand Up @@ -259,79 +259,46 @@ void cx25821_free_mem_upstream_audio(struct cx25821_dev *dev)
static int cx25821_get_audio_data(struct cx25821_dev *dev,
struct sram_channel *sram_ch)
{
struct file *myfile;
struct file *file;
int frame_index_temp = dev->_audioframe_index;
int i = 0;
int line_size = AUDIO_LINE_SIZE;
int frame_size = AUDIO_DATA_BUF_SZ;
int frame_offset = frame_size * frame_index_temp;
ssize_t vfs_read_retval = 0;
char mybuf[line_size];
char mybuf[AUDIO_LINE_SIZE];
loff_t file_offset = dev->_audioframe_count * frame_size;
loff_t pos;
mm_segment_t old_fs;
char *p = NULL;

if (dev->_audiofile_status == END_OF_FILE)
return 0;

myfile = filp_open(dev->_audiofilename, O_RDONLY | O_LARGEFILE, 0);
file = filp_open(dev->_audiofilename, O_RDONLY | O_LARGEFILE, 0);
if (IS_ERR(file)) {
pr_err("%s(): ERROR opening file(%s) with errno = %ld!\n",
__func__, dev->_audiofilename, -PTR_ERR(file));
return PTR_ERR(file);
}

if (IS_ERR(myfile)) {
const int open_errno = -PTR_ERR(myfile);
pr_err("%s(): ERROR opening file(%s) with errno = %d!\n",
__func__, dev->_audiofilename, open_errno);
return PTR_ERR(myfile);
} else {
if (!(myfile->f_op)) {
pr_err("%s(): File has no file operations registered!\n",
__func__);
filp_close(myfile, NULL);
return -EIO;
}
if (dev->_audiodata_buf_virt_addr)
p = (char *)dev->_audiodata_buf_virt_addr + frame_offset;

if (!myfile->f_op->read) {
pr_err("%s(): File has no READ operations registered!\n",
for (i = 0; i < dev->_audio_lines_count; i++) {
int n = kernel_read(file, file_offset, mybuf, AUDIO_LINE_SIZE);
if (n < AUDIO_LINE_SIZE) {
pr_info("Done: exit %s() since no more bytes to read from Audio file\n",
__func__);
filp_close(myfile, NULL);
return -EIO;
dev->_audiofile_status = END_OF_FILE;
fput(file);
return 0;
}

pos = myfile->f_pos;
old_fs = get_fs();
set_fs(KERNEL_DS);

for (i = 0; i < dev->_audio_lines_count; i++) {
pos = file_offset;

vfs_read_retval = vfs_read(myfile, mybuf, line_size,
&pos);

if (vfs_read_retval > 0 && vfs_read_retval == line_size
&& dev->_audiodata_buf_virt_addr != NULL) {
memcpy((void *)(dev->_audiodata_buf_virt_addr +
frame_offset / 4), mybuf,
vfs_read_retval);
}

file_offset += vfs_read_retval;
frame_offset += vfs_read_retval;

if (vfs_read_retval < line_size) {
pr_info("Done: exit %s() since no more bytes to read from Audio file\n",
__func__);
break;
}
dev->_audiofile_status = IN_PROGRESS;
if (p) {
memcpy(p, mybuf, n);
p += n;
}

if (i > 0)
dev->_audioframe_count++;

dev->_audiofile_status = (vfs_read_retval == line_size) ?
IN_PROGRESS : END_OF_FILE;

set_fs(old_fs);
filp_close(myfile, NULL);
file_offset += n;
}
dev->_audioframe_count++;
fput(file);

return 0;
}
Expand Down

0 comments on commit aa13d1c

Please sign in to comment.