c3fc9df84a
* Also change _orig to _intr for clarity * Cleaned up {IPC,KER}VEC * Renamed _minix_kernel_info_struct to get_minix_kerninfo * Merged _senda.S into _ipc.S * Moved into separate files get_minix_kerninfo and _do_kernel_call * Adapted do_kernel_call to follow same _ convention as ipc functions * Drop patches in libc/net/send.c and libc/include/namespace.h Change-Id: If4ea21ecb65435170d7d87de6c826328e84c18d0
53 lines
1,021 B
C
53 lines
1,021 B
C
/*
|
|
pci_set_acl.c
|
|
*/
|
|
|
|
#include "pci.h"
|
|
#include "syslib.h"
|
|
#include <unistd.h>
|
|
#include <minix/rs.h>
|
|
#include <minix/ds.h>
|
|
#include <minix/sysutil.h>
|
|
|
|
/*===========================================================================*
|
|
* pci_set_acl *
|
|
*===========================================================================*/
|
|
int pci_set_acl(rs_pci)
|
|
struct rs_pci *rs_pci;
|
|
{
|
|
int r;
|
|
cp_grant_id_t gid;
|
|
message m;
|
|
endpoint_t endpoint;
|
|
|
|
if (pci_procnr == ANY)
|
|
{
|
|
r= ds_retrieve_label_endpt("pci", &endpoint);
|
|
if (r != 0)
|
|
{
|
|
panic("pci_set_acl: ds_retrieve_label_endpt failed for 'pci': %d", r);
|
|
}
|
|
pci_procnr = endpoint;
|
|
}
|
|
|
|
|
|
gid= cpf_grant_direct(pci_procnr, (vir_bytes)rs_pci, sizeof(*rs_pci),
|
|
CPF_READ);
|
|
if (gid == -1)
|
|
{
|
|
printf("pci_set_acl: cpf_grant_direct failed: %d\n",
|
|
errno);
|
|
return EINVAL;
|
|
}
|
|
|
|
m.m_type= BUSC_PCI_SET_ACL;
|
|
m.m1_i1= gid;
|
|
|
|
r= ipc_sendrec(pci_procnr, &m);
|
|
cpf_revoke(gid);
|
|
if (r != 0)
|
|
panic("pci_set_acl: can't talk to PCI: %d", r);
|
|
|
|
return m.m_type;
|
|
}
|
|
|