Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 207879
b: refs/heads/master
c: 68c16b4
h: refs/heads/master
i:
  207877: 188c45c
  207875: f9c96f0
  207871: e428368
v: v3
  • Loading branch information
Arjan van de Ven authored and Greg Kroah-Hartman committed Aug 10, 2010
1 parent 890cc11 commit a39bdb2
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 8 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: 99dd3f6b7e2ef5179f67503a401a99141708687a
refs/heads/master: 68c16b4117cc746a91897d629b61e5f2af18c225
15 changes: 8 additions & 7 deletions trunk/drivers/serial/mrst_max3110.c
Original file line number Diff line number Diff line change
Expand Up @@ -56,8 +56,7 @@ struct uart_max3110 {
wait_queue_head_t wq;
struct task_struct *main_thread;
struct task_struct *read_thread;
int mthread_up;
spinlock_t lock;
struct mutex thread_mutex;;

u32 baud;
u16 cur_conf;
Expand Down Expand Up @@ -397,7 +396,8 @@ static int max3110_main_thread(void *_max)
atomic_read(&max->con_tx_need) ||
atomic_read(&max->uart_tx_need)) ||
kthread_should_stop());
max->mthread_up = 1;

mutex_lock(&max->thread_mutex);

#ifdef CONFIG_MRST_MAX3110_IRQ
if (atomic_read(&max->irq_pending)) {
Expand All @@ -417,7 +417,7 @@ static int max3110_main_thread(void *_max)
transmit_char(max);
atomic_set(&max->uart_tx_need, 0);
}
max->mthread_up = 0;
mutex_unlock(&max->thread_mutex);
} while (!kthread_should_stop());

return ret;
Expand All @@ -444,8 +444,9 @@ static int max3110_read_thread(void *_max)

pr_info(PR_FMT "start read thread\n");
do {
if (!max->mthread_up)
max3110_console_receive(max);
mutex_lock(&max->thread_mutex);
max3110_console_receive(max);
mutex_unlock(&max->thread_mutex);

set_current_state(TASK_INTERRUPTIBLE);
schedule_timeout(HZ / 20);
Expand Down Expand Up @@ -745,7 +746,7 @@ static int serial_m3110_probe(struct spi_device *spi)
max->name = spi->modalias; /* use spi name as the name */
max->irq = (u16)spi->irq;

spin_lock_init(&max->lock);
mutex_init(&max->thread_mutex);

max->word_7bits = 0;
max->parity = 0;
Expand Down

0 comments on commit a39bdb2

Please sign in to comment.