Compare commits
2 Commits
9bb2610e5f
...
791dcb4e2b
| Author | SHA1 | Date | |
|---|---|---|---|
| 791dcb4e2b | |||
| 034bae3788 |
+1
-1
@@ -1 +1 @@
|
||||
mvm
|
||||
./mvm
|
||||
|
||||
@@ -0,0 +1,104 @@
|
||||
/*
|
||||
* Copyright (c) 2026 Mirocom Laboratories and MSP engineers.
|
||||
* All Rights Reserved.
|
||||
*/
|
||||
|
||||
#include <stddef.h>
|
||||
#include <stdint.h>
|
||||
#include <stdlib.h>
|
||||
#include <errno.h>
|
||||
#include "mvm/bus.h"
|
||||
|
||||
int
|
||||
bus_ctl_init(struct mvm_bus_ctl *busctl)
|
||||
{
|
||||
if (busctl == NULL) {
|
||||
errno = EINVAL;
|
||||
return -1;
|
||||
}
|
||||
|
||||
busctl->head = NULL;
|
||||
busctl->tail = NULL;
|
||||
busctl->dev_count = 0;
|
||||
return 0;
|
||||
}
|
||||
|
||||
int
|
||||
bus_dev_alloc(mvm_devtype_t type, void *data, struct mvm_bus_dev **res)
|
||||
{
|
||||
struct mvm_bus_dev *dev;
|
||||
|
||||
if (type == BUS_DEV_NONE || data == NULL) {
|
||||
errno = EINVAL;
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (res == NULL) {
|
||||
errno = EINVAL;
|
||||
return -1;
|
||||
}
|
||||
|
||||
if ((dev = malloc(sizeof(*dev))) == NULL) {
|
||||
errno = ENOMEM;
|
||||
return -1;
|
||||
}
|
||||
|
||||
dev->type = type;
|
||||
dev->data = data;
|
||||
dev->next = NULL;
|
||||
*res = dev;
|
||||
return 0;
|
||||
}
|
||||
|
||||
void
|
||||
bus_dev_free(struct mvm_bus_dev *dev)
|
||||
{
|
||||
if (dev == NULL) {
|
||||
return;
|
||||
}
|
||||
|
||||
free(dev);
|
||||
}
|
||||
|
||||
int
|
||||
bus_ctl_append(struct mvm_bus_ctl *busctl, struct mvm_bus_dev *dev)
|
||||
{
|
||||
if (busctl == NULL || dev == NULL) {
|
||||
errno = EINVAL;
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (busctl->head == NULL || busctl->tail == NULL) {
|
||||
busctl->head = dev;
|
||||
busctl->tail = dev;
|
||||
} else {
|
||||
busctl->tail->next = dev;
|
||||
busctl->tail = dev;
|
||||
}
|
||||
|
||||
++busctl->dev_count;
|
||||
return 0;
|
||||
}
|
||||
|
||||
void
|
||||
bus_ctl_free(struct mvm_bus_ctl *busctl)
|
||||
{
|
||||
struct mvm_bus_dev *dev, *tmp;
|
||||
|
||||
if (busctl == NULL) {
|
||||
return;
|
||||
}
|
||||
|
||||
if ((dev = busctl->head) == NULL) {
|
||||
return;
|
||||
}
|
||||
|
||||
while (dev != NULL) {
|
||||
tmp = dev;
|
||||
bus_dev_free(tmp);
|
||||
dev = dev->next;
|
||||
}
|
||||
|
||||
busctl->head = NULL;
|
||||
busctl->tail = NULL;
|
||||
}
|
||||
@@ -0,0 +1,98 @@
|
||||
/*
|
||||
* Copyright (c) 2026 Mirocom Laboratories and MSP engineers.
|
||||
* All Rights Reserved.
|
||||
*/
|
||||
|
||||
#ifndef MVM_BUS_H
|
||||
#define MVM_BUS_H 1
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
/*
|
||||
* Represents valid device types that can be
|
||||
* on the bus.
|
||||
*
|
||||
* @BUS_DEV_NONE: No associated type
|
||||
* @BUS_DEV_ROM: This device is a ROM module
|
||||
*/
|
||||
typedef enum {
|
||||
BUS_DEV_NONE,
|
||||
BUS_DEV_ROM
|
||||
} mvm_devtype_t;
|
||||
|
||||
/*
|
||||
* Represents a device on the bus
|
||||
*
|
||||
* @type: Device type
|
||||
* @data: Device specific descriptor
|
||||
* @next: Next device in list
|
||||
*/
|
||||
struct mvm_bus_dev {
|
||||
mvm_devtype_t type;
|
||||
void *data;
|
||||
struct mvm_bus_dev *next;
|
||||
};
|
||||
|
||||
/*
|
||||
* Represents the bus control / management structure
|
||||
* that keeps track of all registered devices.
|
||||
*
|
||||
* @head: Dequeue point
|
||||
* @tail: Enqueue point
|
||||
* @dev_count: Number of devices attached
|
||||
*
|
||||
*/
|
||||
struct mvm_bus_ctl {
|
||||
struct mvm_bus_dev *head;
|
||||
struct mvm_bus_dev *tail;
|
||||
size_t dev_count;
|
||||
};
|
||||
|
||||
/*
|
||||
* Append a device to a bus control descriptor
|
||||
*
|
||||
* @busctl: Bus control descriptor to append to
|
||||
* @dev: Device to append
|
||||
*
|
||||
* Returns zero on success
|
||||
*/
|
||||
int bus_ctl_append(struct mvm_bus_ctl *busctl, struct mvm_bus_dev *dev);
|
||||
|
||||
/*
|
||||
* Allocate a new bus device
|
||||
*
|
||||
* @type: Device type
|
||||
* @data: Device specific data
|
||||
* @res: Result is written here
|
||||
*
|
||||
* Returns zero on success
|
||||
*/
|
||||
int bus_dev_alloc(mvm_devtype_t type, void *data, struct mvm_bus_dev **res);
|
||||
|
||||
/*
|
||||
* Deallocate resources associated with a bus device
|
||||
* descriptor
|
||||
*
|
||||
* @dev: Device descriptor to release
|
||||
*/
|
||||
void bus_dev_free(struct mvm_bus_dev *dev);
|
||||
|
||||
/*
|
||||
* Deallocate resources associated with a bus control
|
||||
* descriptor
|
||||
*
|
||||
* @busctl: Bus control descriptor to release
|
||||
*/
|
||||
void bus_ctl_free(struct mvm_bus_ctl *busctl);
|
||||
|
||||
/*
|
||||
* Initialize a bus control descriptor
|
||||
*
|
||||
* @busctl: Descriptor to initialize
|
||||
*
|
||||
* Returns zero on success
|
||||
*/
|
||||
int bus_ctl_init(struct mvm_bus_ctl *busctl);
|
||||
|
||||
#endif /* !MVM_BUS_H */
|
||||
Reference in New Issue
Block a user