Skip to content

Commit

Permalink
Intial RX path working
Browse files Browse the repository at this point in the history
Signed-off-by: Sebastian Schildt <[email protected]>
  • Loading branch information
SebastianSchildt committed Jan 9, 2025
1 parent 6831901 commit 22231c5
Show file tree
Hide file tree
Showing 4 changed files with 67 additions and 9 deletions.
70 changes: 64 additions & 6 deletions examples/acf-can/linux-kernel-mod/1722ethernet.c
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
#include <linux/netdevice.h>
#include <linux/etherdevice.h>
#include <linux/skbuff.h>
#include <linux/can/core.h>
#include <linux/if_ether.h>
#include <linux/timekeeping.h>

Expand Down Expand Up @@ -150,10 +151,10 @@ int ieee1722_packet_handdler(struct sk_buff *skb, struct net_device *dev,
}


printk(KERN_INFO "Received packet: src=%pM, dst=%pM, proto=0x%04x\n",
printk(KERN_INFO "Received packet: src=%pM, dst=%pM, proto=0x%04x ",
eth->h_source, eth->h_dest, ntohs(eth->h_proto));

printk(KERN_INFO "Data: ");
printk(KERN_CONT "Data: ");
for (int i = 0; i < skb->len; i++)
{
printk(KERN_CONT "%02x ", skb->data[i]);
Expand Down Expand Up @@ -211,11 +212,68 @@ int ieee1722_packet_handdler(struct sk_buff *skb, struct net_device *dev,
return NET_RX_DROP;
}

//Forward the packet
uint8_t is_fd=Avtp_Can_GetFdf(can);
struct sk_buff *can_skb;
struct can_frame *cf;
struct canfd_frame *cfd;

int err;

// Process the packet here
//return RX_HANDLER_PASS; // Pass the packet to the next handler
return NET_RX_SUCCESS;


// Allocate a CAN skb
if (is_fd) {
can_skb = alloc_canfd_skb(can_dev, &cfd);
cf=(struct can_frame *)cfd; //This is a bit of a hack, but we know that the first part of the canfd_frame is the same as can_frame
} else {
can_skb = alloc_can_skb(can_dev, &cf);
}
if (!can_skb) {
printk(KERN_ERR "Failed to allocate CAN skb\n");
return NET_RX_DROP;
}

cf->can_id = Avtp_Can_GetCanIdentifier(can);
if (Avtp_Can_GetEff(can)) {
cf->can_id |= CAN_EFF_FLAG;
}
if (Avtp_Can_GetRtr(can)) {
cf->can_id |= CAN_RTR_FLAG;
}
cf->can_dlc = msg_length - AVTP_CAN_HEADER_LEN - Avtp_Can_GetPad(can);

if (is_fd) {
cfd->flags = 0;
if (Avtp_Can_GetBrs(can)) {
cfd->flags |= CANFD_BRS;
}
if (Avtp_Can_GetFdf(can)) {
cfd->flags |= CANFD_FDF;
}
if (Avtp_Can_GetEsi(can)) {
cfd->flags |= CANFD_ESI;
}
}

if (is_fd && cf->can_dlc > CANFD_MAX_DLEN) {
printk(KERN_ERR "DLC too large for CAN FD\n");
return NET_RX_DROP;
}
else if (!is_fd && cf->can_dlc > CAN_MAX_DLEN) {
printk(KERN_ERR "DLC too large for CAN\n");
return NET_RX_DROP;
}

memcpy(cf->data, skb->data + sizeof(Avtp_Ntscf_t) + sizeof(Avtp_Can_t), cf->can_dlc);

// Send the CAN skb
err = can_send(can_skb, 1);
if (err) {
printk(KERN_ERR "Failed to send CAN skb: %d\n", err);
kfree_skb(skb);
return NET_RX_DROP;
}

return NET_RX_SUCCESS;
}

2 changes: 1 addition & 1 deletion examples/acf-can/linux-kernel-mod/1722ethernet.h
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ typedef struct {
Avtp_Ntscf_t ntscf;
// IEEE 1722 ACF message #1
Avtp_Can_t can;
} ACFCANPdu_t;
} __attribute__((packed)) ACFCANPdu_t;


void prepare_ntscf_header(Avtp_Ntscf_t *ntscf_header, struct acfcan_cfg *cfg);
Expand Down
2 changes: 1 addition & 1 deletion include/avtp/acf/Can.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ extern "C" {
typedef struct {
uint8_t header[AVTP_CAN_HEADER_LEN];
uint8_t payload[0];
} Avtp_Can_t;
} __attribute__((packed)) Avtp_Can_t;

typedef enum {
AVTP_CAN_CLASSIC = 0,
Expand Down
2 changes: 1 addition & 1 deletion include/avtp/acf/Ntscf.h
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ extern "C" {
typedef struct {
uint8_t header[AVTP_NTSCF_HEADER_LEN];
uint8_t payload[0];
} Avtp_Ntscf_t;
} __attribute__((packed)) Avtp_Ntscf_t;

typedef enum {
AVTP_NTSCF_FIELD_SUBTYPE,
Expand Down

0 comments on commit 22231c5

Please sign in to comment.