Rev 2471 | Rev 2745 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 2471 | Rev 2626 | ||
---|---|---|---|
Line 87... | Line 87... | ||
87 | break; |
87 | break; |
88 | case CMD_MEM_WRITE_1: |
88 | case CMD_MEM_WRITE_1: |
89 | *((uint8_t *) code->cmds[i].addr) = code->cmds[i].value; |
89 | *((uint8_t *) code->cmds[i].addr) = code->cmds[i].value; |
90 | break; |
90 | break; |
91 | case CMD_MEM_WRITE_2: |
91 | case CMD_MEM_WRITE_2: |
92 | *((uint16_t *) code->cmds[i].addr) = code->cmds[i].value; |
92 | *((uint16_t *) code->cmds[i].addr) = |
- | 93 | code->cmds[i].value; |
|
93 | break; |
94 | break; |
94 | case CMD_MEM_WRITE_4: |
95 | case CMD_MEM_WRITE_4: |
95 | *((uint32_t *) code->cmds[i].addr) = code->cmds[i].value; |
96 | *((uint32_t *) code->cmds[i].addr) = |
- | 97 | code->cmds[i].value; |
|
96 | break; |
98 | break; |
97 | case CMD_MEM_WRITE_8: |
99 | case CMD_MEM_WRITE_8: |
98 | *((uint64_t *) code->cmds[i].addr) = code->cmds[i].value; |
100 | *((uint64_t *) code->cmds[i].addr) = |
- | 101 | code->cmds[i].value; |
|
99 | break; |
102 | break; |
100 | #if defined(ia32) || defined(amd64) |
103 | #if defined(ia32) || defined(amd64) |
101 | case CMD_PORT_READ_1: |
104 | case CMD_PORT_READ_1: |
102 | dstval = inb((long) code->cmds[i].addr); |
105 | dstval = inb((long) code->cmds[i].addr); |
103 | break; |
106 | break; |
Line 116... | Line 119... | ||
116 | break; |
119 | break; |
117 | #endif |
120 | #endif |
118 | default: |
121 | default: |
119 | break; |
122 | break; |
120 | } |
123 | } |
121 | if (code->cmds[i].dstarg && code->cmds[i].dstarg < 4) { |
124 | if (code->cmds[i].dstarg && code->cmds[i].dstarg < |
- | 125 | IPC_CALL_LEN) { |
|
122 | call->data.args[code->cmds[i].dstarg] = dstval; |
126 | call->data.args[code->cmds[i].dstarg] = dstval; |
123 | } |
127 | } |
124 | } |
128 | } |
125 | } |
129 | } |
126 | 130 | ||
Line 280... | Line 284... | ||
280 | * |
284 | * |
281 | * @param irq IRQ structure. |
285 | * @param irq IRQ structure. |
282 | * @param a1 Driver-specific payload argument. |
286 | * @param a1 Driver-specific payload argument. |
283 | * @param a2 Driver-specific payload argument. |
287 | * @param a2 Driver-specific payload argument. |
284 | * @param a3 Driver-specific payload argument. |
288 | * @param a3 Driver-specific payload argument. |
- | 289 | * @param a4 Driver-specific payload argument. |
|
- | 290 | * @param a5 Driver-specific payload argument. |
|
285 | */ |
291 | */ |
286 | void ipc_irq_send_msg(irq_t *irq, unative_t a1, unative_t a2, unative_t a3) |
292 | void ipc_irq_send_msg(irq_t *irq, unative_t a1, unative_t a2, unative_t a3, |
- | 293 | unative_t a4, unative_t a5) |
|
287 | { |
294 | { |
288 | call_t *call; |
295 | call_t *call; |
289 | 296 | ||
290 | spinlock_lock(&irq->lock); |
297 | spinlock_lock(&irq->lock); |
291 | 298 | ||
Line 298... | Line 305... | ||
298 | call->flags |= IPC_CALL_NOTIF; |
305 | call->flags |= IPC_CALL_NOTIF; |
299 | IPC_SET_METHOD(call->data, irq->notif_cfg.method); |
306 | IPC_SET_METHOD(call->data, irq->notif_cfg.method); |
300 | IPC_SET_ARG1(call->data, a1); |
307 | IPC_SET_ARG1(call->data, a1); |
301 | IPC_SET_ARG2(call->data, a2); |
308 | IPC_SET_ARG2(call->data, a2); |
302 | IPC_SET_ARG3(call->data, a3); |
309 | IPC_SET_ARG3(call->data, a3); |
- | 310 | IPC_SET_ARG4(call->data, a4); |
|
- | 311 | IPC_SET_ARG5(call->data, a5); |
|
303 | /* Put a counter to the message */ |
312 | /* Put a counter to the message */ |
304 | call->priv = ++irq->notif_cfg.counter; |
313 | call->priv = ++irq->notif_cfg.counter; |
305 | 314 | ||
306 | send_call(irq, call); |
315 | send_call(irq, call); |
307 | } |
316 | } |