Changeset 2b0db98 in mainline for kernel/generic/src/ipc/irq.c
- Timestamp:
- 2011-01-07T14:02:56Z (14 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 6986418
- Parents:
- d99120f (diff), 0f191a2 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/generic/src/ipc/irq.c
rd99120f r2b0db98 131 131 /** Register an answerbox as a receiving end for IRQ notifications. 132 132 * 133 * @param box Receiving answerbox. 134 * @param inr IRQ number. 135 * @param devno Device number. 136 * @param imethod Interface and method to be associated 137 * with the notification. 138 * @param ucode Uspace pointer to top-half pseudocode. 139 * 140 * @return EBADMEM, ENOENT or EEXISTS on failure or 0 on success. 133 * @param box Receiving answerbox. 134 * @param inr IRQ number. 135 * @param devno Device number. 136 * @param imethod Interface and method to be associated with the 137 * notification. 138 * @param ucode Uspace pointer to top-half pseudocode. 139 * @return EOK on success or a negative error code. 141 140 * 142 141 */ … … 148 147 (sysarg_t) devno 149 148 }; 149 150 if ((inr < 0) || (inr > last_inr)) 151 return ELIMIT; 150 152 151 153 irq_code_t *code; … … 208 210 /** Unregister task from IRQ notification. 209 211 * 210 * @param box 211 * @param inr 212 * @param devno 213 * 212 * @param box Answerbox associated with the notification. 213 * @param inr IRQ number. 214 * @param devno Device number. 215 * @return EOK on success or a negative error code. 214 216 */ 215 217 int ipc_irq_unregister(answerbox_t *box, inr_t inr, devno_t devno) … … 219 221 (sysarg_t) devno 220 222 }; 223 224 if ((inr < 0) || (inr > last_inr)) 225 return ELIMIT; 221 226 222 227 irq_spinlock_lock(&irq_uspace_hash_table_lock, true); … … 399 404 (uint32_t) code->cmds[i].value); 400 405 break; 406 case CMD_PIO_WRITE_A_8: 407 if (srcarg) { 408 pio_write_8((ioport8_t *) code->cmds[i].addr, 409 (uint8_t) scratch[srcarg]); 410 } 411 break; 412 case CMD_PIO_WRITE_A_16: 413 if (srcarg) { 414 pio_write_16((ioport16_t *) code->cmds[i].addr, 415 (uint16_t) scratch[srcarg]); 416 } 417 break; 418 case CMD_PIO_WRITE_A_32: 419 if (srcarg) { 420 pio_write_32((ioport32_t *) code->cmds[i].addr, 421 (uint32_t) scratch[srcarg]); 422 } 423 break; 401 424 case CMD_BTEST: 402 425 if ((srcarg) && (dstarg)) {
Note:
See TracChangeset
for help on using the changeset viewer.