CS318 - Pintos
Pintos source browser for JHU CS318 course
|
Go to the documentation of this file.
5 static int next (
int pos);
92 || (waiter == &q->not_full &&
intq_full (q)));
107 || (waiter == &q->not_full && !
intq_full (q)));
void lock_release(struct lock *lock)
Releases LOCK, which must be owned by the current thread.
bool intr_context(void)
Returns true during processing of an external interrupt and false at all other times.
static void signal(struct intq *q, struct thread **waiter)
bool intq_empty(const struct intq *q)
Returns true if Q is empty, false otherwise.
void lock_init(struct lock *lock)
Initializes LOCK.
#define UNUSED
GCC lets us add "attributes" to functions, function parameters, etc.
A kernel thread or user process.
void intq_init(struct intq *q)
Initializes interrupt queue Q.
uint8_t buf[INTQ_BUFSIZE]
Buffer.
uint8_t intq_getc(struct intq *q)
Removes a byte from Q and returns it.
struct thread * thread_current(void)
Returns the running thread.
void thread_block(void)
Puts the current thread to sleep.
static int next(int pos)
Returns the position after POS within an intq.
enum intr_level intr_get_level(void)
Returns the current interrupt status.
#define INTQ_BUFSIZE
An "interrupt queue", a circular buffer shared between kernel threads and external interrupt handlers...
void intq_putc(struct intq *q, uint8_t byte)
Adds BYTE to the end of Q.
bool intq_full(const struct intq *q)
Returns true if Q is full, false otherwise.
int head
New data is written here.
#define ASSERT(CONDITION)
This is outside the header guard so that debug.h may be included multiple times with different settin...
struct thread * not_empty
Thread waiting for not-empty condition.
struct lock lock
Only one thread may wait at once.
int tail
Old data is read here.
A circular queue of bytes.
static void wait(struct intq *q, struct thread **waiter)
void thread_unblock(struct thread *t)
Transitions a blocked thread T to the ready-to-run state.
struct thread * not_full
Thread waiting for not-full condition.
void lock_acquire(struct lock *lock)
Acquires LOCK, sleeping until it becomes available if necessary.