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